Python으로 SSH를 제어하기

Python으로 SSH를 제어하기

Python
Python으로 SSH를 제어하기
Author

gabriel yang

Published

October 7, 2024


Python으로 SSH를 제어하기 위한 라이브러리 가이드

Python을 사용하여 원격 서버에 SSH(Secure Shell) 연결을 통해 명령을 실행하거나 파일을 전송할 수 있습니다. 이 글에서는 paramiko 라이브러리를 사용하여 비밀번호를 통해 SSH 연결을 제어하는 방법을 예제와 함께 설명하겠습니다.

1. paramiko 라이브러리 소개

paramiko는 Python에서 SSH 프로토콜을 사용하여 원격 서버와 통신할 수 있게 해주는 라이브러리입니다. 비밀번호 인증, 공개 키 인증 등 다양한 방식으로 SSH 연결을 할 수 있으며, 이를 통해 명령을 실행하거나 파일을 전송할 수 있습니다.

2. paramiko 설치

paramiko 라이브러리는 파이썬 패키지로 제공되며, pip 명령어를 통해 쉽게 설치할 수 있습니다.

pip install paramiko

3. 비밀번호를 사용한 SSH 연결 및 명령 실행

비밀번호를 사용하여 SSH 연결을 설정한 후, 원격 서버에서 명령어를 실행하는 기본적인 방법을 알아보겠습니다.

(1) SSH 연결 및 명령 실행

아래 예제에서는 비밀번호를 사용하여 원격 서버에 연결한 뒤, ls -l 명령어를 실행하고 결과를 출력하는 방법을 보여줍니다.

import paramiko

# SSH 클라이언트 객체 생성
ssh = paramiko.SSHClient()

# 자동으로 서버의 SSH 키를 허용하도록 설정
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

# SSH 연결 (호스트 주소, 사용자명, 비밀번호)
ssh.connect(hostname='example.com', username='your_username', password='your_password')

# 원격 서버에서 명령 실행
stdin, stdout, stderr = ssh.exec_command('ls -l')

# 명령어 실행 결과 출력
print(stdout.read().decode())

# SSH 연결 종료
ssh.close()

이 코드는 Python을 통해 SSH를 사용하여 ls -l 명령어를 원격 서버에서 실행하고, 그 결과를 콘솔에 출력합니다.

(2) 오류 처리

SSH 연결이나 명령 실행 중에 발생할 수 있는 오류를 처리하는 방법입니다. paramiko는 다양한 예외 처리를 지원하여, 네트워크 문제나 인증 오류를 보다 안정적으로 처리할 수 있습니다.

import paramiko

try:
    # SSH 클라이언트 객체 생성
    ssh = paramiko.SSHClient()
    ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

    # SSH 연결 (호스트 주소, 사용자명, 비밀번호)
    ssh.connect(hostname='example.com', username='your_username', password='your_password')

    # 명령어 실행
    stdin, stdout, stderr = ssh.exec_command('uptime')

    # 명령어 실행 결과 출력
    print(stdout.read().decode())

except paramiko.AuthenticationException:
    print("인증 실패: 사용자 이름 또는 비밀번호가 잘못되었습니다.")
except paramiko.SSHException as ssh_error:
    print(f"SSH 오류 발생: {ssh_error}")
except Exception as e:
    print(f"기타 오류 발생: {e}")
finally:
    # 연결 종료
    ssh.close()

주요 예외:

  • AuthenticationException: 비밀번호나 사용자 이름이 잘못된 경우 발생
  • SSHException: SSH 연결이나 통신 중 문제가 발생한 경우
  • 기타 예외: 네트워크 오류 등

(3) 명령 실행 결과 및 오류 처리

명령어 실행 결과는 stdout을 통해, 오류는 stderr를 통해 받아볼 수 있습니다. 이를 통해 명령이 성공적으로 실행되었는지, 오류가 발생했는지 판단할 수 있습니다.

import paramiko

# SSH 클라이언트 객체 생성
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(hostname='example.com', username='your_username', password='your_password')

# 명령 실행
stdin, stdout, stderr = ssh.exec_command('ls /invalid_directory')

# 명령어 출력과 오류 메시지 확인
output = stdout.read().decode()
error = stderr.read().decode()

if error:
    print(f"명령 실행 중 오류 발생: {error}")
else:
    print(f"명령 실행 결과: {output}")

ssh.close()

위 코드에서 stderr.read()를 사용하여 명령 실행 중 발생한 오류 메시지를 출력할 수 있습니다.

4. SFTP를 사용한 파일 전송

SSH 연결을 사용하여 파일을 전송할 수 있는 SFTP(Secure File Transfer Protocol)를 활용하면, 로컬 파일을 원격 서버로 전송하거나 반대로 다운로드할 수 있습니다.

import paramiko

# SSH 클라이언트 객체 생성
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(hostname='example.com', username='your_username', password='your_password')

# SFTP 세션 시작
sftp = ssh.open_sftp()

# 로컬 파일을 원격 서버로 업로드
sftp.put('/path/to/local/file.txt', '/path/to/remote/file.txt')

# 원격 서버의 파일을 로컬로 다운로드
sftp.get('/path/to/remote/file.txt', '/path/to/local/file.txt')

# SFTP 및 SSH 연결 종료
sftp.close()
ssh.close()

이 코드는 로컬에 있는 파일을 원격 서버로 전송하고, 원격 서버에 있는 파일을 로컬로 다운로드하는 작업을 보여줍니다.

5. 타임아웃 및 세부 설정

SSH 연결 시 타임아웃을 설정하여, 서버 응답이 너무 오래 걸리거나 네트워크 상태가 좋지 않을 때 오류를 처리할 수 있습니다.

import paramiko

