使用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. opencv----模板匹配

    引自:http://blog.csdn.net/liyuanbhu/article/details/49837661 OpenCV 学习笔记(模板匹配) 模板匹配是在一幅图像中寻找一个特定目标的方法之 ...

  2. 工具软件 PYUV打开raw图片

    引自:http://blog.csdn.net/lavenderss/article/details/51495648 [pYUV]如何打开YUV/RGB图片 pYUV工具本身使用起来比较简单,但如果 ...

  3. 推荐几个不错的h5游戏引擎

    http://www.phaser.io/examples http://www.cocos.com/ http://cn.cocos2d-x.org/tutorial/lists?id=30 coc ...

  4. Ionic学习资源

    http://www.qianduan.net/use-ionic-develop-hybrid-app/

  5. Web Application Stress 对网站进行压力测试

    打开Microsoft web Application Stress工具按下图顺序操作: 1. 2.点击Record 3. 4.在浏览器中输入要测试的URI地址 5.在设置中设置参数,如发起请求线程数 ...

  6. Linux文本编辑器(九)

    [教程主题]:Linux文本编辑器 [1]vi vi编辑器是所有Unix及Linux系统下标准的编辑器,它的强大不逊色于任 何最新的文本编辑器,这里只是简单地介绍一下它的用法和一小部分指令. 由于对U ...

  7. Android训练课程(Android Training) - 使用Volley传输网络数据(Transmitting Network Data Using Volley)

    使用Volley传输网络数据(Transmitting Network Data Using Volley) Volley 是一个 HTTP 库,它使得在Android应用程序中操作网络更容易,是重要 ...

  8. 【C】——网络编程-聊天室

    功能介绍: 此demo是基于TCP套接字编程,目的是实现一个聊天室效果.类似于QQ群效果,如果上线可以通知其他好友,下线也会通知其他好友. 需要用的技术: 一.socket编程. 1> sock ...

  9. JAVA多线程笔试题

    一.题目内容 二.我的答案 利用了线程池.考虑了超时处理.不知道这样写是否还有其他问题,或者更好更优的解决方案? import java.util.*; import java.util.concur ...

  10. js动态加载图片核心代码

    objMapHeart.src = obj.getAttribute("ItemImage"); //==============图片预加载处理================== ...