Git学习

初始Git(学习自廖雪峰老师的Git教程)

1、Git是什么?
Git是一个用C语言写的目前世界上最先进的分布式版本控制系统(没有之一)。

2、Git有什么特点?
简单来说就是:高端大气上档次!

3、集中式版本和分布式版本的区别
集中式版本控制系统:版本库是集中存放在中央服务器的,而工作的时候,用的都是自己的电脑,所以要先从中央服务器取得最新的版本,然后开始工作,工作完了,再把自己的活推送给中央服务器。中央服务器就好比是一个图书馆,你要改一本书,必须先从图书馆借出来,然后回到家自己改,改完了,再放回图书馆。集中式版本控制系统最大的毛病就是必须联网才能工作,如果在局域网内还好,带宽够大,速度够快,可如果在互联网上,遇到网速慢的话,可能提交一个10M的文件就需要5分钟。
分布式版本控制系统:根本没有“中央服务器”,每个人的电脑上都是一个完整的版本库,这样,你工作的时候,就不需要联网了,因为版本库就在你自己的电脑上。既然每个人电脑上都有一个完整的版本库,那多个人如何协作呢?比方说你在自己电脑上改了文件A,你的同事也在他的电脑上改了文件A,这时,你们俩之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。
区别:
和集中式版本控制系统相比,分布式版本控制系统的安全性要高很多,因为每个人电脑里都有完整的版本库,某一个人的电脑坏掉了不要紧,随便从其他人那里复制一个就可以了。而集中式版本控制系统的中央服务器要是出了问题,所有人都没法干活了。
注意:在实际使用分布式版本控制系统的时候,其实很少在两人之间的电脑上推送版本库的修改,因为可能你们俩不在一个局域网内,两台电脑互相访问不了,也可能今天你的同事病了,他的电脑压根没有开机。因此,分布式版本控制系统通常也有一台充当“中央服务器”的电脑,但这个服务器的作用仅仅是用来方便“交换”大家的修改,没有它大家也一样干活,只是交换修改不方便而已。

Git的安装教程
https://www.liaoxuefeng.com/wiki/896043488029600/896067074338496

创建版本库
https://www.liaoxuefeng.com/wiki/896043488029600/896827951938304

mkdir learngit//创建一个文件夹
cd learngit//进入文件目录
pwd//显示当前路径
git init//创建一个Git版本库 
ls -ah //查看目录(-ah要连起来写)

把文件添加进版本库
所有的版本控制系统,其实只能跟踪文本文件的改动,比如TXT文件,网页,所有的程序代码等等,Git也不例外。版本控制系统可以告诉你每次的改动,比如在第5行加了一个单词“Linux”,在第8行删了一个单词“Windows”。而图片、视频这些二进制文件,虽然也能由版本控制系统管理,但没法跟踪文件的变化,只能把二进制文件每次改动串起来,也就是只知道图片从100KB改成了120KB,但到底改了啥,版本控制系统不知道,也没法知道。
不幸的是,Microsoft的Word格式是二进制格式,因此,版本控制系统是没法跟踪Word文件的改动的, 如果要真正使用版本控制系统,就要以纯文本方式编写文件。

千万不要使用Windows自带的记事本编辑任何文本文件。
原因是Microsoft开发记事本的团队使用了一个非常弱智的行为来保存UTF-8编码的文件,他们自作聪明地在每个文件开头添加了0xefbbbf(十六进制)的字符,你会遇到很多不可思议的问题,比如,网页第一行可能会显示一个“?”,明明正确的程序一编译就报语法错误,等等,都是由记事本的弱智行为带来的。

添加文件到仓库

git add readme.txt  //1.添加readme.txt文件到git仓库git add file2.txt file3.txt
git commit -m "text" //2.提交
vi readme.txt //编辑readme.txt i插入,Esc退出插入 :wq保存退出 :w保存 :q退出

版本回退

git log //查看历史记录
git log --pretty=oneline//精简历史记录信息
git reset --hard HEAD^ //回退到上个版本
git reset --hard HEAD~1 //回退到上个版本
git reset --hard 1094a //回退到版本号那个位置
cat readme.txt //读取文件内容
git reflog  //记录你的每一次命令:

首先,Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,上一个版本就是HEAD^ , 上上一个版本就是HEAD^ ^ ,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100
办法其实还是有的,只要上面的命令行窗口还没有被关掉,你就可以顺着往上找啊找啊,找到那个commit id,就可以指定回到某个版本:

git status //查看工作区状态
git diff HEAD -- readme.txt  //查看工作区和版本库的差别
git checkout -- readme.txt//丢弃对工作区的修改
git reset HEAD readme.txt//将暂存区的修改写回工作区
//注意:将暂存区回退工作区后也要丢弃对工作区的修改

删除文件

rm readme.txt	//删除工作区文件
git  checkout  -- readme.txt//撤销工作区删除
git rm readme.txt //删除版本库的文件

远程仓库
第1步:创建SSH Key。在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有id_rsa和id_rsa.pub这两个文件,如果已经有了,可直接跳到下一步。如果没有,打开Shell(Windows下打开Git Bash),创建SSH Key:

ssh-keygen -t  rsa  -C  "dongyuning@jd.com"

第2步:登陆GitHub,打开“Account settings”,“SSH Keys”页面:
然后,点“Add SSH Key”,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容:
点“Add Key”,你就应该看到已经添加的Key:

本地仓库关联GitHub

git remote add origin git@github.com:SWDYN/GitTest.git 
//添加后,远程库的名字就是origin,这是Git默认的叫法,也可以改成别的,但是origin这个名字一看就知道是远程库

把本地库的所有内容推送到远程库上

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

克隆一个本地库

git clone (git@github.com:SWDYN/GitTest.git)->链接

创建分支并切换到分支

git switch-c dev  //创建分支并切换到这个分支
git switch dev //直接切换到dev
git branch //查看当前分支 

合并分支到master上

git merge dev 

刪除dev分支

git branch -d dev

Bug分支
当你接到一个修复一个代号101的bug的任务时,很自然地,你想创建一个分支issue-101来修复它,但是当前正在dev上进行的工作还没有提交;并不是你不想提交,而是工作只进行到一半,还没法提交,预计完成还需1天时间。但是,必须在两个小时内修复该bug,怎么办?

幸好,Git还提供了一个stash功能,可以把当前工作现场“储藏”起来,等以后恢复现场后继续工作:

git stash  //储藏当前工作现场
git stash pop//恢复工作现场
git stash apply //恢复工作现场,恢复后,stash内容并不删除,你需要用git stash drop来删除

解决分支历史遗留Bug问题

git cherry-pick 4c805e2//复制一个特定的提交(解决Bug的分支)到当前分支(需要更新的分支)

Feature分支----用于解决主次问题

git checkout -b feature-vulcan//创建分支并切换
git branch -D feature-vulcan //强行删除

多人协作

git remote //要查看远程库的信息
git remote  -v //查看更详细的远程库信息
git push orign dev //推送dev 到远程仓库orign
git checkout -b dev origin/dev //创建本地dev分支
git  pull //把最新的提交抓下来
git rebase //将提交历史变成一条直线 ,缺点是修改了本地的分叉提交

创建标签

git tag v1.0
git tag //查看所有标签
git tag v0.9 f52c633//为f52c633指定标签
git tag -d  v1.0
git push origin v1.0 //推送标签
git push origin --tags //推送所有未推送的标签
git push origin :refs/tags/v1.0//删除远程标签
git config --global color.ui true //更改颜色
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值