try:
    # SSH 클라이언트 객체 생성
    ssh = paramiko.SSHClient()
    ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())

    # SSH 연결 (호스트 주소, 사용자명, 비밀번호, 타임아웃 설정)
    ssh.connect(hostname='example.com', username='your_username', password='your_password', timeout=10)

    # 명령어 실행
    stdin, stdout, stderr = ssh.exec_command('whoami')

    # 명령어 실행 결과 출력
    print(stdout.read().decode())

except paramiko.AuthenticationException:
    print("인증 실패: 사용자 이름 또는 비밀번호가 잘못되었습니다.")
except paramiko.SSHException as e:
    print(f"SSH 오류: {e}")
except Exception as e:
    print(f"기타 오류: {e}")
finally:
    ssh.close()

카테고리 다른 글

Date Title Author
Jan 1, 3000 전체 카테고리 gabriel yang
Nov 26, 2024 VSCode에서 Python 디버깅 (launch.json 설정) gabriel yang
Nov 23, 2024 Python 설치된 패키지 확인, 설치와 복원하기 gabriel yang
Oct 14, 2024 JSON 파일에서 특정 key의 값 변경 후 저장하는 방법 gabriel yang
Oct 10, 2024 날짜 문자열을 날짜 형식으로 변환하기 gabriel yang
Oct 8, 2024 Request를 통한 JIRA REST API 사용방법 gabriel yang
Oct 8, 2024 Request 라이브러리 사용방법 gabriel yang
Oct 8, 2024 Requests 라이브러리로 베이직 인증 API 호출하기 gabriel yang
Oct 7, 2024 Pytest로 테스트하기 gabriel yang
Oct 7, 2024 Pytest 기본적인 테스트 실행 방법 gabriel yang
Oct 7, 2024 Pytest Fixture 개념과 필요성 gabriel yang
Oct 7, 2024 CI 환경에서 Pytest 사용하기 gabriel yang
Oct 7, 2024 파이썬에서 테스트 코드 리팩토링 기법 gabriel yang
Oct 5, 2024 Python os 모듈을 이용한 파일과 폴더 관리 gabriel yang
Oct 5, 2024 Python shutil 모듈을 이용한 파일과 폴더 관리 gabriel yang
Oct 5, 2024 MongoDB 데이터베이스 백업 및 복원 방법 gabriel yang
Oct 5, 2024 Python jira 라이브러리를 이용해 JIRA를 관리하는 방법 gabriel yang
Oct 4, 2024 Python에서 JSON 파일 읽기 및 데이터 활용 gabriel yang
Oct 4, 2024 JSON 데이터 수정하기 gabriel yang
Oct 4, 2024 JSON 파일의 구성요소와 구조 gabriel yang
Oct 4, 2024 Python에서 Git명령 사용하기 gabriel yang
Oct 3, 2024 파이썬으로 클래스 정의하는 방법 gabriel yang
Oct 3, 2024 파이썬의 상속(Inheritance) 이해하기 gabriel yang
Oct 3, 2024 파이썬 클래스의 self 이해하기 gabriel yang
Oct 3, 2024 파이썬에서 추상 클래스(Abstract Class) 사용하기 gabriel yang
Oct 3, 2024 파이썬 클래스 활용 예시 gabriel yang
Oct 3, 2024 파이썬 클래스와 모듈 gabriel yang
Oct 3, 2024 파이썬에서 Lock을 사용하는 이유와 방법 gabriel yang
Oct 2, 2024 Python에서 zip()을 사용하는 이유와 방법 gabriel yang
Oct 2, 2024 파이썬 시퀀스 슬라이싱 gabriel yang
Oct 2, 2024 파이썬에서 Generator를 사용하는 이유와 사용법 gabriel yang
Oct 2, 2024 파이썬의 @property 기능 gabriel yang
Oct 2, 2024 파이썬 시퀀스 언패킹 gabriel yang
Oct 2, 2024 파이썬 데이터 정렬 gabriel yang
Oct 2, 2024 파이썬 딕셔너리 key 예외처리하기 gabriel yang
Oct 2, 2024 파이썬의 defaultdict 사용법 gabriel yang
Oct 2, 2024 파이썬의 try-except 사용법 gabriel yang
Oct 2, 2024 파이썬의 클로저(Clsure) 사용법 gabriel yang
Oct 2, 2024 파이썬의 가변인자 사용법 gabriel yang
Oct 2, 2024 파이썬의 컴프리헨션(Comprehension) 사용법 gabriel yang
Oct 1, 2024 파이썬 가상환경 설정 gabriel yang
Oct 1, 2024 파이썬을 이용한 테스트 자동화 gabriel yang
Oct 1, 2024 파이썬 docstring을 사용하는 이유와 방법 gabriel yang
Oct 1, 2024 파이썬 yield 제너레이터와 효율적인 반복 처리 gabriel yang
Oct 1, 2024 파이썬 데이터 언패킹 gabriel yang
Oct 1, 2024 Python에서 enumerate를 사용하는 이유와 사용 방법 gabriel yang
Sep 30, 2024 Python 설치 및 기본 파이썬 버전 설정 gabriel yang
Sep 30, 2024 Python을 이용한 폴더 전체 복사 방법 gabriel yang
Sep 30, 2024 Public Key와 Private Key의 역할 gabriel yang
Sep 23, 2024 Python의 @dataclass 데코레이터 gabriel yang
Aug 30, 2024 Python shell명령 수행하기 (Subprocess) gabriel yang
Aug 29, 2024 Google Colab에서 라이브러리 설치하기 gabriel yang
Aug 1, 2024 환경변수 설정하고 Python에서 읽어오기 gabriel yang
Jan 1, 2024 코루틴(coroutine)과 이벤트 루프 gabriel yang
No matching items
Back to BLOG LIST