Git学习笔记

本文是学习廖雪峰老师的网站的git学习笔记,这个连接是到原网址的:https://www.liaoxuefeng.com/wiki/0013739516305929606dd18361248578c67b8067c8c017b000/#0

 

Git学习笔记

目的:版本控制, 想查看某次改动,只需要在软件里瞄一眼就可以

 

分布式版本控制系统:

每个人电脑里都有完整的版本库,如果两个人同时在各自的电脑上修改了同一个文件,只需把各自的修改推送给对方,就可以互相看到对方的修改。但因为两个人相互之间各种原因不能相互访问,所以其实很少在两人之间的电脑上推送版本库的修改,所以通常也有一台充当“中央服务器”的电脑,但这个服务器的作用仅仅是用来方便“交换”大家的修改

 

$ git config --global user.name "Your Name"

$ git config --global user.email email@example.com

 

$ git init

 

所有的版本控制系统,其实只能跟踪文本文件的改动。二进制文件每次改动串起来,版本控制系统也就是只知道图片从100KB改成了120KB,所以版本控制系统是没法跟踪Word文件的改动的。

                                                                                            

 

git add readme.txt

git add 文件夹/            添加整个文件夹及内容

git add *.文件类型       添加目录中所有此文件类型的文件

git添加文件需要add,commit一共两步,这是因为commit可以一次提交很多文件

 

git commit -m "git tracks changes"  提交修改

git commit --amend --no-edit    "--no-edit": 不编辑, 直接合并到上一个 commit,这个命令是在commit之后发现有一个修改忘记了提交,使用这个命令可以将这个commit直接合并到上一个commit中。

 

git status命令可以让我们时刻掌握仓库当前的状态

git status -s # "-s": status 的缩写模式

git diff readme.txt能看看具体修改了什么内容

 

git log查看每次的修改记录

git log --pretty=oneline

 

在Git中,用HEAD表示当前版本,上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。

 

git reset --hard HEAD^   回退到上一个版本

git reset --hard 1094a

git reflog用来记录你的每一次命令

 

工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。你可以简单理解为,需要提交的文件修改通通放到暂存区,然后,一次性提交暂存区的所有修改。

 

 

git commit

 

git checkout -- readme.txt丢弃工作区的修改,工作区修改即是刚刚进行但还未add的修改

git reset HEAD <file>可以将add的修改回退(unstage), 表示最新的版本

 

在用户主目录里找到.ssh目录,里面有id_rsa和id_rsa.pub两个文件,这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人

 

远程仓库:

 

git remote add origin git@github.com:liuyunjian/learngit.git    关联远程仓库,添加后,远程库的默认名字就是origin

 

git push -u origin master   将本地仓库推送到云端仓库,第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令,git push origin master

 

git clone git@github.com:liuyunjian/gitskills.git 从github克隆一个仓库到本地工作目录,呈现出来的形式就是在工作目录下创建了一个类似github上的仓库的文件夹

 

git remote –v   显示远程库得详细信息

 

git push origin master   将本地master分支上所有得本地提交推送到远程库

推送策略推荐:

  1. master分支是主分支,因此要时刻与远程同步;
  2. dev分支是开发分支,团队所有成员都需要在上面工作,所以也需要与远程同步;
  3. bug分支只用于在本地修复bug,就没必要推到远程了,除非老板要看看你每周到底修复了几个bug;
  4. feature分支是否推到远程,取决于你是否和你的小伙伴合作在上面开发。

 

多人协作

当你从远程仓库克隆时,实际上Git自动把本地的master分支和远程的master分支对应起来了,并且,远程仓库的默认名称是origin。

 

要查看远程库的信息,用git remote:

 

$ git remote

origin

或者,用git remote -v显示更详细的信息:

 

$ git remote -v

origin  git@github.com:michaelliao/learngit.git (fetch)

origin  git@github.com:michaelliao/learngit.git (push)

上面显示了可以抓取和推送的origin的地址。如果没有推送权限,就看不到push的地址。

 

推送分支

推送分支,就是把该分支上的所有本地提交推送到远程库。推送时,要指定本地分支,这样,Git就会把该分支推送到远程库对应的远程分支上:

 

$ git push origin master

如果要推送其他分支,比如dev,就改成:

 

$ git push origin dev

但是,并不是一定要把本地分支往远程推送,那么,哪些分支需要推送,哪些不需要呢?

 

master分支是主分支,因此要时刻与远程同步;

 

dev分支是开发分支,团队所有成员都需要在上面工作,所以也需要与远程同步;

 

bug分支只用于在本地修复bug,就没必要推到远程了,除非老板要看看你每周到底修复了几个bug;

 

feature分支是否推到远程,取决于你是否和你的小伙伴合作在上面开发。

 

总之,就是在Git中,分支完全可以在本地自己藏着玩,是否推送,视你的心情而定!

 

假如多人同时更改了远程得同意文件,则你在push时可能会报错有冲突出现,解决办法也很简单,Git已经提示我们,先用git pull把最新的提交从origin/dev抓下来,然后,在本地合并,解决冲突,再推送。

 

抓取分支

git clone git@github.com:michaelliao/learngit.git 其他人可以将你得远程仓库克隆到他得本地目录下,

