百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

如何利用Python批量更新服务器文件

off999 2024-10-11 13:57 26 浏览 0 评论

今天小编给大家介绍一下关于如何利用Python批量更新服务器文件的内容,比如同学们买了个Linux服务器,Centos系统,装了个宝塔搭建了10个网站,比如有时候要在某个文件上加点代码,就要依次去10个文件改动,虽然宝塔是可视化页面操作,不需要用命令,但是也麻烦,虽然还有git的hook方法,但是操作也麻烦,新建个目录的话还得操作一次,所以萌生了一个想法,用Python来批量更新服务器上的文件,下面我们一起来看一下吧。

  

  代码

  importparamiko

  importos

  #连接信息

  host='xxx.65.9.191'

  port=22

  username='root'

  password='root'

  #忽略的目录

  skipArry=['kai.xxxx.com','demo.xxxx.com']

  fullpathArry=[]

  currentIndex=''

  #判断文件是否存在

  defjudgeFileExist():

  globalcurrentIndex;

  currentIndex=os.getcwd()+'/Index.php'

  ifos.path.isfile(currentIndex)==False:

  print('Index文件不存在')

  exit()

  print('文件检测成功,准备连接服务器...')

  defcreatConnect():

  try:

  print('开始连接服务器...')

  s=paramiko.Transport((host,port))

  s.connect(username=username,password=password)

  sftp=paramiko.SFTPClient.from_transport(s)

  print('连接:'+host+'成功')

  returnsftp,s

  exceptExceptionase:

  print('连接服务器失败:'+str(e))

  #

  #获取目录保存为数组

  defgetDirectory(sftp):

  print('开始获取目录...')

  sftp.chdir('/www/wwwroot')

  pathlist=sftp.listdir(path='.')

  forpathinpathlist:

  fullpath='/www/wwwroot/'+path+'/application/index/controller'

  ifpathinskipArry:

  continue

  fullpathArry.append(fullpath)

  print('目录获取完毕')

  #上传Index文件

  defuploadIndex(sftp):

  forfullpathiteminfullpathArry:

  remoteIndex=fullpathitem+'/Index.php'

  print('开始上传:'+remoteIndex)

  try:

  sftp.put(currentIndex,remoteIndex)

  try:

  sftp.file(remoteIndex)

  sftp.chmod(remoteIndex,int("775",8))

  print('修改'+remoteIndex+'权限为755')

  print(fullpathitem+'上传成功')

  except:

  print(fullpathitem+'上传失败')

  continue

  exceptExceptionase:

  print('错误信息:'+str(e))

  continue

  if__name__=="__main__":

  judgeFileExist()

  sftp,s=creatConnect()

  getDirectory(sftp)

  uploadIndex(sftp)

  s.close()

  代码Show完了,开始详细解释一波

  这个方法是检测我当前目录下有没有Index.php这个文件,如果没有的话就直接退出不进行下一步了,这里有个小坑,就是你Index.php这个文件名,你写小写的index.php,也能为True,这里有个要注意的地方,就是要修改currentIndex的值,必须在前面加上global,否则还是为空

  defjudgeFileExist():

  globalcurrentIndex;

  currentIndex=os.getcwd()+'/Index.php'

  ifos.path.isfile(currentIndex)==False:

  print('Index文件不存在')

  exit()

  print('文件检测成功,准备连接服务器...')

  这是连接服务器并创建SFTP,使用了Try来捕获异常错误

  defcreatConnect():

  try:

  print('开始连接服务器...')

  s=paramiko.Transport((host,port))

  s.connect(username=username,password=password)

  sftp=paramiko.SFTPClient.from_transport(s)

  print('连接:'+host+'成功')

  returnsftp,s

  exceptExceptionase:

  print('连接服务器失败:'+str(e))

  这里就是执行操作命令了,使用sftp对象来操作,sftp.chdir是用于切换目录,相当于shell命令的cd/www/wwwroot

  sftp.listdir(path='.')是返回当前目录下的文件夹,且是以数组形式返回,然后将其拼接成完整路径后再保存在本地数组里备用,这里有个ifin是用来跳过一些网站目录,比如我xxx.demo.com这个目录不想更新,就在开头的SkipArry里写上,用来跳过

  defgetDirectory(sftp):

  print('开始获取目录...')

  sftp.chdir('/www/wwwroot')

  pathlist=sftp.listdir(path='.')

  forpathinpathlist:

  fullpath='/www/wwwroot/'+path+'/application/index/controller'

  ifpathinskipArry:

  continue

  fullpathArry.append(fullpath)

  print('目录获取完毕')

  这里就是关键的上传部分了,首先遍历出我们需要修改的文件夹目录,后面拼接上需要修改的文件Index.php形成远程服务器的文件路径,然后使用sftp.put函数来上传我们的文件,第一个参数是本地文件的路径,第二个参数是远程服务器上的路径,上传成功后使用sftp.file来验证该文件是否存在,其实这里我是做了个备份处理的(有点bug就暂时先注释掉了),先将原本的Index.php改名为BackIndex.php在上传新的Index.php,这个判断函数才有用,不然我这样写没啥用,因为上没上传成功肯定都会存在一个Index.php文件.上传好了之后使用sftp.chmod方法来改变该文件的权限为755,这里有个坑,你直接在第二个参数写755,会发现生成的文件权限为363,经过多次试验发现,第二个参数要传入8进制的755,也就是493,生成的权限就是755了,感觉有点坑爹。

  defuploadIndex(sftp):

  forfullpathiteminfullpathArry:

  remoteIndex=fullpathitem+'/Index.php'

  print('开始上传:'+remoteIndex)

  try:

  sftp.put(currentIndex,remoteIndex)

  try:

  sftp.file(remoteIndex)

  sftp.chmod(remoteIndex,int("775",8))

  print('修改'+remoteIndex+'权限为755')

  print(fullpathitem+'上传成功')

  except:

  print(fullpathitem+'上传失败')

  continue

  exceptExceptionase:

  print('错误信息:'+str(e))

  continue

  然后在main里依次执行,就能将服务器上对应的目录下的文件全部替换成我本地的文件了,代码不多,但效果好使。

  以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值。

