Git常用命令和说明
1、git提交代码commit
git commit 主要是将暂存区里的改动给提交到本地的版本库。每次使用git commit 命令我们都会在本地版本库生成一个40位的哈希值,这个哈希值也叫commit-id。
commit-id在版本回退的时候是非常有用的,它相当于一个快照,可以在未来的任何时候通过与git reset的组合命令回到这里。
1.1 git commit -m “message”
这种是比较常见的用法,-m 参数表示可以直接输入后面的“message”,如果不加 -m参数,那么是不能直接输入message的,而是会调用一个编辑器一般是vim来让你输入这个message,
message即是我们用来简要说明这次提交的语句。还有另外一种方法,当我们想要提交的message很长或者我们想描述的更清楚更简洁明了一点,我们可以使用这样的格式,如下:
git commit -m ‘
message1
message2
message3
1.2 git commit -a -m “massage”
其他功能如-m参数,加的-a参数可以将所有已跟踪文件中的执行修改或删除操作的文件都提交到本地仓库,即使它们没有经过git add添加到暂存区,注意,
新加的文件(即没有被git系统管理的文件)是不能被提交到本地仓库的。建议一般不要使用-a参数,正常的提交还是使用git add先将要改动的文件添加到暂存区,再用git commit 提交到本地版本库。
1.3 git commit --amend
如果我们不小心提交了一版我们不满意的代码,并且给它推送到服务器了,在代码没被merge之前我们希望再修改一版满意的,而如果我们不想在服务器上abondon,那么我们怎么做呢?
git commit --amend //也叫追加提交,它可以在不增加一个新的commit-id的情况下将新修改的代码追加到前一次的commit-id中,
(1) 假如现在版本库里最近的一版正是我们想要追加进去的那版,此时是最简单的,直接修改工作区代码,然后git add,之后就可以直接进行git push到服务器,中间不需要进行其他的操作如git pull等
(2) 如果现在版本库里最近的一版不是我们想要追加进去的那版,那么此时我们需要将版本库里的版本回退到我们想要追加的那一版,想要将版本回退到我们想要的哪一版有好几种方法
1) 第一种即是我们从服务器上选取我们需要的版本,直接进行挑拣,在服务器的提交管理页面上右上方一般会有一个Download按钮,点击会弹出一个下拉框,选择其中的cherry-pick,复制命令,
之后在我们版本仓库对应的目录下运行这个命令,执行完后,使用git log -1 命令,可以查看到现在版本库里最近的一版变成了我们刚才挑拣的这版,此时再在工作区直接修改代码,
改完之后进行git add,再执行本git commit --amend命令,之后git push.
2) 使用gitk或其他的图形界面化工具,在终端输入 gitk,回车,会弹出gitk的图形界面,在界面的左侧部分陈列着版本库中的一条条commit-id,此时选中我们需要的那一版,右键点击之后会弹出一个
选择菜单,如果是在master 分支上,那么其中会有一项是 Reset master branch to here,点击这项,会弹出一个名为confirm reset的确认box,选择reset type 中的hard项,再点击OK,
关闭gitk图形界面,回到终端,运行git log -1命令,发现现在版本库里最近的一次提交已经是我们希望的那一版了,此时再在工作区直接修改代码,改完之后进行git add,
再执行本git commit --amend命令,之后git push.
3) 如果我们知道我们需要的版本与现在最近的版本中间隔着 n 个提交,那么我们可以直接使用git reset --hard HEAD~n命令,关于git reset 命令有详解,此时这个命令执行完后,
运行git log -1 命令我们会发现现在版本库里最近的一版就是我们需要的那版,此时再在工作区直接修改代码,改完之后进行git add,再执行本git commit --amend命令,之后git push.
4) 如果我们不知道我们需要的版本与现在最近的版本中间隔着 n 个提交,那么我们可以使用git log来查看版本库中的commit-id,找到我们需要的commit-id后,在终端中执行git reset --hard commit-id,
时这个命令执行完后,运行git log -1 命令我们会发现现在版本库里最近的一版就是我们需要的那版,此时再在工作区直接修改代码,改完之后进行git add,再执行本git commit --amend命令,之后git push.
1.4 git commit --help
查看帮助,还有许多参数有其他效果,一般来说了解上述三种即可满足我们工作中的日常开发了
2.查看当前仓库状态仓库下的工作区文件是否被修改过)
git status
3、git取消忽略某个指定的文件
git update-index --no-assume-unchanged config.conf
4、将当前版本回退到上一个版本,命令如下:
git reset --hard HEAD^
5、 回退到上两个版本
git reset – hard HEAD^^
6、回退到指定版本
git log //显示从最近到最远的提交日志
git reset --ha 1234567rd_commit_id //回退到指定版本
7、查看命令历史
git reflog
8、拉取暂存区文件并将其替换成工作区文件
git checkout-- <file>
9、跟踪取消,即把文件从git中拿出来,不再进行版本跟踪,但保留工作区的文件。
git rm - - cached filename
10、查看工作区和版本库里面最新版本的区别
git diff HEAD – readme.txt
git diff命令比较的是工作目录中当前文件与暂存区快照之间的差异,也就是修改之后还没有暂存起来的变化内容
11、将工作去的内容放入版本库的暂存区
git add readme.txt
12、显示工作目录和暂存区的状态
git status
13、删除一个文件
git rm test.txt
14、从远程库克隆项目
git clone 项目地址
15、创建分支,然后切换到分支
git checkout -b test_localhost
git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:
git branch test_localhost //创建一个分支
git checkout test_localhost //切换分支
16、查看当前分支
git branch //查看本地分支
git branch -r //查看远程分支
git branch -a //命令会列出所有分支,当前分支前面会标一个*号
17、git merge命令用于合并指定分支到当前分支
git merge dev
18、删除本地分支
git branch -d dev
如果有未合并的工作,则不能删除该分支。
git branch --no-merged //查看尚未合并的工作
如果确实想要删除该分支上的改动,可以用大写的删除选项 -D 强制执行
19、删除远程dev分支
git push origin --delete dev
20、切换分支
git checkout <name>
21、查看远程库的信息
git remote 或 git remote -v
22、推送分支,就是把该分支上的所有本地提交推送到远程库。推送时,要指定本地分支,这样,Git就会把该分支推送到远程库对应的远程分支上:
git push origin master
如果要推送其他分支,比如dev,就改成:
git push origin dev
23、拉取分支
git pull //如果当前分支只有一个追踪分支,连远程主机名都可以省略
拉取远程分支:git pull origin dev
将远程存储库中的更改合并到当前分支中。在默认模式下,git pull是git fetch后跟git merge FETCH_HEAD的缩写。
更准确地说,git pull使用给定的参数运行git fetch,并调用git merge将检索到的分支头合并到当前分支中。 使用--rebase,它运行git rebase而不是git merge。
24、 查看工作区的readme.txt与缓存区的readme.txt的区别
$ git diff readme.txt
25、查看最近到最远的提交记录
git log