首先介绍一写基本的git操作命令:

  • 查看当前项目的远程地址:
    • git remote -v
  • 查看远程地址所有分支:
    • git branch -a 或者 git branch -r
  • 查看本地分支与远程分支的映射关系:
    • git branch -vv
 
新建分支和创建映射的方式:
一:
  • 新建分支:
    • git branch  xxx 
    • git checkout xxx
  • 新建分支,并切换到该分支:git checkout -b issue1
  • 当前分支与远程分支创建映射关系(文件跟踪):
    • git branch -u origin/addFile  或者 
    • git branch --set-upstream-to origin/issue1
  • 解除映射关系:git branch --unset-upstream
  •  
  • PS : 本地分支与远程分支可以不同名
二:
  • 在本地新建分支,并自动切换到该分支;建立本地分支和远程分支的映射关系:
    • git checkout -b 本地分支名x origin/远程分支名x       
三:
  • 在本地新建分支,不切换到该分支;不建立远程映射关系:
    • git fetch origin  远程分支名x:本地分支名x
 
分支的修改提交:
  • git add
  • git commit -m "注释"
  • 以上两个命令的合并写法:git commit -a -m "注释"
 
分支的推送:
  • git push origin 本地分支x:远程分支x
  • 分支已有映射关系:git push
 
合并分支:
  • 切换到主分支或者测试分支(master或者develop)
    • git checkout develop
    • git merge hotfix
 
解决合并多个分支时的冲突:
  • 主分支中执行:
    • 获取当前分支状态:
      • git status
    • 选择解决冲突原始工具:
      • git mergetool
      • vimdiff (工具解决冲突保存完成层后,确认已解决,自动存入缓存区)或者使用IDE解决冲突后,主动添加到缓存区(git add ./)
    • 冲突解决完成后,提交文件:
      • git commit 
 
IDE解决冲突,phpstorm为例:
 
 
分支完成开发使命后的删除:
  • 删除本地分支:
    • git branch -d xxx
    • 强制删除:git branch -D XXX
  • 删除远程分支:
    • git push origin --delete hotfix
    • git push origin :br  (origin 后面有空格)
  • 删除a目录下的2.txt文件
    • git rm -r --cached a/2.txt
  • 删除a目录
    • git rm -r --cached a
    • git commit -m "删除a目录下的2.txt文件" 
    • git push
  • Note: 用-r参数删除目录, git rm --cached a.txt 删除的是本地仓库中的文件,且本地工作区的文件会保留且不再与远程仓库发生跟踪关系,如果本地仓库中的文件也要删除则用git rm a.txt
 
分支代码回滚:
  • 本地代码库分支回滚:
    • git reset --hard commit-id :回滚到commit-id,讲commit-id之后提交的commit都去除
    • git reset --hard HEAD~3:将最近3次的提交回滚
  • 远程代码库回滚:
    • 这个是重点要说的内容,过程比本地回滚要复杂
    • 应用场景:自动部署系统发布后发现问题,需要回滚到某一个commit,再重新发布
    • 原理:先将本地分支退回到某个commit,删除远程分支,再重新push本地分支
    • 操作步骤:
    • git checkout the_branch
    • git pull
    • git branch the_branch_backup //备份一下这个分支当前的情况
    • git reset --hard the_commit_id //把the_branch本地回滚到the_commit_id
    • git push origin :the_branch //删除远程 the_branch
    • git push origin the_branch //用回滚后的本地分支重新建立远程分支
    • git push origin :the_branch_backup //如果前面都成功了,删除这个备份分支
    • 如果使用了gerrit做远程代码中心库和code review平台,需要确保操作git的用户具备分支的push权限,并且选择了 Force Push选项(在push权限设置里有这个选项)
 
 
