집 >데이터 베이스 >MySQL 튜토리얼 >SSH 터널링을 사용하여 Python에서 원격 MySQL 서버에 어떻게 안전하게 연결할 수 있습니까?
Python-MySQL 연결을 위한 SSH 터널링 활성화
데이터베이스 연결 영역에서 MySQLdb를 활용하여 원격 서버에 대한 Python 연결을 설정하는 것은 상습. 이 방법은 목적에 부합하지만 향상된 데이터 개인 정보 보호를 위해 SSH 터널을 통해 연결을 보호해야 할 수도 있습니다. 이 기사에서는 Python 구현을 통해 이를 달성하는 방법을 살펴봅니다.
전통적으로 MySQL 서버에 대한 Python 연결은 MySQLdb 모듈을 통해 직접 설정됩니다. 그러나 연결을 위한 보안 SSH 터널을 설정하려면 수정이 필요합니다. paramiko 및 sshtunnel과 같은 외부 라이브러리를 활용하면 대상 MySQL 서버에 대한 SSH 연결 및 포트 전달이 가능합니다.
다음은 Python-MySQL용 SSH 터널을 설정하는 방법을 보여주는 코드 샘플입니다. 연결성:
import pymysql import paramiko from paramiko import SSHClient from sshtunnel import SSHTunnelForwarder # SSH Configuration ssh_host = 'ssh_hostname' ssh_user = 'ssh_username' ssh_port = 22 mypkey = paramiko.RSAKey.from_private_key_file('path/to/ssh/key') # MySQL Configuration sql_hostname = 'sql_hostname' sql_username = 'sql_username' sql_password = 'sql_password' sql_main_database = 'db_name' sql_port = 3306 sql_ip = '1.1.1.1.1' with SSHTunnelForwarder( (ssh_host, ssh_port), ssh_username=ssh_user, ssh_pkey=mypkey, remote_bind_address=(sql_hostname, sql_port)) as tunnel: conn = pymysql.connect(host='127.0.0.1', user=sql_username, passwd=sql_password, db=sql_main_database, port=tunnel.local_bind_port) # Execute queries and access data as usual conn.close()
이러한 라이브러리를 활용하여 Python은 SSH 터널을 통해 원격 MySQL 서버에 대한 보안 연결을 설정할 수 있습니다. 이 접근 방식은 특히 기밀 정보나 민감한 정보를 처리할 때 데이터 보안을 크게 강화합니다.
위 내용은 SSH 터널링을 사용하여 Python에서 원격 MySQL 서버에 어떻게 안전하게 연결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!