如果现在需要在 Linux 服务器 上执行一系列命令(比如搭建 LNMP 环境)我应该会第一时间想到想办法写个 Shell 脚本,然后扔上去执行以下看看结果。
然而一贯懒惰的我并不想这么去执行 Shell 和一些重复命令。所以俺寻思可以有个方法本地直接在服务器端执行脚本,寻思生异端,这时候有某大技霸告诉我有个叫 paramiko 的 Python 库,从此开启我新世界的大门。

对于 paramiko 安装直接 pip 或者 PyCharm 这里就不多说了,如果看到这里你觉得自己不怎么了解python语法的也不必担心,你完全可以用 paramiko 单纯的执行 Shell 命令查看结果和上传下载文件,省去重复的工作。
paramiko 实现了 SSHv2 协议(底层使用 cryptography ),包含两个核心组件:SSHClient 和 SFTPClient 。 SSHClient 是对 SSH 会话的封装,用于执行远程命令,SFTPClient 是对 SFTP 客户端的封装,用以实现远程文件操作。
这里先举两个列子你应该就明白怎么用了,终于开始正片了。
importparamikoclient=paramiko.SSHClient()client.Set_missing_host_key_policy(paramiko.AutoAddPolicy())#自动添加策略,保存服务器的主机名和密钥信息,如果不添加,那么不再本地know_hosts文件中记录的主机将无法连接client.connect(hostname=,port=22,username=,password=)#连接SSH服务端,以用户名和密码进行认证stdin,stdout,stderr=client.exec_command()#stdout为正确输出,stderr为错误输出,同时是有1个变量有值(stdout.read().decode())client.close()
输出
怎样远程执行Linux脚本和命令怎样远程执行Linux脚本和命令
这里说明一下:
client=paramiko.SSHClient(),client.set_missing_host_key_policy(paramiko.AutoAddPolicy())你可以理解为固定姿势。client.connect(hostname=,port=22,username=,password=)这里就是你的linux变量依次为地址、端口(总共65535个端口,不过ssh默认是22端口)、登录名、密码。stdin,stdout,stderr=client.exec_command()这里就是核心你需要做的shell命令,这三个变量不用按照这种姿势,你可以随意,不过按照顺序你知道里面装的什么数据就行(重点在输出和错误)。connect():这个是实现远程服务器连接和认证的,参数有:hostname连接的目标主机port=SSH_PORT指定端口username=None验证的用户名password=None验证的用户密码pkey=None私钥方式用于身份验证key_filename=None一个文件名或文件列表,指定私钥文件timeout=None可选的tcp连接超时时间allow_agent=True,是否允许连接到ssh代理,默认为True允许look_for_keys=True是否在~/.ssh中搜索私钥文件,默认为True允许compress=False,是否打开压缩。set_missing_host_key_policy():这个是设置远程服务器没有在know_hosts文件中记录时的应对策略。(可以理解为避免报错),参数有:AutoAddPolicy自动添加主机名及主机密钥到本地HostKeys对象,不依赖load_system_host_key的配置。即新建立ssh连接时不需要再输入yes或no进行确认WarningPolicy用于记录一个未知的主机密钥的python警告。并接受,功能上和AutoAddPolicy类似,但是会提示是新连接RejectPolicy自动拒绝未知的主机名和密钥,依赖load_system_host_key的配置。此为默认选项exec_command():这是写你需要执行的命令的
接下来你就可以拿出输出做一些该干嘛(ke)干嘛(pa)的事情了,这里先举这个简单的列子。
t=paramiko.Transport((,22))t.connect(username=,password=)sftp=paramiko.SFTPClient.from_transport(t)sftp.put(,)sftp.get(,)t.close()SFTPCLient作为一个sftp的客户端对象,根据ssh传输协议的sftp会话,实现远程文件操作,如上传、下载、权限、状态from_transport(cls,t)创建一个已连通的SFTP客户端通道put(localpath,remotepath,callback=None,confirm=True)将本地文件上传到服务器参数confirm:是否调用()方法检查文件状态,返回ls-l的结果get(remotepath,localpath,callback=None)从服务器下载文件到本地mkdir()在服务器上创建目录remove()在服务器上删除目录rename()在服务器上重命名目录()查看服务器文件状态listdir()列出服务器目录下的文件最后养成随关闭的好习惯client.close()。
Linux远程连接怎么打开程序
好像这种连接方式,仅支持文字界面,你是要打开什么程序啊,一般来说只要执行$ xxx 命令就可以,里面的xxx是你的程序的系统名称,当然有些程序需要加入参数才能打开,这都要看具体是什么程序了。如果你想在图形界面下,最好是使用VNC连接方式,应该就可以进入X-Windows界面了
如何通过ssh远程登录linux系统
建议使用 登录下载地址:是一个Telnet、SSH、rlogin、纯TCP以及串行接口连接软件。 较早的版本仅支持Windows平台,在最近的版本中开始支持各类Unix平台,并打算移植至Mac OS X上。 除了官方版本外,有许多第三方的团体或个人将PuTTY移植到其他平台上,像是以Symbian为基础的移动电话。 PuTTY为一开放源代码软件,主要由Simon Tatham维护,使用MIT licence授权。
用xshell远程连接linux服务器时对服务器有什么要求
首先要能ping通linux服务器,然后linux服务器要开ssh服务,linux不需要安装就有这个服务的。 下面是Linux的ssh的设置方法:首先要修改ssh的配置文件sshd_config,输入命令:vi /etc/ssh/sshd_config2. 在这个文件中,将PermitRootLogin without-password这一行修改为PermitRootLogin yes,这一行的意思是“允许root用户用ssh登录”。 再去掉#PasswordAuthentication no这一行的注释符号#,并把no改为yes,表示用ssh登录时需要密码认证。 3. 修改完配置文件后就可以启动SSH服务了,启动命令为:/etc/init.d/ssh start4. 如果不想每次启动linux后都要启动ssh服务的话,需要设置ssh开机自启动,命令是:update-rc.d ssh enable或者chkconfig ssh on
发表评论