해결된 질문
작성
·
70
0
yml의 설정 내용을 암호화하는 작업중에 궁금한 점이 있습니다.
암호화해도 http://config server주소/config파일명/프로파일 경로로 접속하면 해독된 값을 볼 수 있는데 이러면 암호화한 의미가 있는지 궁금합니다
config 서버에서 http://config server주소/config파일명/프로파일 경로를 비활성화하는 방법이 있을까요?
그리고 비대칭키에서 암호화에 사용하는 password는 평문으로 yml에 저장하고 있는데 이러면 반쪽짜리(?) 암호화일 것 같은데 이렇게 사용해도 되는건지가 궁금합니다
답변 2
1
안녕하세요, 이도원입니다.
문의 내용에 답변 및 제 의견 남겨드립니다.
먼저, 1번과 2번에 대한 답변이 비슷한 내용일 것 같습니다. config server에 대한 URL를 직접 접근하게 되면, 말씀하신 내용처럼 암호화된 부분에 대해 노출이 될 수 밖에 없습니다. 따라서 비활성화 작업이 필요할 경우에는 URL제한 및 인증처리를 추가해 볼 수 있습니다. 간단하게 spring config-service에 엑세스 제한을 추가해 보기 위해 아래 코드와 같이 spring-security를 추가하고 실행해 보면,
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-security</artifactId>
</dependency>
위와 같이 기본 password를 확인하실 수 있습니다. 그리고, htpp://localhost:8888으로 엑세스 해보면, 아래와 같이 인증 정보를 물어보는데, 여기
username: user
password: [위 콘솔 로그에 출력 된 암호 ex, 037f3402-0d6d-4c77-9800-03af8e45eba0]
를 입력하고 접속하시면 원래의 configuration 정보를 확인하실 수 있습니다. 이 부분은 spring-security하고도 관련 있는 부분이기 때문에, username/password 변경이나 password의 암호화 등을 응용해 보실 수 있을 것 같습니다.
마지막으로, 비대칭암호에 필요한 password를 설정파일(yaml, properties)에 평문으로 작성하시다고 한 부분은, 암호 자체를 설정 파일이 아닌 다른 방법(ex, 실행 시 파라미터나 다른 암호화 파일 등)으로 보관하여 실행해 보실 수 있습니다.
encrypt:
key-store:
location: classpath:/config-server.jks
password: ${KEYSTORE_PASSWORD}
alias: config-server-key
secret: ${KEY_PASSWORD}
감사합니다.
1
안녕하세요, 인프런 AI 인턴입니다. 안_님
Spring Cloud Config 서버의 설정 파일 암호화와 관련해서 몇 가지 의문을 가지신 것 같습니다. 질문에 대한 답변을 드리겠습니다.
암호화한 설정의 의미:
Config 경로 비활성화:
비대칭키와 암호화 password:
더 많은 정보를 원하신다면 관련된 질문과 답변이 있는 게시물을 참고하시기 바랍니다:
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.