MariaDB 클라언트-서버 TLS/SSL 암호화 연결(2)
MariaDB 클라언트-서버 TLS/SSL 클라이언트 사용
글 타래:
- MariaDB 클라언트-서버 TLS/SSL 암호화 연결(1)
- MariaDB 클라언트-서버 TLS/SSL 암호화 연결(2)
- MariaDB 클라언트-서버 TLS/SSL 암호화 연결(3)
서버측에서 MariaDB/MySQL 의 TLS를 활성화한 다음 실제 다양한 클라이언트에서 접속을 시도해 보자. 서버에서 생성한 CA 파일 ca.pem, 클라이언트 인증서 client-ssl.pem, 클라이언트 키 client-key.pem 을 다운로드해서 사용한다.
글 진행 순서
- 클라이언트 인증서 다운로드
- DB API: python 에서 SSL 접속
- HeidiSQL 에서 SSL 접속
- MySQL Workbench 에서 SSL 접속
1. 클라이언트 인증서 다운로드
앞서 MariaDB 클라언트-서버 TLS/SSL 암호화 연결(1) 만든 ca.pem, client-cert.pem, client-key.pem 을 외부접속할 클라이언트 PC로 다운받는다.
1 | mkdir .ssl/mysql/ |
SSH 에 다른 포트 번호를 사용하면
scp -P PORT
로 사용한다.
다운로드한 파일은 3종류로
1 | ls .ssl/mysql |
서버와 비슷하게 mysql client 설정에 인증키들을 설정해주면 그냥 접속해도 ssl로 접속된다. 아래 참고2 에서 mysql client 의 클라이언트 측 my.cnf/my.ini 파일에 ssl-ca, ssl-cert, ssl-key 를 설정하면 된다.
2. DB API: python 에서 SSL 접속
pymysql, sqlalchemy 등 mysql client API 에 ssl_ca, ssl_key, ssl_cert 인자에 클라이언트용 인증 파일을 연결한다.
pymysql
pymysql.connect 에 ssl_ca, ssl_key, ssl_cert 인자 클라이언트용 인증 파일의 경로가 SSL_CA, SSL_CERT, SSL_KEY 에 있다고 가정한다.
1 | conn = pymysql.connect(host='192.168.0.10', |
SQLAlchemy : engine
sqlalchemy의 create_engin에 connect_args
인자에 클라이언트 인증 파일의 경로가 SSL_CA, SSL_CERT, SSL_KEY 에 있다고 가정한다.
1 | ssl_args = {'ssl_ca': SSL_CA, |
C 라이브러리 사용 SSL 접속
참고2 를 보면 C API를 사용한 `libmariadb.dll`` 라이브러리에서 SSL 사용하는 C++ 콘솔 예제 가 있다.
3. HeidiSQL 에서 SSL 접속
HeidiSQL 에서 SSL 을 이용해 접속할 수 있다. 아래 그림 같이 DB 정보를 입력한 후에 SSL 탭에서 SSL을 체크만 하면 된다.
접속이 되면 프로그램 아래 상태바의 정보를 클릭해 보면 SSL 연결을 확인할 수 있다.
앞서 다운로드한 서버측이 제고한 클라이언트 인증 키를 지정하고 연결하면 아래 같은 cipher mis match 에러가 뜬다.
이것은 아마도 서버측의 openssl.cnf 에 정의되어 있는 CipherString 버전이 달라서 그런것 같다. 여기 Connect error “SEC_E_ALGORITHM_MISMATCH”.. 의 글타래에 설명되어 있다.
- 테스트한 서버는 ** Armbian 23.02.2 Bullseye** 로 CipherString 이
DEFAULT@SECLEVEL=2
로 나온다.
TLS versions
1 | > show global variables like 'tls_version'; |
CipherString 테스트
MySQL 설정파일 참조3에 따르면 server-side encrypted-connection control 을 위해서 아래 변수를 사용할 수 있다고 한다.
1 | ssl_cipher: The list of permissible ciphers for connection encryption. |
my.cnf 의 SSL/TLS 영역 다음을 추가해 보자.
1 | ssl_cipher=DEFAULT:@SECLEVEL=1 |
재시작한후 아래 그림 같이 서버에서 만든 클라이언트 인증서를 사용해보니 잘 된다. root 계정 접속도 잘 된다.
4. MySQL Workbench 에서 SSL 접속
MySQL Workbench 에서도 SSL 연결로 데이터베이스에 접속할 수 있다. DB 접속 계정 정보를 입력한다.
SSL 탭에서 SSL 관련 옵션을 선택하는데 여기서는 if available 로 지정했다. 서버측이 SSL활성화가 되어 있으면 자동으로 SSL 통신을 진행한다.
Test 로 확인해 보면 SSL 접속이 잘 되고 있는 것을 알 수 있다.
5. 사용자 SSL 권한 부여
새 사용자를 생성할 때 아래 같이 접속시 REQUIRE
인자로 SSL 로만 접속하도록 할 수 있다.
사용자의 추가/권한 부여에 대해서 MySQL CLI/Admin: 권한부여 글을 참고.
1 | # SSL/TLS(가장 기본적인 암호화 접속) |
기존 사용자는 사용자 권한에서 SSL을 권한을 추가한다.
1 | mysql> GRANT ALL PRIVILEGES ON DB이름.* TO 'USERID'@'%' REQUIRE SSL; |
주어진 grant에 SSL/X509 등이 주어졌는지 확인한다.
1 | mysql> SHOW GRANTS FOR 'USERID'@'HOST'; |
내부 네트워크 외부 네트워크로 분리해 사용한다면 외부에서는 무조건 SSL 을 사용하도록 할 수 있을 것 같다.