JSCODE Logo
프로그래밍 과외블로그후기멘토진
회사명 : JSCODE대표 : 박재성사업자 등록번호 : 244-22-01557통신판매업 : 제 2023-인천미추홀-0381 호
학원 명칭 : 제이에스코드(JSCODE)원격학원학원설립ㆍ운영 등록번호 : 제6063호

서울특별시 구로구 경인로 20가길 11(오류동, 아델리아)

Copyright ⓒ 2025 JSCODE - 최상위 현업 개발자들의 프로그래밍 교육 All rights reserved.

이용약관개인정보처리방침
← 블로그 목록으로 돌아가기

보안을 위해 외부에서 MySQL 접근하지 못하도록 막기

JSCODE 박재성
JSCODE 박재성
2025-12-06
author
JSCODE 박재성
category
쿠버네티스
createdAt
Dec 6, 2025
series
비전공자도 이해할 수 있는 쿠버네티스 입문/실전
slug
block-external-access-to-mysql
type
post
updatedAt
Dec 6, 2025 04:46 AM

✅ 기존 구성의 보안적인 문제점

notion image
지금까지 만든 구조를 살펴보면 위와 같다. 위의 구조에서 MySQL을 중점적으로 살펴보면 보안에 취약한 점이 있다. 30002번 포트로 MySQL에 직접적으로 접근할 수 있게끔 보안이 설정되어 있다는 점이다. Service의 NodePort를 활용해 30002번 포트를 외부로 오픈해서 MySQL에 아무나 접근할 수 있게 만들었다.
 
 

✅ Service 종류 복습

  • NodePort : 쿠버네티스 내부에서 해당 서비스에 접속하기 위한 포트를 열고 외부에서 접속 가능하도록 한다.
  • ClusterIP : 쿠버네티스 내부에서만 통신할 수 있는 IP 주소를 부여. 외부에서는 요청할 수 없다.
  • LoadBalancer : 외부의 로드밸런서(AWS의 로드밸런서 등)를 활용해 외부에서 접속할 수 있도록 연결한다.
 
 

✅ 보안적인 문제점 해결

보안적인 문제점 해결을 위해 Service의 종류 중 NodePort를 사용하지 않고 ClusterIP를 활용해야 한다. ClusterIP를 활용함으로써 외부에서 아무나 MySQL에 접근하지 못하게 막아야 한다.
 
  1. 기존 Service 매니페스트 파일 수정하기
    1. mysql-service.yaml
      apiVersion: v1 kind: Service # Service 기본 정보 metadata: name: mysql-service # Service 이름 # Service 세부 정보 spec: type: ClusterIP # Service의 종류 selector: app: mysql-db # 실행되고 있는 파드 중 'app: mysql-db'이라는 값을 가진 파드와 서비스를 연결 ports: - protocol: TCP # 서비스에 접속하기 위한 프로토콜 port: 3306 # 쿠버네티스 내부에서 Service에 접속하기 위한 포트 번호 targetPort: 3306 # 매핑하기 위한 파드의 포트 번호 nodePort: 30002 # 외부에서 사용자들이 접근하게 될 포트 번호
       
  1. 기존 Service 중단하면 작동 안 하는 지 먼저 확인하기
    1. $ kubectl delete service mysql-service $ kubectl rollout restart deployment spring-deployment
      notion image
       
  1. Service 작동시키기
    1. $ kubectl apply -f mysql-service.yaml $ kubectl rollout restart deployment spring-deployment
 
  1. Spring Boot 서버와 잘 연결됐는 지 확인
    1. notion image
 
  1. 원래 접속하던 DB에 접속이 안 되는 지 확인
    1. notion image
 
 

✅ 그림으로 이해하기

notion image
 
 

✅ DB를 관리하기 위해 접속해야 할 때는?

쿠버네티스의 포트 포워딩을 활용해서 접속하면 된다. 아래 포트 포워딩 명령어를 사용하면 내 로컬 컴퓨터에서만 해당 파드와 연결을 허용시킬 수 있게 된다.
$ kubectl port-forward pod/[MySQL 파드명] 3306:3306
notion image
 
author
category
쿠버네티스
createdAt
Dec 6, 2025
series
비전공자도 이해할 수 있는 쿠버네티스 입문/실전
slug
type
series-footer
updatedAt
Dec 6, 2025 04:46 AM
📎
이 글은 비전공자도 이해할 수 있는 쿠버네티스 입문/실전 강의의 수업 자료 중 일부입니다.