Spring Boot 를 AWS 로 배포해보자.
PRJ : Spring Boot (java17)
배포 : Elastic Beanstalk
DB : RDS (MySQL) Elastic Cache Redis
CI/CD : GithubAcations
이전 포스팅에서 RDS
를 통해 데이터 베이스 연결에 성공했다.
Elastic Cache
를 이용해 Redis
를 연결하자
ElasticCache
검색 후 이동한다.
지금 시작
-> Redis
를 클릭
특이 사항은 없다. 위와 같이 설정.
복제본 갯수를 0개로 해야 다중 AZ
, 자동 장애 조치
옵션을 비활성화 할 수 있다.
서브넷 그룹 설정.
클러스터 생성 완료.
ElasticCache
-> Redis 캐시
-> 클러스터
생성이 완료되면 엔드포인트를 얻을 수 있다.
해당 엔드포인트의 접근 권한을 설정하자.
인바운드 규칙에서 위와 같이 설정한다. 포트는 6379
Redis
가 잘 생성된 것인가?
확인을 위해 로컬에서 접속하려 했지만 접속이 불가하다.
EC2
로 들어가서 확인을 해야하는 상황이다.
Elastic Beanstalk
로 생성하면 SSH
에 접속할 수 있는 키 페어 생성하는 설정이 없다.
키 페어 생성 후 EB 환경
과 맵핑 해주자.
EC2
-> 키 페어
-> 키 페어 생성
키 페어 이름을 설정해 주고 위와 같이 설정. (Mac)
키 페어 생성
클릭
한 번 발급된 Key
는 재 발급이 불가하므로, .csv
를 다운 받거나 메모한다.
EB
가 생성한 EC2
에 보안에서 인바운드 규칙을 추가해주자.
EB
-> 구성
-> 서비스 액세스
-> 편집
위에서 생성한 키를 EC2 키 페어
에 추가해준다. 적용
클릭
# 키 페어가 있는 위치에서
# 키 페어 400 으로 권한 변경
$ chmod 400 key.pem
# EC2 ssh 접속
$ ssh -i key.pem ec2-user@`퍼블릭 IPv4 주소`
$ ssh -i
접속할 때의 주소다.
"The authenticity of host .....(yes/no)?" 와 같은 메시지가 뜨면 "yes" 엔터
접속이 완료된 모습
EC2
-> 보안 그룹
-> 사용하고 있는 인바운드 규칙에 6379
를 추가한다.
redis-cli 구축을 위해 GNU 컴파일러 모음(gcc)을 설치한다.
$ sudo yum install gcc
아래의 명령어를 입력해 redis-cli 를 설치한다
$ wget http://download.redis.io/redis-stable.tar.gz
$ tar xvzf redis-stable.tar.gz
$ cd redis-stable
$ make distclean # ubuntu 에서만 입력한다 (생략 가능)
$ make
아래 명령어로 접속을 해보자!
$ src/redis-cli -c -h `mycachecluster.eaogs8.0001.usw2.cache.amazonaws.com` -p `6379`
접근이 되었다면 redis-cli
명령어를 통해 확인할 수 있다.
$ keys *
EB
-> 환경
-> 구성
-> 업데이트, 모니터링 및 로깅
-> 편집
-> 환경 속성
에서
Key:Value 로 Redis 를 설정해준다.
(ex. mycachecluster.eaogs8.0001.usw2.cache.amazonaws.com)
6379
5000
(배포를 위한)application.yml 도 설정해준다.
참고
https://docs.aws.amazon.com/ko_kr/AmazonElastiCache/latest/red-ug/nodes-connecting.html