본문 바로가기

프로젝트17

Redis Cache를 이용한 애플리케이션 성능 향상시키는 방법 캐싱이란 무엇인가 오랜 시간이 걸리는 작업의 결과를 저장해서 향후 동일한 요청 시 시간과 비용을 단축시키는 기법입니다. 고성능 애플리케이션을 만드는데 가장 중요한 포인트 중 하나입니다. 캐싱의 종류 및 비교 캐싱에는 크게 로컬캐싱과 글로벌 캐싱으로 나누어서 생각해볼 수 있습니다. 로컬 캐싱 : WAS 서버에서 사용 글로벌 캐싱 : 별도의 캐시 서버를 둬서 사용 로컬캐싱 vs 글로벌 캐싱 항목 로컬 캐싱 글로벌 캐싱 저장위치 애플리케이션 서버에 저장 별도의 캐시 서버에 저장 데이터간 공유 다른 서버에서 참조하기 어려움 서버간 데이터 공유 쉬움 Memory, Disk 사용 애플리케이션 장비와 공유 별도의 서버를 사용함으로 해당 서버의 리소스를 모두 사용가능 캐시 데이터 변경 시 - 해당 서버를 제외하고 모든.. 2021. 8. 11.
Jenkins를 사용한 CI 구성 젠킨스의 설치 과정은 공식사이트에 잘 설명되어 있으니 설치방법에 대해서는 링크로 대신하겠습니다. Jenkins를 설치했으면 정상적으로 서비스가 동작하는지 확인합니다. sudo systemctl start jenkins sudo systemctl stop jenkins sudo systemctl restart jenkins Jenkins는 기본 포트가 8080이며, 혹시라도 접속이 안될 시 방화벽을 확인합니다. CI를 사용할 프로젝트를 생성합니다. 생성 시 Pipeline을 선택합니다. 그리고 Github에 pull request를 수신하기 위해서는 플러그인을 설치해야 합니다. GitHub Pull Request Builder 플러그인을 설치합니다. 플러그인을 설치 후 아까 만들어둔 프로젝트 설정으로 돌아.. 2021. 8. 5.
CI/CD 왜 필요한가? 진행하고 있는 프로젝트에 여러 기능들이 들어감에 따라 실제 서버에 배포하여 성능 테스트 및 개발을 동시에 진행해야 될 상황이 되었습니다. 그래서 지금까지는 Local 환경에서 테스트하고 개발하였지만, 이제는 실제 서버 환경에 배포도 하고 개발한 내용을 지속적으로 반영하는 등 CI/CD 작업이 필요해 보였습니다. CI..? CD..?🤔 우선 처음 CI, CD를 처음 사용해보는 것 이어서 개념을 정리하려고 합니다. CI (Continuous Integration) 지속적인 통합.. 왜 해야 할까요?? 많은 개발자들이 개발을 할 때 이젠 필수적으로 사용하는 것이 있습니다. 바로 버전 관리 툴(Git, SVN)입니다. 개발자들은 버전 관리 툴을 이용하여 기능별 feature를 만들고 개발하고 머지를 반복합니다... 2021. 8. 5.
Session Storage 선택과정 Storage라 하면 크게 SQL, NoSQL을 생각해볼 수 있습니다. SQL databases Db2 MySQL PostgreSQL Oracle Database Microsoft SQL Server NoSQL databases Redis MongoDB Elasticsearch Memcached 하지만 Session을 저장하기위해 사용하는 부분인 만큼 빠른 응답속도가 뒷받침되어야 했습니다. 여기서 잠깐 정리하자면 왜 빨라야 할까요? 현재 제가 토이 프로젝트로 진행하고있는 Careers에서는 로그인 세션을 저장하고 관리할 Storage를 찾고 있습니다. 당연히 서비스를 이용하기 위해서는 로그인을 한 상태여야 하며, 이는 서버가 모든 요청이 들어올 때 마다 Session Storage에 가서 Set-Cook.. 2021. 7. 29.
Jenkins를 통한 CI/CD 도입 젠킨스를 사용한 이유 https://github.com/f-lab-edu/careers 프로젝트를 어느정도 진행하다보니 CI/CD를 적용해야될 때가 되었다. 자바진영에서는 CI/CD 툴로 젠킨스를 가장 많이 사용하는 걸로 알고있다. 그래서 젠킨스의 CI/CD를 도입하여 프로젝트 개발에만 집중할 수 있도록 이참에 환경 구성을 해보았다. CI란 Continuous Integration 즉 지속적인 통합을 의미한다. 개발자가 개발을 하면 그 코드들은 결국은 다른 여러 개발자들과의 코드들과 Merge가 되어야 한다. 이때 CI를 반영하지 않고 나중에 몰아서 처리하게 된다면 Merge양과 범위에 따라 개발자들의 시간과 리소스를 투자해야 한다. 하지만 CI를 사용하면 CI툴이 특정 이벤트를 받아 빌드, 테스트, M.. 2021. 7. 7.
Java CheckStyle 적용 프로젝트를 진행하면서 혼자 코드를 작성하는 것이 아니라 협업을 하다 보니 코드 품질이 떨어지는 현상이 발생하였습니다. 이를 해결하기 위해 프로젝트에 CheckStyle을 반영하는 과정을 공유하고자 합니다. Intellij에 Checkstyle반영 처음에는 각자의 IDE에 checkstyle 파일을 다운받아 개발 시 적용될 수 있도록 설정하였습니다. 몇몇 설정들은 상의하에 수정하여 가독성을 향상시켰습니다. 하지만 프로젝트가 진행될수록 간헐적으로 자동정렬 단축키를 누르지 못한 파일들이 생겨나고 카멜표기법 등 일관되지 않는 코드들이 커밋되어가고 있었습니다. 이런 문제들이 종종 발생하여 다른 방법을 찾아보게 되었습니다. Git Pre commit에 Checkstyle 적용 찾아보니 Git에서는 Pre Commi.. 2021. 6. 10.
대규모 서버들의 세션 처리방법 들어가기기 앞서... 이전 포스팅에서 말씀드린대로 Scale out을 프로젝트에 반영하기로 하였습니다. 혹시라도 왜 Scale up이 아닌 Scale out을 선택하였는지 궁금하신 분들이 있으시다면 이전 포스팅을 참고 부탁드립니다. Scale out을 반영한다고 했는데 너무 막연했습니다. 뭘 어떻게 해야하지?? 일단 사용자의 요청부터 의식의 흐름대로 생각해 보도록 하였습니다. 대규모 트래픽을 감당하기위해 서버를 여러 대 두었고.. 그러면 사용자들이 로그인을 하고 A서버에 접근해서 데이터를 가져오고 그 다음 요청할때 A가 아닌 B서버에서 데이터를 가져오고.. 🤔....? 데이터를 가져올 수 있나? A서버로 로그인 요청을 처리해서 B 서버는 세션정보가 없는데..? 그럼 로그인 요청을 처리한 A서버 한테만 요.. 2021. 4. 29.
대규모 트래픽을 고려한 서버 확장 방법 요즘 제공되는 거의 모든 IT 서비스들은 네트워크를 통해 서버와 통신을 하여 사용자에게 원하는 데이터를 제공해 줍니다. 이 말을 달리 표현하자면 사용자들의 요청에 비례하여 서버의 처리량은 증가할 수밖에 없습니다. 서버의 처리량 증가라는 말은 서버의 부하가 증가한다는 말과 동일하며 부하를 감당하지 못하는 서버는 사용자가 요청한 정보를 신속하게 처리할 수 없게 됩니다. 이러한 문제점을 해결하기 위한 방안으로 Scale up, Scale out이란 개념이 있습니다. 이후 내용은 제가 토이프로젝트를 하면서 어떻게 고민하고 어떤방식을 도입하였는지 등의 고민들을 함께 나눠 보고자 합니다. 일단 진행하기에 앞서 간단하게 Scale up , Scale out에 대한 개념을 정리해 보고자 합니다. 개념정리 Scale o.. 2021. 4. 6.