远程仓库相关命令
检出仓库:$ [email protected]:yaoxiabing/saltstack.git 查看远程仓库:$ git remote -v 添加远程仓库:$ git remote add [name] [url] 删除远程仓库:$ git remote rm [name] 修改远程仓库:$ git remote set-url --push [name] [newUrl] 拉取远程仓库:$ git pull [remoteName] [localBranchName] 推送远程仓库:$ git push [remoteName] [localBranchName]
分支(branch)操作相关命令
查看本地分支:$ git branch 查看远程分支:$ git branch -r 创建本地分支:$ git branch [name] ----注意新分支创建后不会自动切换为当前分支 切换分支:$ git checkout [name] 创建新分支并立即切换到新分支:$ git checkout -b [name] 删除分支:$ git branch -d [name] ---- -d选项只能删除已经参与了合并的分支,对于未有合并的分支是无法删除的。如果想强制删除一个分支,可以使用-D选项 合并分支:$ git merge [name] ----将名称为[name]的分支与当前分支合并 创建远程分支:$ git push origin [name] 删除远程分支:$ git push origin :heads/[name] 或 $ git push origin :[name] 如:[root@centos7 saltstack]# git push origin --delete 123 # 删除远程分支
发现有人总结得不错,就直接引用了。http://blog.chinaunix.net/uid-9398085-id-3164754.html
example1 : 把本地的某个分支origin2提交到远程仓库,并作为远程仓库的master分支,或者作为名叫123的分支
[root@centos7 saltstack]# git branch origin2 # 创建一个本地分支origin2 [root@centos7 saltstack]# git push origin origin2:123 # 提交本地origin2分支作为远程的123分支 [root@centos7 saltstack]# git push origin origin2:master # 提交本地origin2分支作为远程的master分支
example2: 删除不对应远程分支的本地分支
[root@centos7 saltstack]# git fetch -p # 在fetch之后删除掉没有与远程分支对应的本地分支 -p:是prune 修剪的意思
example3: 手误rm删除本地仓库的某个文件,使用git checkout -- <file>可以恢复
[root@centos7 saltstack]# ll total 24 drwxr-xr-x 4 root root 37 Oct 30 23:27 config -rw-r--r-- 1 root root 555 Oct 30 23:27 config.ini -rw-r--r-- 1 root root 13157 Oct 30 23:27 fabfile.py -rw-r--r-- 1 root root 38 Oct 30 23:31 README drwxr-xr-x 4 root root 37 Oct 30 23:27 template [root@centos7 saltstack]# rm README -f [root@centos7 saltstack]# ll total 20 drwxr-xr-x 4 root root 37 Oct 30 23:27 config -rw-r--r-- 1 root root 555 Oct 30 23:27 config.ini -rw-r--r-- 1 root root 13157 Oct 30 23:27 fabfile.py drwxr-xr-x 4 root root 37 Oct 30 23:27 template [root@centos7 saltstack]# git checkout -- README [root@centos7 saltstack]# ll total 24 drwxr-xr-x 4 root root 37 Oct 30 23:27 config -rw-r--r-- 1 root root 555 Oct 30 23:27 config.ini -rw-r--r-- 1 root root 13157 Oct 30 23:27 fabfile.py -rw-r--r-- 1 root root 38 Oct 30 23:35 README drwxr-xr-x 4 root root 37 Oct 30 23:27 template
example4: 使用rm(没使用git rm)删除某个文件,git commit -a强制提交
[root@centos7 saltstack]# ls config config.ini fabfile.py README template [root@centos7 saltstack]# [root@centos7 saltstack]# [root@centos7 saltstack]# rm README -f [root@centos7 saltstack]# git commit -a -m "for test" [root@centos7 saltstack]# git push [root@centos7 saltstack]# ll total 20 drwxr-xr-x 4 root root 37 Oct 30 23:27 config -rw-r--r-- 1 root root 555 Oct 30 23:27 config.ini -rw-r--r-- 1 root root 13157 Oct 30 23:27 fabfile.py drwxr-xr-x 4 root root 37 Oct 30 23:27 template
example5:使用git rm -rf强制删除某个目录后,使用git reset回退。
git reset [--hard|soft|mixed|merge|keep] [commit或HEAD],根据--soft --mixed --hard,会对working directory、index、HEAD进行重置。 A). --hard:除了“Untracked files”,其他变更都被重置。即:重设index和working directory,自从commit以来在working directory和index中的任何改变都被丢弃,并把HEAD指向commit。 B). --soft:这个模式的效果是,执行完毕后,自从commit以来的所有改变都会显示在git status的"Changes to be committed"中,当然,还有“Untracked files”。即:恢复commit以来的index和working directory内容。即:not commited C). --mixed:这个模式是默认模式。这个模式的效果是,自从commit以来的修改都会被保留,但会被标记成"Changes not staged for commit"。即:仅重置index,文件修改被转移到working directory中。即:not added (来自某大神的博客:http://lingxiankong.github.io/blog/2014/07/18/git-notes/)
example6: 如何判断分支tracking了没?
git的tracking就是把来源和目标绑定在一起,tracking只能一对一。 git push -u origin master 这时所在的分支就已经 tracking to origin/master 了,-u 就是这个用处。 查看.git/config配置文件也可以看出来 [branch "master"] remote = origin merge = refs/heads/master # 有这个表示是有tracking的,tracking实质其实就是pull 的 merge 动作来源
查看提交日志相关命令
[root@centos7 saltstack]# git blame test.txt # 查看test.txt这个文件中内容每一行提交的作者,最后的提交时间 [root@centos7 saltstack]# git log # 查看仓库提交记录,有几个常用选项 --oneline:一行显示每个commit的提交哈希值和提交信息 --graph:在显示内容左边绘制一张分支拓扑图 --all:显示所有分支 --name-status:简洁的日志信息,以及修改了哪些文件 -5:显示5个commit记录
后续继续补充。。。
参考链接:http://zengrong.net/post/1746.htm