git详细认知

初识

集中式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

注意:看完多操作,加深印象,多练练就体会其中

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值