1.在Linux上我們通過scp命令實現主機間的文件傳送,通過ssh實現遠程登錄 ,比如 我們經常使用的xshell遠程登錄工具,就是基礎ssh協議實現window主機遠程登錄Linux主機
下面簡單的在python實現這幾個功能 下面使用到paramiko模塊,這個不是python的內置模塊,我直接通過pycharm下載這個模塊,
第一步實現一個簡單的ssh登錄命令 代碼如下:
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 的服務器端修改了默認端口一直
連不上,修改配置文件后設置允許遠程主機遠程連接 ,/etc/ssh/sshd_config文件中配置
然后實現模擬Linux的scp 命令上傳下載文件 ,使用了paramiko的Transport 簡單的測試代碼如下
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主機的環境目錄下 ,
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()
成功的實現了免密連接,代碼知識做簡單的測試用,以連接為主,沒考慮其他的實際需要
這些東西玩了一下午,還是挺神奇的,