본문 바로가기
반응형

문제 해결, 기술 비교/개인프로젝트(북클럽)25

cache란? Redis를 cache로 조회 성능 개선하기 cache란? 캐시란, 나중에 요청될 결과를 미리 저장해두었다가 빠르게 서비스를 해주는 것을 의미합니다. 예를 들어 Factorial의 Dynamic programming이 있습니다. 미리 계산을 해두면 나중에 계산을 또 하지 않아도 됩니다. 4! = 4 * 3!입니다. 3!은  3! = 3 * 2!입니다. 이렇게 3!을 미리 저장해두고 4!에 이용하면 빠르게 계산 할 수 있습니다.  캐싱 전략(Caching Strategy) 캐싱전략은 크게 Look aside Cache와 Write Back 2가지 방식이 있습니다. 또한 Write에는 Cache 데이터 저장 여부에 따라 Write-Around, Write-Through 2가지가 있습니다. 1. Look aside Cache(Lazy Loading) 이.. 2022. 6. 20.
Redis를 로그인 Session Storage로 이용하기 외부 Session Storage 사용 이유 다수의 서버에서 세션을 관리하는 방법은 여러가지가 있는데, 최종적으로 외부 Session Storage를 사용하도록 결정했습니다. 외부에서 로그인 정보를 따로 관리한다면, 다음과 같은 장점이 있습니다. 톰캣 서버에 문제가 있더라도 영향을 받지 않을 수 있다. 배포하는 과정에서 생기는 세션 관리에도 전혀 영향을 받지 않는다 여러 서버 세션 정보의 정합성을 유지할 수 있다 세션을 다루는 부분을 Redis에서 관리하도록 개선할 예정입니다. Redis는 In-memory 저장소로, key-value 방식을 이용해 고속 쓰기 및 읽기 처리가 가능합니다. 세션 자체가 복잡한 연산과 계산을 필요로 하지 않으므로 적절합니다. Redis 코드에 추가하기 gradle에 의존성 .. 2022. 6. 17.
분산 서버에서 Session 관리하기 분산서버에서 로그인 관련 Session을 어떻게 관리할지 생각해봅니다. 일단 Load Balancer를 통해, 여러명의 사용자가 여러대의 서버에 요청을 보낸다고 가정합니다. 가장 기초의 Load Balancer Load Balancer를 사용한 일반적인 서버 관리의 경우 다음처럼 round-robin(기본설정) 알고리즘으로 서버에 요청이 갑니다. User1과 User2의 요청이 Load Balancer를 거치면, Server1, Server2에 다양하게 라우팅 됩니다. 하지만, 이렇게 다양한 SERVER로 로드 밸런싱이 된다면 다음과 같은 문제에 직면합니다. 1. User1이 Server1에 요청을 보내어 로그인을 합니다. 2. User1이 Server1에서 웹 사이트를 이용합니다. 3. 잠시 후 ser.. 2022. 6. 17.
sentry.io로 에러 로그 관리하기 개요 다양한 로그 수집을 알아보다가 최근에 많이 사용하는 sentry을 알게되었습니다. sentry가 무엇이고 어떻게 사용하는지 코드로 함께 알아보겠습니다. Sentry란? Sentry란 Application 에러 트래킹, 성능 모니터링을 제공해주는 서비스입니다. 에러가 발생하면 알림을 받을 수 있고 에러에 대한 상세 정보를 트래킹 해줍니다. 특히 에러 상황을 자세히 알려주기 때문에 디버깅에 유용합니다. 또한 성능 모니터링을 이용해 각 지표들을 쉽게 확인할 수 있습니다. 다양한 플랫폼 지원 아무래도 하나의 기업은 몇 가지 기술이 아닌 수십 가지 기술을 사용할 확률이 높습니다. sentry는 방대한 플랫폼을 지원하기 때문에 어떠한 기술을 사용하여도 모두 호환이 가능합니다. 상세한 디버깅 기능 제공 전통적인.. 2022. 6. 1.
Elastic Search 연동 및 테스트하기 Elastic search란? Elasticsearch는 분산 검색과 분석 도구입니다. Elasticsearch로 정형화, 비정형화, 숫자 데이터, 지역 데이터 등 다양한 데이터를 빠르게 검색할 수 있습니다. 이를 인덱싱(indexing)이라고 합니다. 단순한 데이터 검색과 데이터에서 패턴을 발견하기 위해 정보를 수집할 수 있습니다. 데이터와 쿼리의 크기가 증가하면서, Elasticsearch의 분산 환경은 배포가 그에따라 원활하게 확장하도록 합니다. indexing : 원본 데이터를 변환하여 저장하는 과정으로 데이터가 효율적으로 검색 될 수 있는 구조로 변경됩니다. indices, index : indexing 과정을 통해 생성된 결과물이자 저장소입니다. 역색인(Inverted Index) 아래는 일반.. 2022. 5. 27.
RabbitMQ 이용해서 글 작성하기 오늘날, 많은 시스템은 단일 애플리케이션에서 다중 애플리케이션으로, 계산 중심에서 데이터 중심으로 확장되고 있습니다. 그에 따라, 외부 연동 서버를 이용도 증가하고 있으며 효율적인 관리 기술이 필요합니다. 다양한 외부 서버를 연동하면서 비동기 처리를 하기 위한 솔루션들이 많은데 이 중에 하나인 RabbitMQ를 알아봅니다. * AMQP(Advanced Message Queuing Protocol) 먼저, MQ (Message Queue) 란 메시지 기반의 미들웨어로 메시지를 이용하여 여러 어플리케이션, 시스템, 서비스들을 연결해주는 솔루션입니다. MOM(Message Oriented Middleware) 를 구현한 솔루션으로 비동기 메시지를 사용하는 서비스들 사이에서 데이터를 교환해주는 역할을 합니다. .. 2022. 5. 27.
cerbot로 SSL 인증서 만들기 개요 ubuntu 18.04 환경에서 개인 프로젝트를 하던 중, Spring Security를 활용한 로그인을 하던 중 http에 https 적용하고 싶었습니다. 실제 운영에서는 https 적용을 위해 한국 전자인증에서 도메인에 맞는 SSL을 구입하여 적용하였습니다. Cerbot이란? Cerbot는 무료로 TLS인증서를 발급받을 수 있는 라이브러리로 Let's Encrypt라는 비영리 기관에서 관리됩니다. 루트 도매인, 서브 도매인, 와일드카드 도매인 인증서까지 무료로 발급 받을 수 있습니다. Apache와 nginx에 TLS/SSL 설정이 자동으로 되어 nginx에 많이 사용됩니다. 시스템 관리자로 웹서버에서 다이렉트로 사용됩니다. cerbot 설치하기 //certbot 을 설치 하기 위해 먼저 epe.. 2022. 5. 24.
application.yml 분리하기 application.yml 설정이 테스트환경과 운영환경 등으로 나눠질 수 있습니다. 이 설정은 여러개의 파일로 나눠도 되고, 하나의 파일에도 가능합니다 먼저 여러개의 파일로 분리하는 방법입니다. # application.yml spring: profiles: dev # application-dev.yml spring: profiles: dev ... #application-prod.yml spring: profiles: prod ... application.yml에서 사용하고자 하는 profiles에 명칭을 써주면 됩니다. 만약에 intellij에서 강제로 항상 특정 profiles 실행을 하고 싶다면, Edit Configurations에서 새로운 환경을 추가합니다 다음과 같이 기본 App설정에서 A.. 2022. 5. 22.
jenkins build시, slack 알람 연동하기 새로운 채널을 만든 다음에 다음과 같이 Slack 찾아보기에서 앱에 들어갑니다. 새로운 채널로 test-notification을 만듭니다. Jenkins CI 에서 추가를 누르면 브라우저로 연동이 됩니다. 내가 만든 test-notification에 Jenkins CI를 연동합니다 그 다음에 어떻게 연동해야하는지 친절하게 설명이 나와있으므로 추가해주면 됩니다. Jenkins의 플러그인 설치로 들어가 slack notification을 설치합니다. 설치가 끝나면 자동으로 재시작을 합니다. Jenkins 관리 - 시스템 설정에서 slack으로 이동해 환경설정을 합니다 workspace는 Jenkins 사이트에 있는 팀 하위 도메인을 입력합니다 default channel은 내가 만든 채널이름을 입력합니다 s.. 2022. 5. 22.
반응형