创建一个新的本地仓库:
$ git init 复制代码
添加修改
添加修改到暂存区:
# 把指定文件添加到暂存区 $ git add xxx # 把当前所有修改添加到暂存区 $ git add . # 把所有修改添加到暂存区 $ git add -A 复制代码
提交的时候warning: LF will be replaced by CRLF in 解决办法
原因是存在符号转义问题
windows中的换行符为 CRLF, 而在linux下的换行符为LF,所以在执行add . 时出现提示,解决办法:
git config --global core.autocrlf false 复制代码
提交修改到本地仓库:
# 提交本地的所有修改 $ git commit -a # 提交之前已标记的变化 $ git commit # 附加消息提交 $ git commit -m 'commit message' 复制代码
储藏
有时,我们需要在同一个项目的不同分支上工作。当需要切换分支时,偏偏本地的工作还没有完成,此时,提交修改显得不严谨,但是不提交代码又无法切换分支。这时,你可以使用 git stash
将本地的修改内容作为草稿储藏起来。
推荐:太赞了,SpringBoot+Vue前后端分离完整入门教程!
官方称之为储藏,但我个人更喜欢称之为存草稿。
# 1. 将修改作为当前分支的草稿保存 $ git stash # 2. 查看草稿列表 $ git stash list stash@{0}: WIP on master: 6fae349 :memo: Writing docs. # 3.1 删除草稿 $ git stash drop stash@{0} # 3.2 读取草稿 $ git stash apply stash@{0} 复制代码
撤销修改
撤销本地修改:
# 移除缓存区的所有文件(i.e. 撤销上次git add) $ git reset HEAD # 将HEAD重置到上一次提交的版本,并将之后的修改标记为未添加到缓存区的修改 $ git reset <commit> # 将HEAD重置到上一次提交的版本,并保留未提交的本地修改 $ git reset --keep <commit> # 放弃工作目录下的所有修改 $ git reset --hard HEAD # 将HEAD重置到指定的版本,并抛弃该版本之后的所有修改 $ git reset --hard <commit-hash> # 用远端分支强制覆盖本地分支 $ git reset --hard <remote/branch> e.g., upstream/master, origin/my-feature # 放弃某个文件的所有本地修改 $ git checkout HEAD <file> 复制代码
删除添加.gitignore
文件前错误提交的文件:
$ git rm -r --cached . $ git add . $ git commit -m "remove xyz file" 复制代码
撤销远程修改(创建一个新的提交,并回滚到指定版本):
$ git revert <commit-hash> 复制代码
彻底删除指定版本:
# 执行下面命令后,commit-hash 提交后的记录都会被彻底删除,使用需谨慎 $ git reset --hard <commit-hash> $ git push -f 复制代码
更新与推送
更新:
# 下载远程端版本,但不合并到HEAD中 $ git fetch <remote> # 将远程端版本合并到本地版本中 $ git pull origin master # 以rebase方式将远端分支与本地合并 $ git pull --rebase <remote> <branch> 复制代码
推送:
# 将本地版本推送到远程端 $ git push remote <remote> <branch> # 删除远程端分支 $ git push <remote> :<branch> (since Git v1.5.0) $ git push <remote> --delete <branch> (since Git v1.7.0) # 发布标签 $ git push --tags 复制代码
查看信息
显示工作路径下已修改的文件:
$ git status 复制代码
显示与上次提交版本文件的不同:
$ git diff 复制代码
显示提交历史:
# 从最新提交开始,显示所有的提交记录(显示hash, 作者信息,提交的标题和时间) $ git log # 显示某个用户的所有提交 $ git log --author="username" # 显示某个文件的所有修改 $ git log -p <file> 复制代码
显示搜索内容:
# 从当前目录的所有文件中查找文本内容 $ git grep "Hello" # 在某一版本中搜索文本 $ git grep "Hello" v2.5 复制代码
分支
增删查分支:
# 列出所有的分支 $ git branch # 列出所有的远端分支 $ git branch -r # 基于当前分支创建新分支 $ git branch <new-branch> # 基于远程分支创建新的可追溯的分支 $ git branch --track <new-branch> <remote-branch> # 删除本地分支 $ git branch -d <branch> # 强制删除本地分支,将会丢失未合并的修改 $ git branch -D <branch> 复制代码
切换分支:
# 切换分支 $ git checkout <branch> # 创建并切换到新分支 $ git checkout -b <branch> 复制代码
标签
# 给当前版本打标签 $ git tag <tag-name> # 给当前版本打标签并附加消息 $ git tag -a <tag-name> 复制代码
合并与重置
merge 与 rebase 虽然是 git 常用功能,但是强烈建议不要使用 git 命令来完成这项工作。
因为如果出现代码冲突,在没有代码比对工具的情况下,实在太艰难了。
你可以考虑使用各种 Git GUI 工具。
合并:
# 将分支合并到当前HEAD中 $ git merge <branch> 复制代码
重置:
# 将当前HEAD版本重置到分支中,请勿重置已发布的提交 $ git rebase <branch> 复制代码
Github
Github 作为最著名的代码开源协作社区,在程序员圈想必无人不知,无人不晓。
这里不赘述 Github 的用法,确实有不会用的新手同学,可以参考官方教程:https://guides.github.com/
clone 方式
Git 支持三种协议:HTTPS / SSH / GIT
而 Github 上支持 HTTPS 和 SSH。
HTTPS 这种方式要求你每次 push 时都要输入用户名、密码,有些繁琐。
而 SSH 要求你本地生成证书,然后在你的 Github 账户中注册。第一次配置麻烦是麻烦了点,但是以后就免去了每次 push 需要输入用户名、密码的繁琐。
以下介绍以下,如何生成证书,以及在 Github 中注册。
生成 SSH 公钥
如前所述,许多 Git 服务器都使用 SSH 公钥进行认证。为了向 Git 服务器提供 SSH 公钥,如果某系统用户尚未拥有密钥,必须事先为其生成一份。这个过程在所有操作系统上都是相似的。首先,你需要确认自己是否已经拥有密钥。默认情况下,用户的 SSH 密钥存储在其 \~/.ssh
目录下。进入该目录并列出其中内容,你便可以快速确认自己是否已拥有密钥:
$ cd ~/.ssh $ ls authorized_keys2 id_dsa known_hosts config id_dsa.pub 复制代码
我们需要寻找一对以 id_dsa
或 id_rsa
命名的文件,其中一个带有 .pub
扩展名。 .pub
文件是你的公钥,另一个则是私钥。如果找不到这样的文件(或者根本没有 .ssh
目录),你可以通过运行 ssh-keygen
程序来创建它们。在 Linux/Mac 系统中,ssh-keygen
随 SSH 软件包提供;在 Windows 上,该程序包含于 MSysGit 软件包中。
$ ssh-keygen Generating public/private rsa key pair. Enter file in which to save the key (/home/schacon/.ssh/id_rsa): Created directory '/home/schacon/.ssh'. Enter passphrase (empty for no passphrase): Enter same passphrase again: Your identification has been saved in /home/schacon/.ssh/id_rsa. Your public key has been saved in /home/schacon/.ssh/id_rsa.pub. The key fingerprint is: d0:82:24:8e:d7:f1:bb:9b:33:53:96:93:49:da:9b:e3 schacon@mylaptop.local 复制代码
首先 ssh-keygen
会确认密钥的存储位置(默认是 .ssh/id_rsa
),然后它会要求你输入两次密钥口令。如果你不想在使用密钥时输入口令,将其留空即可。
现在,进行了上述操作的用户需要将各自的公钥发送给任意一个 Git 服务器管理员(假设服务器正在使用基于公钥的 SSH 验证设置)。他们所要做的就是复制各自的 .pub
文件内容,并将其通过邮件发送。公钥看起来是这样的:
$ cat ~/.ssh/id_rsa.pub ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEAklOUpkDHrfHY17SbrmTIpNLTGK9Tjom/BWDSU GPl+nafzlHDTYW7hdI4yZ5ew18JH4JW9jbhUFrviQzM7xlELEVf4h9lFX5QVkbPppSwg0cda3 Pbv7kOdJ/MTyBlWXFCR+HAo3FXRitBqxiX1nKhXpHAZsMciLq8V6RjsNAQwdsdMFvSlVK/7XA t3FaoJoAsncM1Q9x5+3V0Ww68/eIFmb1zuUFljQJKprrX88XypNDvjYNby6vw/Pb0rwert/En mZ+AW4OZPnTPI89ZPmVMLuayrD2cE86Z/il8b+gw3r3+1nKatmIkjn2so1d01QraTlMqVSsbx NrRFi9wrf+M7Q== schacon@mylaptop.local 复制代码
在你的 Github 账户中,依次点击 Settings > SSH and GPG keys > New SSH key
然后,将上面生成的公钥内容粘贴到 Key
编辑框并保存。至此大功告成。
后面,你在克隆你的 Github 项目时使用 SSH 方式即可。
克隆一个已创建的仓库:
# 通过 SSH $ git clone ssh://user@domain.com/repo.git #通过 HTTP $ git clone http://domain.com/user/repo.git 复制代码
本文使用 mdnice 排版