两断小代码、改改就拿去做 git的增量发布

2024-03-01 09:18

本文主要是介绍两断小代码、改改就拿去做 git的增量发布,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

用我的代码要标注来源!


# coding:utf-8
import  os, commands,datetime,re
from app.config import common as config'''
从ubuntu 上 操作centos 先要使用密码命令 ssh user@host 登录下才行
错误 target uses selinux but python bindings (libselinux-python) aren't installed! ====>yum install libselinux-python
'''class Ansible:repo_path = ""to_path = ""tar_path = ""delfile_path = ""group = ""woner = ""mode = ""fname = ""hosts = ""#远程执行命令、可指定执行目录,默认在git目录def runcmd(self,cmd,remote_path =None,statusLineOnly = True,noStatus =False):if None == remote_path:remote_path = self.repo_pathgrep = " |grep rc | awk '{print $1\":\"$3}'" if statusLineOnly else ""if noStatus==True and remote_path==False:grep = " |grep -v rc "cmd = "ansible %s -a '%s chdir=%s ' -f 20 %s " % (self.hosts,cmd,remote_path,grep)return commands.getoutput(cmd).split("\n")def __init__(self, hosts="test_group", repo="vas",mkdir=True):now = datetime.datetime.now()timeNow = now.strftime("%Y%m%d-%H%M%S")cfg = config.GIT_REPO[repo]lockpath = config.APP_PATH+"/runtime/lock/"+hosts+".lock"if not os.path.exists(lockpath):mkdir = Falsewith open(lockpath, 'w') as fobj:fobj.write(hosts)self.repo_path = cfg['path']self.to_path = cfg['remote']['path']self.tar_path = config.TAR_TMP_PATHself.delfile_path = config.DEL_LIST_PATH.replace('last_delfile','dellist_'+timeNow)self.group = cfg['remote']['group']self.owner = cfg['remote']['owner']self.mode = cfg['remote']['mode']self.hosts = hosts if hosts else config.ANSIBLE_GROUP['test_group']['ip']self.fname = self.tar_path+"/update_" + timeNow + ".tar.gz"if mkdir ==True:self.mkdir()os.chdir(self.repo_path)commands.getoutput("git fetch --all")def mkdir(self):# print u"\ngit repo path :", self.repo_pathcommands.getoutput("mkdir %s -p" % self.tar_path)ans_cmd = "ansible %s -a 'mkdir  %s -p ; mkdir  %s  -p ;mkdir -p %s' " % (self.hosts, self.to_path, self.tar_path,self.tar_path)mkdir = commands.getoutput(ans_cmd)# print ans_cmdres = [l for l in mkdir.split("\n")][0].split("|")[1].strip()# print "init remote dir: %s , %s \t %s" % (self.to_path, self.tar_path, res)commands.getoutput("echo '' > %s" % self.delfile_path)def incrPush(self):ret = ""'''git 增量更新操作:return:'''#git_cmd = "git diff $(git log --pretty=format:'%h' -1) --name-status HEAD^ | grep -v '.idea' | grep -v '.svn' |awk '{if($1==\"D\") print $2}' >" + self.delfile_pathgit_cmd = u"git diff HEAD^ --name-status | grep -v '.idea' | grep -v '.svn' |awk '{if($1 ==\"D\") print $2}' >" + self.delfile_pathcommands.getoutput(git_cmd)ret +=    u"<b>创建本次删除的文件列表到</b> ==> %s  SUCCESS " % self.delfile_pathdellist = []with open(self.delfile_path) as f:dellist = f.readlines()if dellist:ret +=    u"\n<b>删除文件明细:</b>\n" + "\n".join(dellist)else:ret += u"\n无文件删除记录"git_cmd = "git diff  --name-status HEAD^ | grep -v '.idea' | grep -v '.svn' |awk '{if($1!=\"D\") print $2}' | xargs tar cf " + self.fnameres = commands.getoutput(git_cmd)if not os.path.exists(self.fname):ret +=  u"\n <b>查找本次变更的文件: None</b>"else:listCmd = "git diff  --name-status HEAD^ | grep -v '.idea' | grep -v '.svn' |awk '{if($1!=\"D\") print $2}' "listRes = commands.getoutput(listCmd)ret +=  u"\n <b>打包变更的文件到</b> ==> %s   SUCCESS " % self.fnameret +=  u"\n <b>文件变更明细:</b>\n" + listResans_cmd = "ansible %s -m copy -a 'src=%s dest=%s remote_src=False group=%s mode=%s owner=%s ' " % (self.hosts, self.fname, self.fname, self.group, self.mode, self.owner)put = commands.getoutput(ans_cmd)result = [l for l in put.split("\n")][0].split("|")[1][:8].strip()ret += u"\n\n <b>推送文件到(%s) </b> : %s " % (self.hosts,result)if result.lower() !="success":ret += put#zipflleans_cmd = "ansible %s -a 'tar xvf %s  -C %s' " % (self.hosts, self.fname, self.to_path)put = commands.getoutput(ans_cmd)result = [l for l in put.split("\n")][0].split("|")[1].strip()ret += u"\n<b>执行远程(%s)解压文件</b> : %s " % (self.hosts,result)if result.lower() !="success":ret += putret += u"\n <b>删除远程服务器文件</b>:"if os.path.getsize(self.delfile_path) >0:#del filesflist = open(self.delfile_path).readlines()if flist:ret += "\n"for line in flist:f = line.strip()ans_cmd = "ansible %s -a 'rm -rf %s' " % (self.hosts, self.to_path + "/%s" % f)put = commands.getoutput(ans_cmd)ret +=  u'  D  %s %s ' % (f , [l for l in put.split("\n")][0].split("|")[1].strip())else:ret += u" 无"else:ret += u" 无删除列表文件 \n"return ret



