git是什么(写在前边的叨叨,就是给一点不懂的小白打个比喻,大佬请自行跳过)
git在平时的开发中用的太频繁了,以至于我都不知道如何去形容它。囧。
假设我们开发的工作类似于图书整理,写的代码就是很多人借书还书,假设我和你一起来整理这些书,有很多人来借书,你给A一本,我给B一本,这没有任何问题,但是,突然来了C和D,他俩同时要借一本《时间简史》,而且这本书仅此一本,我的手伸向了这本书,你的手也伸向了这本书,然后,是书在我们俩的争夺中被撕成两半了?还是我和你打起来了?
我们当然都不会这么蠢,我们拿书的时候一定会看看对方有没有正在拿,如果你先伸手了我就让给你,没有必要打一架(笑)。
我们多人开发的时候,维护一套代码,git这个工具就包含了我们许多的行为,比如常用的git pull 就相当于是用眼睛去看一下,看看书架是不是有别人已经动过了,别人已经把书摆满了,自己还继续往这个地方放书,当然放不进去啦。
git安装
- windows :https://git-scm.com/downloads
- linux:
yum install git
/apt-get install git
- MacOS:
brew install git
git常规操作
1. 新建仓库,设置全局的个人信息,ssh-key的设置
- 新建仓库
git init
- 设置个人信息
git config --global user.name "yourname"
git config --global user.email test@runoob.com
git config --list //查看当前配置信息
- ssh-key的设置
由于本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以必须要让github仓库认证你SSH key,在此之前,必须要生成SSH key。
首先在家目录下进入 .ssh 文件夹,如果没有这个文件夹或者文件夹下没有id_rsa、id_rsa.pub两个文件,就进行下边的生成过程。
ssh-keygen -t rsa -C "youremail@example.com"
之后一路回车,.ssh文件夹下就有了两个文件,私钥id_rsa和共钥id_rsa.pub,需要提供ssh密钥的都是要的共钥,id_rsa.pub。
2. 拉取远程仓库,设定远程仓库,分支和远程建立连接
- 拉取远程仓库
git clone [git地址]
这个就是最常用的git拉取一个仓库的代码到本地的命令,会在当前的目录下新建一个仓库代码文件夹。如果你的ssh已经保存在这个仓库里了,那么你可以push,否则的话你只有pull的权限。
- 设定远程仓库
比如现在你是在本地init了一个仓库,然后你在github上申请了一个仓库地址,你要把你的代码推到github上,就需要设定远程仓库了。
git remote add [名字] [地址]
比如git remote add origin git@github.com:gaopu1995/hiphp.git
,就可以把本地仓库和远程建立连接。一般默认叫它 origin。
其他的几个远程仓库命令:
git remote //查看当前远程分支名字
git remote -v //查看当前远程分支的url,有两个,一个fetch的,一个push的,一般会是一样的,就是你设置的那一个
git remote remove <name> //移除远程分支
git remote -h //其他的就自己看一下帮助吧
- 当前分支和远程仓库的分支建立连接
git push --set-upstream origin master
如果你删除或者更换了远程仓库,新的仓库在你推送的时候会让你把你当前的分支和远程分支建立映射关系,最后的两个参数就是远程仓库名和远程仓库的分支名,操作对象是你当前分支。
3. 推拉提交,处理冲突
- 推拉提交
git pull //拉取最新代码
git push //把本地提交推送到远程
git add [文件](多个文件空格隔开) //把本地的更改添加到更改缓存中
git commit -m "提交注释" //提交目前缓存中的更改
解释一下:
- git的管理是针对修改的,而推拉的单位都是每次提交的修改,就是你每次拉取(pull)的时候,都是按照别人推送的内容拉取的。比如别人推送了三个文件的修改,那你拉下来,要么不拉取,要么就是这三个文件的改动。
- 而推送的时候,首先是有一个缓存区,你把你想要提交的修改文件添加到这个缓存区,然后提交的时候就会统一把这个缓存区里的所有修改都提交到本地。
- 提交是提交到本地,本地的修改推送(push)到远程仓库,别人才能拉取到你的修改。
- commit的注释一定要写明白。这是个合作工具。交流很重要。
- 处理冲突
- 冲突是什么:比如一个文件,他修改了,而你在没有拉取他的代码之前,也对这个部分修改了,就会产生冲突。
- 为什么会有冲突:前边说过,git是对修改进行管理的,比如本来是一个a,他把a->b,你把a->c,现在他先提交的,你拉取他的代码,你的git合并你们的修改的时候,要把a变成b,但是你已经把a变成c了,git就会把这个区域标出来
怎么改:冲突部分会用 >>>>>>>>分支 标出来,改成正确的,add然后commit就行。
4. 新分支,分支合并,分支删除
git checkout [分支名] //切换分支
git checkout -b [新分支名] //从当前分支copy一个新的分支
git branch -d [分支名] //删除分支
git branch //显示当前所在分支
git merge [分支名] //当前分支合并目标分支的修改
5. 暂存stash
git stash //暂存代码
git stash list //查看stash存的内容
git stash pop //恢复第一个暂存
git stash clear //清理暂存
6. 查看log
git log //查看提交记录
git log --oneline //查看提交记录的简单模式
7. 回溯
git reset --hard commit_id //回退到某个版本