转发此文+关注 并私信小编“资料”即可免费领取2019最新python资料和零基础入门教程!

不定期分享干货,欢迎初学和进阶中的小伙伴!


相关推荐

实战:用 Python+Flask+Echarts 构建电商实时数据大屏

在电商运营中,实时掌握销售趋势、用户行为等核心数据是决策的关键。本文将从实战角度,详解如何用Python+Flask+Echarts技术栈,快速搭建一个支持实时更新、多维度可视化的电商数据大屏,帮...

DeepSeek完全使用手册:从新手到高手的2000字实操指南

一、工具定位与核心功能矩阵(200字)DeepSeek是一款专注于深度推理的强大AI助手,其功能丰富多样,可归纳为4大能力象限:plaintext差异化优势:DeepSeek支持最长达16Ktok...

Python绘制可爱的图表 cutecharts

一个很酷的python手绘样式可视化包——可爱的图表cutecharts。Cutecharts非常适合为图表提供更个性化的触感。Cutecharts与常规的Matplotlib和Seabo...

第十二章:Python与数据处理和可视化

12.1使用pandas进行数据处理12.1.1理论知识pandas是Python中最常用的数据处理库之一,它提供了高效的数据结构和数据分析工具。pandas的核心数据结构是Serie...

5分钟就能做一个Excel动态图表,你确定不学学?(纯gif教学)

本文说明下图是一个比较酷炫的Excel动态图表,最难的部分就是用到了一个复选框控件。其实这个控件我很早就见过,但是不会用呀!望洋兴叹。这次呢,我也是借着这个文章为大家讲述一下这个控件的使用。本文没有...

Python数据可视化:从Pandas基础到Seaborn高级应用

数据可视化是数据分析中不可或缺的一环,它能帮助我们直观理解数据模式和趋势。本文将全面介绍Python中最常用的三种可视化方法。Pandas内置绘图功能Pandas基于Matplotlib提供了简洁的绘...

如何使用 Python 将图表写入 Excel

将Python生成的图表写入Excel文件是数据分析和可视化中常见的需求。Python提供了多种库(如matplotlib、openpyxl和xlsxwriter)来实现这一功能。本文...

Excel 图表制作太痛苦?用 Python 生成动态交互图表

做个动态图表花了3小时?你该换方法了!上周帮销售部做季度汇报图表,Excel操作把我整崩溃了——插入折线图后发现数据源选错,重新选择又得调格式想做动态筛选图表,捣鼓"开发工具"...

Python Matplotlib 入门教程:可视化数据的基石

一、简介Matplotlib是Python中最流行的数据可视化库,提供从简单折线图到复杂3D图形的完整解决方案。其核心优势在于:o灵活性强:支持像素级样式控制o兼容性好:与NumPy、Pa...

20种Python数据可视化绘图 直接复制可用

本文介绍20种python数据绘图方法,可直接用于科研绘图或汇报用图。1.折线图(LinePlot)-描述数据随时间或其他变量的变化。importmatplotlib.pyplotasp...

Python os模块完全指南:轻松玩转文件管理与系统操作

Pythonos模块完全指南:轻松玩转文件管理与系统操作os模块是Python与操作系统对话的"瑞士军刀",学会它能让你轻松管理文件、操控路径、获取系统信息。本教程通过场景化案例+...

Python中h5py与netCDF4模块在Anaconda环境的下载与安装

本文介绍基于Anaconda环境,下载并安装Python中h5py与netCDF4这两个模块的方法。h5py与netCDF4这两个模块是与遥感图像处理、地学分析等GIS操作息息相关的模块,应用...

python中的模块、库、包有什么区别?

一文带你分清Python模块、包和库。一、模块Python模块(Module),是一个Python文件,以.py结尾,包含了Python对象定义和Python语句。模块能定义函数,类和变...

centos7 下面使用源码编译的方式安装python3.11

centos7下面使用源码编译的方式安装python3.11,步骤如下:cd/root#只是将python3.11的安装包下载到/root目录下wgethttps://www.python.o...

Python其实很简单 第十四章 模块

模块是一组程序代码,可以是别人已经写好的,也可以是自己编写的,但都是已经存在的,在编程时直接使用就可以了。模块机制的最大好处就是程序员不再编写重复的代码,而直接利用已有的成果,这样就能将更多的精力投入...

取消回复欢迎 发表评论: