| 일 | 월 | 화 | 수 | 목 | 금 | 토 |
|---|---|---|---|---|---|---|
| 1 | ||||||
| 2 | 3 | 4 | 5 | 6 | 7 | 8 |
| 9 | 10 | 11 | 12 | 13 | 14 | 15 |
| 16 | 17 | 18 | 19 | 20 | 21 | 22 |
| 23 | 24 | 25 | 26 | 27 | 28 | 29 |
| 30 |
- 톰캣
- redis + spring boot 함께
- aws elasticache 활용
- catalina.out
- insert
- mysql
- Linux
- jQuery
- springboot+redis
- 정규식
- docker 컨테이너로 띄우기
- Tomcat
- Java
- feignClient
- 만들면서 배우는 클린 아키텍처
- js
- 엔티티 코드 치환
- 리눅스
- select
- architecture
- Entity Code 치환
- Docker Compose
- 자바
- 특수문자 치환
- javascript
- 자바스크립트
- for문
- 제이쿼리
- sftp
- 초단위
- Today
- Total
목록전체 글 (74)
꾸준하게, 차근차근
배포 환경의 인프라를 구성했으니 AWS EC2에서 Docker Compose로 Redis + Spring Boot를 한 번에 띄워봐야하지 않겠는가! 1. Dockerfile 만들기EC2 내에서 사용할 Dockerfile을 생성한다.로컬 환경에서 사용할 파일과 배포 환경에서 사용할 파일을 구분하기 위해 이번엔 Dockerfile-prod로 생성하자.FROM openjdk:17-jdkCOPY build/libs/*SNAPSHOT.jar app.jar# 배포 환경 profiles를 지정해줘야 하기 때문에 명령어가 추가되었다ENTRYPOINT ["java", "-jar", "-Dspring.profiles.active=prod", "/app.jar"] 2. compose.yml 파일 만들기compose.yml ..
백엔드 개발을 하다 보면 Docker를 자주 활용하는 것을 알 수 있다.따라서 이번엔 Docker Compose로 Redis와 Spring Boot를 한 번에 띄울 수 있게 구성을 진행해보려 한다. 1. Dockerfile 만들기Spring Boot 프로젝트 root 디렉토리에 Dockerfile을 생성한다.# JDK17을 사용해서FROM openjdk:17-jdk# 빌드한 파일을 복사해와서COPY build/libs/*SNAPSHOT.jar app.jar# 복사한 파일을 기반으로 실행ENTRYPOINT ["java", "-jar", "/app.jar"] 2. compose.yml 파일 만들기이 파일도 Spring Boot 프로젝트 root 디렉토리에 생성하면 된다.services: api-serve..
1. 부하 테스트의 기본 개념우리가 실제 서비스를 배포 하기 전, 문득 이런 생각이 들 수 있다."우리 서버에 요청이 몰려서 서버가 터지면 어떡하지?""트래픽이 몰려 갑자기 서버가 죽으면 어떡하지?" 이런 문제를 사전에 방지하기 위해 배포 전 우리는 부하 테스트를 진행해봐야 한다. 우선 부하 테스트의 의미를 먼저 알아보자.부하 테스트는 서비스를 배포하기 전, 서버가 어느 정도의 요청을 견딜 수 있는지 확인하는 과정을 의미한다. 부하 테스트 진행할 때 사용하는 용어에 대해서도 알아볼까?Throughput: 1초당 처리할 수 있는 작업량TPS(Transaction Per Seconds): 1초당 처리한 요청의 수만약 내가 처리한 서버가 1초당 최대 100개의 API 요청을 처리할 수 있다고 가정한다면,해당 ..
1. EC2에 Redis 설치 생성한 EC2에 접속하기 위해 연결을 클릭한다. 연결을 누르면 EC2 인스턴스에 원격 접속을 하게 된다. EC2 인스턴스에 접속이 완료되었다. Redis 설치# apt update 명령어sudo apt update# Redis 설치 명령어sudo apt install redis Redis 설치 및 통신 확인 2. EC2에 JDK 설치JDK 설치 JDK 설치 여부 확인 3. Spring Boot 프로젝트에 배포 환경 설정 추가로컬 환경과 분리하여 배포 환경의 설정을 추가해준다.데이터베이스 설정 정보는 일전에 생성한 RDS의 정보로 작성한다.# local 환경spring: profiles: default: local datasource: url: jdbc:mysq..
현업에서 사용하고 있는 환경과 최대한 비슷하게 환경을 구성하기 위해 AWS EC2에서 Redis를 활용해보고,Redis 적용 전,후의 성능을 또 비교해보자! 1. 배포 환경 인프라 구성이제 로컬 환경이 아닌 실제 배포 환경의 인프라를 구성해서 사용해보려고 한다.배포 환경 아키텍처는 아래와 같이 구성한다. 아키텍처 구성AWS EC2RDSSpring BootRedis사용자는 EC2를 통해 데이터를 요청 하고, EC2 내부에는 Spring과 Redis를 같이 설치한다.데이터베이스는 EC2 내부가 아닌 외부 RDS를 통해 통신할 수 있도록 하자! 2. EC2 생성 AWS 홈페이지에 로그인한 후, EC2를 검색해서 클릭한다. 리전이 서울인 것을 확인하고 인스턴스 시작을 클릭한다. 이름 및 태그는 서버 이름을 작성..
드디어 Spring Boot에 Redis를 연동하고 성능 테스트 내용까지 다뤄보자!이론도 이론이지만 실습이 더 재밌는건 어쩔 수 없다! 1. Spring Boot 프로젝트에 Redis 세팅 추가build.gradle 파일에 Redis 의존성 먼저 추가해야 한다.implementation 'org.springframework.boot:spring-boot-starter-data-redis' 의존성을 추가하고 추가한 의존성이 프로젝트에 빌드될 수 있도록 오른쪽 상단에 있는 코끼리 새로고침 표시를 눌러줘야 한다. 2. application.yml 설정 파일 수정Redis 연동에 필요한 설정과 Redis 사용에 대한 로그가 찍힐 수 있도록 설정을 추가해준다.spring: profiles: default:..
Redis의 기본 개념부터 전략까지 머릿속에 넣었으니 이제 활용해볼 때이다!익숙한 Spring Boot를 활용해서 Redis를 구현해볼까? 1. Spring Boot 프로젝트 생성Spring Boot 프로젝트 세팅 환경은 참고로 작성한다.Spring Boot 3.x.x 버전MySQL 8.x 버전 이상JDK 17 우선 IntelliJ Ultimate 버전을 사용하고 있어 사이트를 통하지 않고 프로젝트를 진행하는 방법만 다룰 예정이다.Community Edition 버전을 사용하거나 다른 IDE 사용 유저들은 사이트를 통해 진행할 수 있도록 링크를 공유해놓을테니 참고하시면 좋겠다. Community Edition, 다른 IDE 사용 유저 프로젝트 세팅 참고https://start.spring.io/ Ulti..
Redis의 기본 개념을 다지면서 Redis의 장점도 알게 되었고 기본 명령어 7가지와 Key의 네이밍 컨벤션까지 다지게 되었다.이제 어떤 전략이 실무에서 자주 활용되는지 머릿속에 넣어보자! 1. 캐시(Cache)란?원본 저장소보다 데이터를 빠르게 가져올 수 있는 임시 데이터 저장소를 의미한다.Chrome에서도 사용자에게 웹브라우저를 빠르게 제공하기 위해 브라우저에 이미지와 파일들을 캐시해둔다. 캐시는 Redis에서만 사용되는 용어는 아니고 전반적인 개발 분야에서는 통용되어서 사용되는 용어라 개발 분야에서는 굉장히 중요하다. 2. 캐싱(Caching)이란?임시 데이터 저장소에서 빠르게 데이터를 가져오는 방식이라고 이해하면 된다. 3. 현업에서 가장 많이 사용되는 Caching 전략Caching 전략은 구..