ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

2020-05-21 免密在远程服务器上执行命令

2020-05-21 23:54:29  阅读:229  来源: 互联网

标签:免密 21 05 ansible ssh key ubuntu 服务器 paramiko


一.paramiko方式
前提:
1.安装过paramiko
pip install paramiko
2.生成了密钥对
ssh-keygen -t rsa -P '' -f ~/.ssh/id_rsa
3.将公钥拷至远程服务器(或直接复制粘贴到服务器~/.ssh/authorized_keys文件中)
ssh-copy-id -i ~/.ssh/id_rsa.pub ubuntu@123.206.26.82

 

# paramiko方式

import paramiko
port=22
keyPath='/home/ubuntu/.ssh/id_rsa'  #私钥路径,公钥已传至远程服务器,同时需保证私钥有可读权限
hostname="123.206.26.82"
username="ubuntu"

key=paramiko.RSAKey.from_private_key_file(keyPath)

s=paramiko.SSHClient()
s.load_system_host_keys()
s.set_missing_host_key_policy(paramiko.AutoAddPolicy()) #不会提示knowhosts 找不到
s.connect(hostname,port,username,pkey=key)

stdin,stdout,stderr=s.exec_command('ls >> ~/hh.txt')
s.close()

print (stdout.read())
print (stderr.read())

 

 二.ansible 方式

前提:

1.安装了ansible

sudo apt install ansible

2.配置了密钥对并已将公钥上传至远程服务器

 同上.

3.将远程服务器的ip已经添加到ansible 的hosts文件中

echo "123.203.26.82" >> /etc/ansible/hosts

 

# ansible 方式
ansible -u ubuntu 123.206.26.82 -m shell -a "ls >> ~/hh.txt"

 

标签:免密,21,05,ansible,ssh,key,ubuntu,服务器,paramiko
来源: https://www.cnblogs.com/cxl-blog/p/12934473.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有