服务器上部署Git 并创建 webhook:
    • 使用php执行webhook,注意事项:
      • linux下php的执行用户,权限;
      • 切记hook操作的目标文件,不要用高权限用户修改或者pull等操作(例root),否则会造成hook失效,后面再思考是否可以避免这样的情况。
      • 做钩子大多是走 ssh 协议, 需要coding 里配置部署公钥
        • hook前期的配置工作:
          • 生成 当前设备、php执行用户 公钥,配置至coding的应用公钥和部署公钥中,可参考coding - ssh公钥生成文档 https://coding.net/help/doc/git/ssh-key.html#i-4
          • clone git仓库ssh地址(允许后续hook文件的免密拉取代码操作)
            • BTW:如果项目一开始采用https协议克隆代码,可通过:git remote set-url origin <ssh地址>   将https转化成ssh
            • 如果使用tortoise git等三方工具,则需替换默认ssh工具到Git执行文件,以tortoise git为例:
Setting->network->SSH
C:\Program Files\TortoiseGit\bin\TortoiseGitPlink.exe
替换为本地Git执行文件路径
X:\Program Files\Git\usr\bin\ssh.exe
 
编写webhook文件,给一个简单的示例:
<?php
error_reporting(1);
$output = shell_exec('id -a');//判断是否是www:www在执行
$action_user = "<pre>$output</pre>";
file_put_contents('./log/user_action.log',"USER_ACTION::".$action_user.$output. PHP_EOL , FILE_APPEND); $target = '/usr/local/nginx/html/git_work/forecast_admin/forecast'; // 测试环境web目录
$token = 'forecast'; //token校验暂不启用
$wwwUser = 'www';
$wwwGroup = 'www'; $json = json_decode(file_get_contents('php://input'), true);
file_put_contents('./log/user_action.log',"HOOK_DATA::".file_get_contents('php://input'). PHP_EOL , FILE_APPEND); $cmds = array(
"cd $target && git pull origin develop",
"chown -R {$wwwUser}:{$wwwGroup} $target/",
); foreach ($cmds as $cmd) {
$shellExec = shell_exec($cmd); if($shellExec == NULL) {
file_put_contents('./log/test_try2.log', 'shell success'.$cmd, FILE_APPEND);
} else {
file_put_contents('./log/test_try_error.log', 'shell false'.$cmd, FILE_APPEND);
}
}
根据实际情况,按照以上git分支的方法操作本地和远程分支,就ok哒。
 
 
此外,关于git webhook和php发布 待了解的两个公共包:

1.composer  cpliakas/git-wrapper

2.composer  deploy
 
 
 

