1.在Linux上咱們經過scp命令實現主機間的文件傳送,經過ssh實現遠程登陸 ,好比 咱們常用的xshell遠程登陸工具,就是基礎ssh協議實現window主機遠程登陸Linux主機python
下面簡單的在python實現這幾個功能 下面使用到paramiko模塊,這個不是python的內置模塊,我直接經過pycharm下載這個模塊,linux
第一步實現一個簡單的ssh登陸命令 代碼以下:shell
import paramiko # 建立SSH對象 ssh = paramiko.SSHClient() # 容許鏈接不在know_hosts文件中的主機 ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())#第一次登陸的認證信息 # 鏈接服務器 ssh.connect(hostname='192.168.158.131', port=22, username='root', password='hadoop') # 執行命令 stdin, stdout, stderr = ssh.exec_command('ls /') # 獲取命令結果 res,err = stdout.read(),stderr.read() result = res if res else err print(result.decode()) # 關閉鏈接 ssh.close()
登陸並能實現簡單的命令發送 和接收指令結果 ,這裏面的方法寫死了 ,但總算鏈接成功了,應爲開始虛擬機的在學習iptables加了許多規則,而且在ssh 的服務器端修改了默認端口一直windows
連不上,修改配置文件後設置容許遠程主機遠程鏈接 ,/etc/ssh/sshd_config文件中配置服務器
而後實現模擬Linux的scp 命令上傳下載文件 ,使用了paramiko的Transport 簡單的測試代碼以下ssh
import paramiko transport = paramiko.Transport(('192.168.158.131', 22)) transport.connect(username='root', password='hadoop') sftp = paramiko.SFTPClient.from_transport(transport) # 將location.py 上傳至服務器 /tmp/test.py sftp.put('fromlinux.txt', '/tmp/test_from_win') # 將remove_path 下載到本地 local_path # sftp.get('/root/oldgirl.txt', 'fromlinux.txt') transport.close()
一樣的也能 測試成功 ,能實現文件的上傳與下載工具
最後注意到paramiko.RSAKey這個功能,能思想比較牛逼的ssh免密登陸,核心的過程就是在Linux經過ssh-keygen在主機上生成一對密鑰 ,公鑰放在~/.ssh/authorized_keys文件在,將私鑰拷貝到windows主機的環境目錄下 ,oop
import paramiko private_key = paramiko.RSAKey.from_private_key_file('id_rsa31.txt')#要將私鑰放在這裏 # 建立SSH對象 ssh = paramiko.SSHClient() # 容許鏈接不在know_hosts文件中的主機 ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy()) # 鏈接服務器 ssh.connect(hostname='10.0.0.41', port=22, username='fang', pkey=private_key) # 執行命令 stdin, stdout, stderr = ssh.exec_command('df;ifconfig') result = stdout.read() print(result.decode()) stdin, stdout2, stderr = ssh.exec_command('ifconfig') # 獲取命令結果 result2 = stdout2.read() print(result2.decode()) # 關閉鏈接 ssh.close()
成功的實現了免密鏈接,代碼知識作簡單的測試用,以鏈接爲主,沒考慮其餘的實際須要學習
這些東西玩了一下午,仍是挺神奇的,測試