前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >git 大法,玩转版本管理

git 大法,玩转版本管理

作者头像
桃翁
发布2018-12-05 18:19:57
4690
发布2018-12-05 18:19:57
举报
文章被收录于专栏:前端桃园前端桃园

最近有小伙伴问我 git 应该怎么学,我觉得 git 就是多用就会了,把常用的命令先看两边,然后再在实际过程中运用,忘了再去查一查,用多了就记住了,当然这只是代码管理,要达到真正的版本管理,还需要一些规范。比如提交代码的规范,各个版本之间怎么管理,分支怎么管理等等,我尽量在下一篇文章中分享。

今天文章就先把一些常用的命令进行介绍,看看自己有哪些还没用过的,记下来,说不定遇到这种事儿就会用了。

工程下载、分支的增删查改

工程下载:

  • clone 远程工程:git clone https://XXXX.git
  • fetch 远程分支到本地某分支:git fetch origin :

分支的增删查改

  • 查看分支:git branch
  • 查看远程所有分支:git branch -r
  • 查看本地和远程所有分支:git branch -a
  • 创建分支:git branch
  • 切换分支:git checkout
  • 创建并切换分支:git checkout -b
  • 合并某分支到当前分支:git merge
  • 把分支推送到远程:git push origin
  • 删除本地分支:git branch (-d | -D)
  • 删除远程分支:git push origin -d
  • 分支重命名:git branch (-m | -M)

查看提交信息日志

  • 查看分支最近一次的修改列表:git status
  • 查看分支的commit信息(倒叙排列)
  • git log 查看commit id, Author, Date, commit info
  • git shortlog 按提交者分类显示提交信息
  • git log --oneline 只输出commit id 和 commit info
  • git log --stat 查看增删查改了哪些文件

版本回退

  • 回退到上一版本:git reset --hard HEAD^
  • 回退到上上版本:git reset --hard HEAD^^
  • 回退到上上版本:git reset --hard HEAD~2
  • 回退到某个版本:git reset --hard
  • 强制推送到远程分支:git push -f

注意: 1、HEAD 指向的版本是当前版本,^ 表示上一个版本,~N 表示上N个版本,可简写 2、git log 可以查看 3、git reflog 可以查看命令历史,用来回到某个未来的版本

文件的添加、提交、拉取、推送、比对、合并

  • 添加新增文件:git add README.md
  • 添加所有新增文件:git add .
  • 暂存变更文件:git stash [save "暂存备注"]
  • 恢复暂存文件:git stash pop
  • 提交变更文件:git commit -m "变更备注"
  • 拉取远程代码:git pull [origin ]
  • 推送到远程:git push origin
  • 比对两个分支:git diff
  • 比对两个分支变更的文件列表:git diff --stat
  • 比对本地和远程分支:git diff origin/
  • 合并某个分支:git merge
  • 强制覆盖本地分支: 1、git fetch --all 2、git reset --hard origin/ 3、git pull

常用选项和其他命令

git 中部分选项解释

  • -f --force:强制
  • -d --delete:删除
  • -D --delete --force
  • -m --move:移动或重命名
  • -M --move --force
  • -r --remote:远程
  • -a --all:所有

其他命令

  • 清空工程:
代码语言:javascript
复制
$ git rm -rf .
  • 每隔X秒运行一次git pull:
代码语言:javascript
复制
for((i=1;i<=10000;i+=1)); do sleep X && git pull; done

使用git rebase将一个feature分支变基到master分支

代码语言:javascript
复制
$ git checkout feature 
$ git rebase master

配置相关

  • 查看当前配置: git config --list
  • 修改 git 的 name 和 email :
代码语言:javascript
复制
git config --global user.name <name>
git config --global user.email <email>

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2018-10-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 前端桃园 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 工程下载、分支的增删查改
    • 工程下载:
      • 分支的增删查改
      • 查看提交信息日志
      • 版本回退
      • 文件的添加、提交、拉取、推送、比对、合并
      • 常用选项和其他命令
        • git 中部分选项解释
          • 其他命令
          • 配置相关
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档