# coding:utf-8
import subprocess, os, time, commands, sysclass gittool:remote = "origin"curr_branch = ""def __init__(self, repoPath):self.path = repoPathos.chdir(repoPath)def diff(self, commi1, commit2):return self.__run("git diff %s  %s --name-status | grep -v .svn | grep -v .idea")def checkout(self, branch, isNew=False):return self.__run("git checkout " + (' -b ' if isNew else "") + branch)def merge(self, branch):return self.__run("git merge " + branch)def commit(self, commitinfo):res = self.__run("git commit -am '%s' " % commitinfo)ret = []for i in res:ret.append(i.strip())return retdef fetch(self, remote=""):return self.__run("git fetch -v " + (remote if remote != '' else " --all"))def log(self, full=False):if full:return self.__run('git log -n 30')else:return self.__run('git log --pretty=format:"%h | %ad | %s | %ae |%an " --date=local -n 50')def status(self):return self.__run("git status -s ")def push(self, remote, branch):cmd = "git push " + remote.strip() + " " + branch.strip()return self.__run(cmd)def pull(self, branch="", remote=""):branch = branch if branch != '' else self.curr_branchreturn self.__run("git pull " + remote.strip() + " " + branch.strip())def show(self,tagName):res = self.__run("git show --name-status --pretty=format:'%h | %ad | %s | %ae |%an #br' --date=local " + tagName)return resdef tag(self, tagName=None, tagDesc=None, showTag=False):if showTag:return self.__run("git tag %s -v" % tagName)else:if None == tagName:return self.__run("git tag")else:if None == tagDesc:raise Exception(u"必须输标签注释")cmd = " git tag -a %s -m '%s' " % (tagName, tagDesc)self.__run(cmd)return ["create tag success"]def reset(self, to=None):return self.__run("git reset " + "--hard " + to if to != "" else "")def branch(self):return [x.replace("*", "") for x in self.__run("git branch")]def remote_list(self):cmd = "git remote -v |  awk '{print $1}' | uniq"return self.__run(cmd)def current_branch(self):branchs = self.__run("git branch")for x in branchs:if x.find("*") != -1:return x.strip().replace('*', '')return Nonedef __run(self, cmd):res = commands.getoutput(cmd)print "cmd:" + cmdreturn [x.strip().replace("\t", '    ') for x in res.split("\n")]




这篇关于两断小代码、改改就拿去做 git的增量发布的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/761947

相关文章

高效+灵活,万博智云全球发布AWS无代理跨云容灾方案!

摘要 近日,万博智云推出了基于AWS的无代理跨云容灾解决方案,并与拉丁美洲,中东,亚洲的合作伙伴面向全球开展了联合发布。这一方案以AWS应用环境为基础,将HyperBDR平台的高效、灵活和成本效益优势与无代理功能相结合,为全球企业带来实现了更便捷、经济的数据保护。 一、全球联合发布 9月2日,万博智云CEO Michael Wong在线上平台发布AWS无代理跨云容灾解决方案的阐述视频,介绍了

活用c4d官方开发文档查询代码

当你问AI助手比如豆包,如何用python禁止掉xpresso标签时候,它会提示到 这时候要用到两个东西。https://developers.maxon.net/论坛搜索和开发文档 比如这里我就在官方找到正确的id描述 然后我就把参数标签换过来

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

代码随想录冲冲冲 Day39 动态规划Part7

198. 打家劫舍 dp数组的意义是在第i位的时候偷的最大钱数是多少 如果nums的size为0 总价值当然就是0 如果nums的size为1 总价值是nums[0] 遍历顺序就是从小到大遍历 之后是递推公式 对于dp[i]的最大价值来说有两种可能 1.偷第i个 那么最大价值就是dp[i-2]+nums[i] 2.不偷第i个 那么价值就是dp[i-1] 之后取这两个的最大值就是d

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

D4代码AC集

贪心问题解决的步骤: (局部贪心能导致全局贪心)    1.确定贪心策略    2.验证贪心策略是否正确 排队接水 #include<bits/stdc++.h>using namespace std;int main(){int w,n,a[32000];cin>>w>>n;for(int i=1;i<=n;i++){cin>>a[i];}sort(a+1,a+n+1);int i=1

git ssh key相关

step1、进入.ssh文件夹   (windows下 下载git客户端)   cd ~/.ssh(windows mkdir ~/.ssh) step2、配置name和email git config --global user.name "你的名称"git config --global user.email "你的邮箱" step3、生成key ssh-keygen