Git分支基本命令+coding webhook+lnmp的更多相关文章

  1. Git 分支基本命令

    1. 查看当前分支 (git branch) 2. 创建分支 (git branch 分支名) 3.切换分支(git checkout 分支名) 4.分支上的常规操作 5.分支的合并 (git che ...

  2. github webhook 实现代码自动部署 踩坑!! 附加git&coding webhook部署代码

    踩坑: 1.php程序执行linux命令是以webserver的user用户(如apache .www……)操作的,需要在/etc/sudoers添加用户免密码操作权限; %apache ALL=(A ...

  3. php 通过exec 创建git分支失败

    今天给我们自己的发布系统增加一个新建分支的功能,操作比较简单,但是使用php执行shell命令的时候总是无法push分支到远程,但是登陆服务器执行却是可以的 新建分支命令如下 git fetch -- ...

  4. Git版本控制:Git分支处理

    http://blog.csdn.net/pipisorry/article/details/46958699分支的意义创建分支可以避免提交代码后对主分支的影响,同时也使你有了相对独立的开发环境. 假 ...

  5. Git的基本命令介绍

    Git的安装 进入官网下载系统所需要的版本  官网地址:https://git-scm.com/downloads 点击下载按钮官方网站一般会根据操作系统的自动下载所需要的Git版本. 下载完成后,点 ...

  6. Git版本号控制:Git分支处理

    http://blog.csdn.net/pipisorry/article/details/46958699分支的意义创建分支能够避免提交代码后对主分支的影响,同一时候也使你有了相对独立的开发环境. ...

  7. Git-Runoob:Git 分支管理

    ylbtech-Git-Runoob:Git 分支管理 1.返回顶部 1. Git 分支管理 几乎每一种版本控制系统都以某种形式支持分支.使用分支意味着你可以从开发主线上分离开来,然后在不影响主线的同 ...

  8. 【第七篇】- Git 分支管理之Spring Cloud直播商城 b2b2c电子商务技术总结

    ​ Git 分支管理 几乎每一种版本控制系统都以某种形式支持分支.使用分支意味着你可以从开发主线上分离开来,然后在不影响主线的同时继续工作. 有人把 Git 的分支模型称为必杀技特性,而正是因为它,将 ...

  9. Git 分支

    Git 保存的不是文件的变化或者差异,而是一系列不同时刻的文件快照,某一次的提交指向这处时刻的文件快照,看起来就像每次提交都保存了当时的文件,连续的提交形成一条长链 分支 指向某一个特定的提交,不同的 ...

随机推荐

  1. 为实践javaweb项目,搭建了相应环境

    为实践javaweb项目,搭建了相应环境,现总结一下. JDK与JRE的安装与配置 前提准备: 1.我们下载的JDK安装包里面既包含JDK又包含JRE: 2.要确认你的电脑里面没有JDK和JRE的残留 ...

  2. 通过CSS3属性值的变化实现动画效果+触发这些动画产生交互

    css3过渡 transition 兼容性:IE10+ transition: none | all | property 默认为none all 表示所有属性过渡 property 指定属性值,如c ...

  3. JavaScript自学笔记(3)--- 用JS来实现网页浮窗

    最近做个小项目,给网页加个浮窗,考验了基础的css,js技术,还是蛮有意思的,代码如下(部分代码来源于引用,见底部) <!DOCTYPE html> <html> <he ...

  4. 洛谷P1056 排座椅

    洛谷P1056 排座椅 洛谷传送门 题目描述 上课的时候总会有一些同学和前后左右的人交头接耳,这是令小学班主任十分头疼的一件事情.不过,班主任小雪发现了一些有趣的现象,当同学们的座次确定下来之后,只有 ...

  5. webpack安装jQuery报错

    使用webpack搭建项目,并使用了node下载了jQuery使用,使用命令行完成构建时发现报错了, ERROR in ./node_modules/jquery/lib/node-jquery.js ...

  6. Navicat Premium15安装与激活(破解)

    Navicat premium是一款数据库管理工具,是一个可多重连线资料库的管理工具,它可以让你以单一程式同时连线到 MySQL.SQLite.Oracle 及 PostgreSQL 资料库,让管理不 ...

  7. SpringBoot原理—分析SpringBoot启动机制(starter机制)

    一:前言使用过springboot的同学应该已经知道,springboot通过默认配置了很多框架的使用方式帮我们大大简化了项目初始搭建以及开发过程.本文的目的就是一步步分析springboot的启动过 ...

  8. 关于xshell和文件传输相关

    Xshell连接linux系统 下载Xshell后启动软件 不能连接,没有弹出输入账户和密码时在linux中执行 然后再次执行Xshell 连接成功 文件传输 点击Xshell的文件传输 会引导你去安 ...

  9. 在Visual Studio中将dll以资源的形式嵌入exe中

    一.Dll的优点: 1.扩展应用程序的特性 2.简化项目管理 3.有助于节省内存 4.促进资源的共享 5.促进本地化 6.有助于解决平台间的差异 7.可用于特殊目的 有关于dll及注入相关理论资料,可 ...

  10. 批量获取mysql数据库实例指定参数的值

    需求:需要对比所有mysql数据库实例上面的指定参数配置情况,同时需要需要能看到如ip,端口,master or slave,毕竟主和从参数不一样还是有可能的. 说明:必须要有个数据库存储所有是数据库 ...