使用paramiko模块,比os模块和command模块更加的兼容各种环境。后面两个只能在服务器本机 执行,此模块写得python文件无论是在本地还是服务器本身上运行,都能兼容。

paramiko模块的用法如下。

"""自动部署,可以在本地运行执行linux命令,也可以在远程服务器链接自身运行"""

import paramiko
from app.utils.utils_ydf import mixins, unittest_util class HotelFaresDeploy(mixins.LoggerMixin):
def __init__(self, project_env='ydf', ip='115.95.89.xx', port=22, user_name="webuser", user_password='xxxxxxx'):
"""
:param project_env: 项目环境。不同的环境有不同的文件夹
:param ip: linux服务器ip
:param port: 端口
:param user_name: 用户名
:param user_password: 密码
"""
hotel_fares_dir = None
if project_env == 'ydf':
hotel_fares_dir = '/home/xxx/hotelf/'
elif project_env == 'test':
hotel_fares_dir = '/hotel/hotel_fares'
if project_env not in ('ydf', 'test'):
raise Exception('设置的项目环境错误')
self.hotel_fares_dir = hotel_fares_dir
ssh = paramiko.SSHClient()
ssh.set_missing_host_key_policy(paramiko.AutoAddPolicy())
ssh.connect(ip, port, user_name, user_password)
self.ssh = ssh
self.ssh_session = self.ssh.get_transport().open_session()
self.cmd0 = 'cd {} ; export PYTHONPATH=$PYTHONPATH:{};'.format(self.hotel_fares_dir, self.hotel_fares_dir) # 先进入项目所在文件夹和添加环境变量,这样才能保证后面的程序能顺利执行,linux,运行多条命令用;
self.logger.debug('cmd0 --> ' + self.cmd0) def git_pull(self):
"""
更新git内容
:return:
"""
cmd1 = 'git fetch --all;'
cmd2 = 'git reset --hard origin/haoqiao1.3;'
cmd3 = 'git -C {} pull origin haoqiao1.3'.format(self.hotel_fares_dir)
self.exec_cmd(cmd1 + cmd2 + cmd3) def exec_cmd(self, cmd):
"""
执行cmd命令
:param cmd: 需要执行的命令
:return:
:type cmd : str
"""
self.logger.debug('要执行的命令是: ' + cmd)
stdin, stdout, stderr = self.ssh.exec_command(self.cmd0 + cmd)
stdout_str = stdout.read().decode('utf8')
stderr_str = stderr.read().decode('utf8')
if stdout_str != '':
self.logger.info('执行 {} 命令的stdout是 -- > \n{}'.format(cmd, stdout_str))
if stderr_str != '':
self.logger.error('执行 {} 命令的stderr是 -- > \n{}'.format(cmd, stderr_str))
return stdout_str, stderr_str def run_pyhton_file(self, python_file_path):
"""
:param python_file_path:python文件的相对路径
:return:
:type python_file_path:str
"""
python_file_path_short = python_file_path.split('/')[-1] # 防止是直接去进内层文件夹手动启动的短命令
stdout_str, stderr_str = self.exec_cmd("ps aux | grep %s|grep -v grep|awk '{print $2}'" % python_file_path_short)
pid_before = stdout_str
self.logger.info('进程名 [{}] 部署前的进程号是 --> {}'.format(python_file_path_short, pid_before)) self.exec_cmd("ps aux|grep %s|grep -v grep|awk '{print $2}' |xargs kill -9" % python_file_path_short)
self.exec_cmd('nohup python3 %s >/dev/nohup.out 2>&1 &' % python_file_path) # 这里要用长路径,不然找不到文件
# cmd = 'ps aux | grep %s|grep -v grep' % python_file_path
stdout_str, stderr_str = self.exec_cmd("ps aux | grep %s|grep -v grep|awk '{print $2}'" % python_file_path_short)
pid_after = stdout_str
self.logger.info('进程名 [{}] 部署后的进程号是 --> {}'.format(python_file_path_short, pid_after))
if pid_after == '':
self.logger.critical('重新启动 [{}] 失败'.format(python_file_path_short))
elif pid_before != pid_after:
self.logger.warning('重新启动 [{}] 成功'.format(python_file_path_short))
else:
self.logger.critical('启动前后进程号一样'.format(python_file_path_short)) def recover_screen(self):
"""进入screen"""
raise NotImplementedError('还没写,不需要用screen') def run_redis_hotel_id_task_manager(self):
self.run_pyhton_file('app/apis/elongin/elong_proj/redis_hotel_id_task_manager.py') def run_gunicorn(self, application_name, port):
"""
部署gunicorn
:param application_name: 应用名称
:param port: 端口
:return:
"""
application_name_short = application_name.split('.')[-1]
stdout_str, stderr_str = self.exec_cmd("ps aux | grep %s|grep -v grep|awk '{print $2}'" % application_name_short)
pid_before = stdout_str
self.logger.info('进程名 [{}] 部署前的进程号是 --> {}'.format(application_name_short, pid_before)) self.exec_cmd("ps aux|grep %s|grep -v grep|awk '{print $2}' |xargs kill -9" % application_name_short)
self.exec_cmd('nohup gunicorn -w 9 -k gevent --bind 0.0.0.0:%s %s >/dev/webnohup.out 2>&1 &' % (port, application_name)) stdout_str, stderr_str = self.exec_cmd("ps aux | grep %s|grep -v grep|awk '{print $2}'" % application_name_short)
pid_after = stdout_str
self.logger.info('进程名 [{}] 部署后的进程号是 --> {}'.format(application_name_short, pid_after))
if pid_after == '':
self.logger.critical('重新启动 [{}] 失败'.format(application_name_short))
elif pid_before != pid_after:
self.logger.warning('重新启动 [{}] 成功'.format(application_name_short))
else:
self.logger.critical('启动前后进程号一样'.format(application_name_short)) def query_process(self, process_name):
"""查询进程"""
cmd = "ps aux|grep %s|grep -v grep" % process_name
self.exec_cmd(cmd)