但是默认情况下,你的小伙伴只能看到本地的master分支。如果,你的小伙伴要在dev分支上开发,就必须创建远程origin的dev分支到本地,于是他用这个命令创建本地dev分支:git checkout -b dev origin/dev                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 

在本地已经有dev分支时直接这样使用会报错,所以要使用:

git branch --set-upstream-to=origin/dev dev

指定本地dev分支与远程origin/dev分支的链接。

 

多人协作的工作模式:

 

1.首先,可以试图用git push origin <branch-name>推送自己的修改;

 

2.如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并;

 

3.如果合并有冲突,则解决冲突,并在本地提交;

 

没有冲突或者解决掉冲突后,再用git push origin <branch-name>推送就能成功!

 

如果git pull提示no tracking information,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream-to <branch-name> origin/<branch-name>。

 

这就是多人协作的工作模式,一旦熟悉了,就非常简单。

 

分支:

1.HEAD指向的就是当前分支,工作区的修改和提交也是根据HEAD来的,即是针对当前分支进行的

2.当我们创建新的分支,例如dev时,Git新建了一个指针叫dev,指向master相同的提交,再把HEAD指向dev,就表示当前分支在dev上:

3.分支合并

(1)(Fast forward)直接合并时,就是普通的指针操作,将master指向合并过来的分支(例如取名dev)就可以,这样就只剩下一条master分支,这个时候删除dev分支就只是删除一个指针而已。

在一个分支(dev)修改提交之后切换到另一个分支(master)是看不见在dev中的修改和操作的,但是如果在dev中的修改和操作只是add而没有commit在master分支中确实可以看见未commit的操作内容和状态的。

(2)存在冲突时合并:

a.需要手动修改使得两个分支的内容一致(即以手动修改源文件的方式消除冲突)

 

 

4.命令

git checkout -b dev    创建dev分支,然后切换到dev分支

相当于以下两条命令:

git branch dev       创建dev分支

git checkout dev     切换到dev分支

git branch     查看当前分支

git merge dev   在处于主分支master时使用,把dev分支的工作成果合并到master分支上

git merge --no-ff -m "merge with no-ff" dev   --no-ff参数,表示禁用Fast forward,加上-m参数,是因为本次合并要创建一个新的commit,把commit描述写进去

git branch -d dev   删除dev分支

git log --graph --pretty=oneline --abbrev-commit   查看分支的合并情况

 

bug分支

git stash  在当前的工作分支(dev)上还有很多没有提交的时候,但是出现了master有bug临时需要修改之类的特殊情况,需要临时开另一条分支,git stash可以把当前(dev)工作现场“储藏”起来,然后去开辟新的修改bug分支,在合并到master之后,再恢复(dev)现场后继续工作。因为如果不进行保存,在还没有提交修改之前是不能进行分支的切换的。

 

git stash list  查看保存的stash

 

git stash apply  恢复保存的stash   git stash drop  删除保存的stash

git stash pop  恢复的同时把stash内容也删了

 

 

rebase

rebase   把分叉的提交历史“整理”成一条直线,看上去更直观。缺点是本地的分叉提交已经被修改过了。

使用rebase branch-B的效果如下,就是将branch-B真正的合并到branch-A上来,而这里的c3合并之后其实id

 

 

 

 

标签管理

git tag <name>      就可以打一个新标签, 默认标签是打在最新提交的commit上的。

 

git tag v0.9 f52c633   给id对应的commit打标签

注意,标签不是按时间顺序列出,而是按字母排序的。

git show <tagname>  查看标签信息

git tag -d v0.1        删除标签v0.1

创建的标签都只存储在本地,不会自动推送到远程。所以,打错的标签可以在本地安全删除

 

git push origin v1.0   向远程推送标签v1.0

git push origin –tags  一次性推送全部尚未推送到远程的本地标签

 

删除远程标签分两步:

  1. 先从本地删除:git tag -d v0.9
  2. 从远程删除:git push origin :refs/tags/v0.9

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

常用命令:

  1. ls  文件夹目录
  2. touch  生成文件夹
  3. vim  文件编辑器
  4. mkdir -p <文件夹名> 创建文件夹
  5. rm <文件名> 删除文件
  6. rm -r :  删除一个文件夹, r (recusive 是递归的意思), 删除用的就是递归,先删除文件夹里面的内容,再删除文件夹。
  7. mv 移动文件, mv index.html  src   index.html 是我们要移动的文件, src 是目标文件夹,当然, 这样写,必须保证文件和目标文件夹在同一目录下
  8. reset 清屏,把git bash命令窗口中的所有内容清空。
  9. exit 可以直接退出窗口,就不会再鼠标按窗口上的

 

。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。

教训:

千万不要使用Windows自带的记事本编辑任何文本文件。原因是Microsoft开发记事本的团队使用了一个非常弱智的行为来保存UTF-8编码的文件,他们自作聪明地在每个文件开头添加了0xefbbbf(十六进制)的字符。

操作中发现的错误和问题:

git pull

fatal:refuse to merge unrelated histories

远程库和本地库有着不同的提交历史,使用 --allow-unrelated-histories 加在命令后面即可,不过要强制写readme文档进行log记录

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值