功能 | 命令 | 备注 |
初始化Git仓库 | git init | 需要提前cd到你预期的git仓库目录。命令执行之后会在当前目录生成一个.git的隐藏文件,用来追踪管理版本库。 |
暂存文件 |
git add [文件名] | 如果没有任何显示,则说明添加成功 |
把文件提交到仓库 | git commit | 还可以git commit -m [ commit说明]方便从历史记录中找到改动记录,命令执行成功之后会提示:1 file changed,2 insertions(一个文件改动,插入了两行内容) |
提交当前目录中的所有文件 |
git commit . | |
把本地的修改推送到服务器 | git push | |
显示最近到最远的提交日志 | git log | --pretty=oneline 参数可以让显示更加的直观 |
列出还没有被git管理的文件和被git管理且被修改但是还未提交(git commit)的文件 |
git status | 输入git status之后 |
撤销对尚未暂存文件的修改 | git check out --<文件名> | 该操作不可逆,需要谨慎使用。 |
对暂存的文件进行撤销,返回到未暂存的状态 | git reset HEAD --<文件名> | 简而言之就是git add的反义词 |
从远程仓库同步代码到本地 | git pull | |
详细查看本地代码都有那些改动 | git diff | 也就是查看修改了,但未暂存(add)的文件,当使用git add之后git diff就不会再显示内容 |
重命名文件 | git mv Newfile Renamefile | 指令的意思就是将文件Newfile,重命名为Renamefile |
查看所有提交的差异 | git log -p | 使用git log -p -1可以用来查看最近一次提交的差异 |
从版本库中删除该文件 | git rm <文件名> | 在文件管理器中手动删除之后,git就会知道你删除了文件,此时可用git status查看。如果要从版本库中删除,就使用git rm <文件名>并使用git commit。当文件被误删的时候(假如此时还没有git commit,此时就可以使用git checkout <文件名>来回复被删除的文件) |
用版本库中的文件替换当前工作区中的文件 | git checkout -- <文件名> | 版本库就是github上的文件,工作区就是本地repo。 |
- git之所以要分add和commit两步,优点是在于add一次可以add很多不同的文件,而commit一次可以提交很多的文件
- clone:把在服务器是那个托管的项目/代码克隆到本地
- git add:告诉git哪些文件是需要进行版本控制的
- git commit:把代码的改动提交到版本控制中(此时的提交只是提交到本地,并没有提交到服务器上)
- commit之后在vim中会打开一个日志窗口,此时可以将自己的提交日志写在里边(描述性很强的提交日志很有利于将来的版本追踪)
关于.gitignore:
.gitignore顾名思义,就是用来配置git忽略版本控制的文件。格式规范如下:
- 所有的空行和“#”开头的文件都会被git忽略,也就是.gitignore中的注释。
- 可以使用标准的glob模式匹配(其实我不懂glob是什么,类似简化后的正则表达式)
- 匹配模式最后跟反斜杠“\”,说明这是要忽略的目录。
- 要忽略指定模式意外的文件或目录,可以在模式前加上“!”来表示取反。
- *: 星号(*)是通配符,比如bulid/* 意思就是忽略build目录下的所有文件,*.c 的意思就是忽略所有后缀为.c的文件
关于git status:
git status可以显示出当前目录所有还没有被git管理的文件和被git管理且被修改但还未提交(git commmit)的文件。
git status相关名词解释
文件状态 | 解释 | 备注 |
changes not stagged for commit | 文件被修改了,但是还没有在提交(commmit)之前进行储存(stagged) | 在弹出此条信息之后,git会给出提示使用git add <文件名> 或者 git checkout -- <文件名> |
untracked | 刚刚在本地仓库创建的新文件处在未被跟踪的状态 | 此时git会提示可以使用git add <文件名>之后添加到commit中去,或者可以直接使用git commit -a来直接进行提交(反之,git commit -a 只对状态为M的文件有效) |
Your branch is ahead of 'orgin/master' by 2 commits | 本地仓库已经领先远端的主分支2个提交。 | 可以使用git push操作来发布本地的提交熬 |
在熟练使用git status之后还可以使用git status -s来查看简写的状态。此时M ---被修改,A ---被添加,D ---被删除,R ---重命名,?? ---未被追踪
关于git push:
git clone的时候有https和ssh两种方式,两种方式传输的传输方式暂不做研究讨论。在配置好ssh-key的情况下,ssh-key,默认是不需要帐号和密码的。(可以通过git config --list来查看是否配置了ssh-key)
关于配置和操作远端仓库的常用指令
功能 | 命令 | 备注 |
查看目前现有的远端仓库 | git remote -v | 这样查看到的远端仓库地址格式是https格式 |
添加新的远端仓库 | git remote add <远端仓库地址别名> <url> | |
删除别名为orgin的远端仓库 | git remote rm orgin | 删除之后再次使用git remote -V时,就会发现名为orgin的远端仓库已经被删除 |
将远端仓库上名为orgin_ssh的仓库改名为 orgin | git remote rename orgin_ssh orgin | |
查看push到远端的分支上 | git remote show orgin | |
配置免密码提交:
在使用Git进行开发的时候,我们可以使用ssh url或者http url来进行源代码的(clone/push/pull),二者的区别是,使用ssh url需要进行本地配置ssh key,这也就意味着你必须是开发者或者有一定的权限,每次的代码同步不需要进行输入用户名和密码的操作。http url相对就宽松一些。但是需要在每次同步操作的时候输入用户名和密码。为了省去每次输入密码的重复步骤可以新建一个本地文件来储存用户名和密码,当第一次输入之后,用户名和密码就会被储存起来,今后同步的时候不再需要。
在Git的官网介绍了这种实现,通过一个叫做credential helper。可以理解成证书或者凭证。它帮我们储存了credential(凭证,里边包含了用户名和密码)。
在运行git config --global credential.helper store,在第一次输入密码之后,今后同步就不再需要用户名和密码了。