python使用paramiko自动化部署linux程序的更多相关文章

  1. Python学习笔记—自动化部署【新手必学】

      前言本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理.作者:唯恋殊雨   目录 pexpect fabric pexpect P ...

  2. 前端自动化部署linux centOs + Jenkins + nignx + 单页面应用

    Jenkins是什么? Jenkins 是一款业界流行的开源持续集成工具,广泛用于项目开发,具有自动化构建.测试和部署等功能. 准备工作 Linux centOS系统阿里云服务器一个 码云一个存放vu ...

  3. pxe+kickstart 自动化部署linux操作系统

    kickstart 是什么? 批量部署Linux服务器操作系统 运行模式: C/S client/server 服务器上要部署: DHCP tftp(非交互式文件共享) 安装系统的三个步骤: 1.加载 ...

  4. Jenkins自动化部署.netcore程序

    一.安装jenkins 百度一下 二.构建前的准备 搭建好.net core2.0的环境,下载:https://aka.ms/dotnetcore-2-windowshosting  (,net co ...

  5. Jenkins自动化部署.net程序

    一.安装Jenkins 百度上一大堆就不做说明了. 二.构建.net前的准备 1.安装MSBUILD.EXE插件 1.1.进去jenkins->系统管理->插件管理 1.2.配置MSBUI ...

  6. Jenkins自动化部署入门详细教程

    大纲 1.背景 在实际开发中,我们经常要一边开发一边测试,当然这里说的测试并不是程序员对自己代码的单元测试,而是同组程序员将代码提交后,由测试人员测试: 或者前后端分离后,经常会修改接口,然后重新部署 ...

  7. python+paramiko库+svn写的自动化部署脚本

    第一篇博文 直接开门见山的说了. 这是件什么事?:每次部署都是复制本地的文件粘贴到服务器端,因为路径复杂,所以费时且手工容易出漏洞. 一直在想有什么办法可以解决这种,因为以前在微软的一个牛人同事做过一 ...

  8. Linux 自动化部署

    1.pexpect Pexpect 是 Don Libes 的 Expect 语言的一个 Python 实现,是一个用来启动子程序,并使用正则表达式对程序输出做出特定响应,以此实现与其自动交互的 Py ...

  9. Linux上天之路(十八)之自动化部署

    pexpect Pexpect 是 Don Libes 的 Expect 语言的一个 Python 实现,是一个用来启动子程序,并使用正则表达式对程序输出做出特定响应,以此实现与其自动交互的 Pyth ...

随机推荐

  1. STM32 双ADC同步规则采样

      最近需要用到两个ADC对电压电流进行同步采样,看了一下STM32的ADC介绍,发现STM32最多有3个独立ADC,有在双AD模式下可以进行同步测量,正好满足我的要求.参考官方给的例子在结合自己的需 ...

  2. IIS 7上部署PHP

    前言 前段时间整了一个挂Q的平台.源代码是从网上下载的,后期稍微调整了一下链接和title之类的文字就上线了.详细在这里. 运行了一段时间,除了偶尔出现QQ下线上线,整体效果基本上符合预期,个人感觉很 ...

  3. 搭建自己的挂Q平台

    准备工作: 在前篇[分享]免费建立自己的站点里面介绍了怎么申请免费域名和空间. 在这里[随记]Q号解除限制一波三折有我被挂Q工具坑苦的经历. 在网上(出处不明了,下载的包太多,非CSDN)下载到的免费 ...

  4. Hbase 学习(八) 使用MapReduce

    在hbase的demo里面有个IndexBuilder的例子,它就是使用了MapReduce来操作hbase的,例子也比较简单,但是只包括了Mapper. 另外网上还有另外一个例子,也是说明这个的,这 ...

  5. 【html】关于锚点的一些事

    今天修改公会系统,有用到锚点对页面位置进行控制,结果碰到了一些问题,通过查询相关资料解决了,在这里总结下. 两种方法跳转到锚点: 1.给锚点添加 name 属性和 id 属性.一般只要加 name 就 ...

  6. SpringCloudConfig与SpringCloudEureka 注册中心与配置中心高可用的意义

    所有的配置会缓存在本地,远程配置中心DOWN机,不影响本地使用,只是无法重新请求服务端获取配置的更新. 不管是注册中心的高可用,还是配置中心的高可用.本质上都是保证服务能注册上去或者能从配置中心获取配 ...

  7. ubuntu下IDEA配置tomcat报错Warning the selected directory is not a valid tomcat home

    产生这个问题的主要原因是文件夹权限问题. 可以修改文件夹权限或者更改tomcat文件目录所有者. 这里我直接变更tomcat文件夹所有者: sudo chown -R skh:skh tomcat-/ ...

  8. MFC中的句柄

    1.引出句柄 CDC问题:1.CDC dc;dc.LineTo(point);无法运行 2.CDC *dc=GetDC();dc->LineTo(point);就可以运行了 MFC中有大量的句柄 ...

  9. linux下shellcode提取常用到的命令

    汇编语言的汇编指令: nasm -f elf xxx.asm    生成xxx.o文件 ld -o xxx  xxx.o  生成可执行文件,不用加参数-s ,否则在提取shellcode的十六进制码的 ...

  10. spring mvc中关于url中传递中文乱码的解决方法

    在传值过程中,也是乱码出现的频繁地.先不说到底是什么场景了,通常常用的方案有如下几个 配置指定的filter <!-- 配置请求过滤器,编码格式设为UTF-8,避免中文乱码--> < ...