初识
集中式VS分布式
概念
安装
Linux
命令安装
sudo apt-get install git
源码安装
Git官网下载源码,然后解压,依次输入:./config,make,sudo make install
Windows
Git官网直接下载安装程序,按默认选项安装即可
基础命令
查看仓库当前的状态
git status
查看修改内容
git diff
git diff HEAD -- file
版本回退
查看提交历史
git log
git reset --hard commit_id
查看命令历史
git reflog
撤销修改
git checkout -- file
文件还在工作区
git reset HEAD file
文件添加到暂存区
版本回退
文件提交到版本库
删除文件
$ git rm file $ git commit -m "remove file"
分支管理
创建分支
创建并切换到新建分支
$ git checkout -b dev
创建分支
$ git branch dev
切换分支
$ git checkout dev
合并分支
分支合并到当前分支上
$ git merge dev
禁用Fast forward合并分支
$ git merge --no-ff -m ‘合并dev分支使用–on–ff’ dev
查看分支
$ git branch
$ git branch -a
删除分支
$ git branch -d dev
强行删除分支
$ git branch -D dev
删除远程分支
git push origin :远程分支名
git push origin --delete 远程分支名
解决冲突
查看分支的合并情况
$ git log --graph
先解决冲突。解决冲突后,再提交,合并完成。
分支管理策略
1、master分支用于发布新版本 2、dev分支用于开发使用,发布版本时dev分支合并到master上
3、每个人都在dev分支开发,每个人都有自己的分支,完成时往dev分支合并
bug分支
1、保存未完成的开支分支
$ git stash
2、切换到修复bug分支并新建bug分支,完成修复合并分支,提交修复内容
3、查看保存分支信息
git stash list
4、恢复保存分支
git stash apply 恢复保存分支 git stash drop 删除stash内容
git stash pop 恢复并删除stash内容
多人协作
查看远程库的信息
$ git remote
查看远程库的详细信息
git remote -v
推送分支
$ git push origin master
把该分支上的所有本地提交推送到远程库
抓取分支
$ git checkout -b dev origin/dev
备注:克隆只能获取到master分支,若要获取远程的其他分支到本地,则用上面命令执行
1.首先,可以试图用git push origin branch-name推送自己的修改; 2.如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并;
3.如果合并有冲突,则解决冲突,并在本地提交;
4.没有冲突或者解决掉冲突后,再用git push origin branch-name推送就能成功!
5.如果git pull提示“no tracking information”,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream branch-name origin/branch-name
新建本地分支并推送远程分支
git push origin test:test
使用Github
忽略特殊文件
实战
拉取远程分支到本地
本地没有代码仓库时 1、本地新建文件夹进入并初始化:$ git init
2、与远程仓库建立连接:git remote add origin XXXXX.git
3、使用git branch 查看本地是否具有dev分支
4、如果没有 git fetch origin dev
5、在本地创建分支dev并切换到该分支 git checkout -b dev origin/dev
6、把gitLab上dev分支上的内容都拉取到本地:git pull origin dev
拉取远程标签到本地
本地没有代码仓库时 1、本地新建文件夹进入并初始化:$ git init
2、与远程仓库建立连接:git remote add origin XXXXX.git
3、$ git fetch origin tagName
5、新建一个分支,指向某个tag: $ git checkout -b branchName tagName
设置
创建版本库
远程仓库
准备工作
1、创建SSH Key
$ ssh-keygen -t rsa -C "youremail@example.com"
2、登陆GitHub Add SSH Key
在Key文本框里粘贴id_rsa.pub文件的内容
添加远程仓库
本地仓库关联远程库
$ git remote add origin git@github.com:xxxxx.git
首次本地仓库内容推送至远程库
$ git push -u origin master
本地仓库提交内容至远程
$ git push origin master
注:先有本地库后有远程库按以上操作进行本地库与远程库关联
提示refusing to merge unrelated histories时,$ git pull origin master --allow-unrelated-histories
failed to push some refs to git 解决是同步远程仓库生成的文件到本地仓库:git pull --rebase origin master
从远程库克隆
$ git clone git@github.com:xxxxx.git
注:远程库建立一个库克隆到本地
标签管理
标签
发布版本时,先在版本库中打一个标签(tag), 确定标签时刻的版本。但取某个标签的版本,
就是把那个打标签的时刻的历史版本取出来。
标签也是版本库的一个快照
创建标签
git tag <name>
$ git tag <name> commit_id
创建带有说明的标签: $ git tag -a v0.1 -m “version 0.1 released” 3628164
-a指定标签名,-m指定说明文字
查看所有标签
git tag
查看标签信息
git show <tagname>
删除标签
删除本地
git tag -d <tagname>
删除远程
git push origin :refs/tags/<tagname>
推送标签到远程
git push origin <tagname>
使用云码
功能
提供免费的Git仓库 集成了代码质量检测
项目演示
项目管理
代码托管
文档管理
提供私有库
5人以下小团队免费
删除关联远程库
git remote rm origin
注意:看完多操作,加深印象,多练练就体会其中