.pub是什么文件_一篇文章看懂Git是什么以及如何简单的上手Git

b413190adb09b8bf469b2741731fee7e.png

本文来自DotNET技术圈

作者:显杰

1.Git是什么

Git是目前世界上==最先进的分布式版本控制系统==

什么是版本控制系统?

好比设计师从开始设计第一个版本的设计稿开始:

Demo => Demo1 => Demo2 => ... =>Demo1001 => Demo最终版本 => Demo最终确认版本!

但是改了这多设计师也不记得每个版本之间都改了些啥

如果能有一个软件,能每次记录文件之间的改动,并且还能协调多个用户编辑,所以就出现了Git

==Git是分布式版本控制系统,那么他们就没有中央服务器的,每个人的电脑就是一个完整的版本库==,这样,工作的时候就不需要联网了,因此版本都是在自己的电脑上,既然每个人的电脑都有一个完整的版本库,那么多个人如何协作呢,比如自己在电脑上,更改了文件A,其他人也在电脑上改了文件A,这时候,你们两之间只需要把各自的修改推送给对方,就可以互相看到对方的修改了


2.Git与Github的区别

==Git简单的说其实就是一个软件==,用于记录一个或若干个文件内变化,以便将来查询特定版本修订情况的软件

==Github(https://www.github.com)是一个为用户提供Git服务的网站==,就是一个可以存放代码的地方,当然可以放的不只是代码,Github除了提供管理Git的web界面外,还提供了订阅,关注,讨论组,在线编辑器等丰厚的功能

3.Git的安装

75350d63931284cb2038caa60c11398a.png
在这里插入图片描述

4.Git的使用

1. 本地仓库:

1.1 工作流程

7b0cd679b3f5e4c357c8745d2a29917a.png
在这里插入图片描述
d5b7ab8239ee7329f22cb046b7d2104b.png
在这里插入图片描述

工作区写好的文件通过工作区转移到暂存区(相当于背包)如何一次性把暂存区的文件转移到Git仓库,为什么要有一个暂存区呢,因为不可能工作区的文件一次次的从工作区把文件直接运到Git仓库,而因该一次性全部运过去,减少了消耗嘛


1.1.2 本地仓库操作 什么是仓库呢?仓库有名版本库,英文名是Repository,我们可以简单理解成是一个目录,用于存放代码的,这个目录里面的所有文件都可以被Git管理起来,每个文件的修改,删除等操作Git都等跟踪到。安装好后,首次使用需要先进行全局配置桌面空白地方右键,点击“Git Bash Here” 打开Git命令行窗口
==Git config -global user.name "用户名" Git config -global user.email "邮箱"==

7cf7f1e4b4fcd11f2ebb0ec8ca715cf0.png
在这里插入图片描述

当我们需要Git去管理某个新项目/已经存在项目的时候,就需要创建仓库了,注意:创建仓库的时候使用的目录不一定要求是空目录,选择一个非空目录也是可以的。A.创建空目录

mkdir 文件名

B.在命令行中进入项目目录

cd 文件路径/文件名称

C git文件夹初始化到选中的文件夹中

git init
ec1fbcd3d12b755815aa477d9df297dd.png
在这里插入图片描述

D Git常用指令操作

查看当前状态:git status [非必要] 添加到缓存区:git add 文件名
    说明:git add指令,可以添加一个文件,也可以同时添加多个文件。     语法1:git add 文件名    语法2:git add 文件名1 文件名2 文件名3 …    语法3:git add . [添加当前目录到缓存区中]    提交至版本库:git commit -m "注释内容"    在后续对于文件(可以操作1个或多个)操作之后,重复使用 git add与git commit指令即可

1.版本回退 版本回退分为两步骤进行操作:

查看版本,确定需要返回的时刻点: 指令: Git log 和 Git log --pretty=oneline

效果如下

a2cf1f4799d7eeb8fb95d67fc6120ae1.png
在这里插入图片描述

)

d0677bd8bce055f9cbc67d36a18cf102.png
在这里插入图片描述
回退操作指令: Git reset --hard 版本号

如果,回到过去之后,要想再回来到之前最新的版本的时候,这需要使用指令,得到最新的commit id。指令:

get reflog
3465dad202e92df47549be186d1ebf2a.png
在这里插入图片描述
**小结:**
        i. 想要回到过去,必须先得到 commit id,然后通过 git reset -hard 进行回退         ii. 想要回到未来,需要先使用 git reflog 查看历史记录,得到最新的commit id;        iii.在写回退指令的时候 commit id可以不用写全,git自动识别,但是也不能写太少,至少需要写前4位字符

1.远程操作Github 3.1. 两种常规使用方式 ==基于http协议==1.创建空的目录Stop2.使用clone指令克隆线上仓库到本地 语法:git clone

9bfbc8be1a84346503de9a0e87de6883.png
在这里插入图片描述
5df329fefb7763a81ff6eff4ef2a9a4b.png
在这里插入图片描述

3..在仓库上做对应的操作(提交暂存区,提交本地仓库,提交线上仓库,拉取线上仓库) 提交到线上仓库指令:

git push
e1135a62b8b5969182bcd44b6795cc92.png
在这里插入图片描述

在首次往线上仓库shop提交内容的时候出现了403的致命错误,原因是因为不是任何人都可以往我这儿线上仓库提交内容,必须需要鉴权需要在.git 里面 config里面进行修改

b8431999cee9be8ef85ebc851b317386.png
在这里插入图片描述

格式为:账号:密码@。如果看到如下则成功,可以看到github中文件已经增加

4a4175cb6cc8e033097339637c5e9c93.png
在这里插入图片描述

拉取线上仓库指令:

git pull
f4e1e95526d2ddef5867b365995a19b9.png
在这里插入图片描述
35b5201b1b83bf81565790b1b904d2ae.png
在这里插入图片描述

提醒: 在每天工作的第一件事就是先 git pull 拉取线上最新的版本,每天下班前要做的是 git push 将本地代码提交到线上仓库中


==基于ssh协议== 该方式与前面的https方式相比,只是影响github对于用户的身份鉴权方式,对于git的具体操作(如提交本地,添加注释,提交远程等操作)没有任何影响。

 1. 生成公私钥对指令(需先自行安装OpenSSH)     ssh-keygen -t rsa -C "注册邮箱"     ![在这里插入图片描述](https://img-blog.csdnimg.cn/20191128131801924.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQyMjUxNTk2,size_16,color_FFFFFF,t_70) 2. 上传公钥文件内容(id_rsa.pub) ![在这里插入图片描述](https://img-blog.csdnimg.cn/20191128131841658.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3FxXzQyMjUxNTk2,size_16,color_FFFFFF,t_70) 3. 继续克隆,完成http一样的操作 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20191128131926803.png)
52b1d1da04813efb601883e093718916.png
在这里插入图片描述

1.分支管理 什么是分支?

a382c1c7bf00f3abcdead9d11e4fa8ae.png
在这里插入图片描述

在版本回退的时候,每次提交后都会有记录,Git把他们串成时间线,形成类似于时间轴的东西,这个时间轴就是一个分支,我们称之为==master分支(主分支)==分支相关指令:==1.查看分支:git branch==

![在这里插入图片描述](https://img-blog.csdnimg.cn/20191128132210631.png)

==2.创造分支:git branch 分支名==

![在这里插入图片描述](https://img-blog.csdnimg.cn/20191128132336987.png)

==3.切换分支:git checkout 分支名==

![在这里插入图片描述](https://img-blog.csdnimg.cn/20191128132414201.png) ![在这里插入图片描述](https://img-blog.csdnimg.cn/2019112813242214.png) ![在这里插入图片描述](https://img-blog.csdnimg.cn/20191128132430693.png)

当我切换到master的时候

e641ed9477f8373e941b8d54cdc8d48a.png
在这里插入图片描述
![在这里插入图片描述](https://img-blog.csdnimg.cn/20191128132454956.png)

发现并没有修改对于新分支可以使用==git checkout -b 分支名== 指令来切换分支 -b 表示创建并切换,相当于2个操作==4.分支并和指令 git merge 分支名==

![在这里插入图片描述](https://imgconvert.csdnimg.cn/aHR0cHM6Ly9pbWctYmxvZy5jc2RuaW1nLmNuLzIwMTkxMTI4MTMyNzQzOTYxLnBuZw?x-oss-process=image/format,png)

当我合并dev的时候 ,发现文件就进行整合,已经有修改后的一行。

22ab784b4e32b157d716bdaca7de5e79.png
在这里插入图片描述

== 5. 删除分支 git branch -d 分支名== 删除分支之前,先要退出到要删除的分支(不然删除不掉的)

6e083eb54d4d7bbdf036204f8856d3b0.png
在这里插入图片描述

2.冲突的产生于解决 比如,我下班后已经push代码到线上,走了,而我之后,有同事A在线上修改了代码,多加了一行

39d5d369b04e889f29b15e0822b10d7f.png
在这里插入图片描述

但是第二天,上班我本机代码,并不会显示同事修改的,但是我又在本机增加了一行。

![在这里插入图片描述](https://img-blog.csdnimg.cn/20191128133300503.png)

当我第二天下班后,准备将我写的代码去push后,就会发现。

f66ffe45fef8fe66be1064d48ed4ee9a.png
在这里插入图片描述
c67b5f3ea2fe0b8553e6a042f07d97c8.png
在这里插入图片描述

就会提示我,先要我pull一下,得到数据再提交。==【冲突解决的办法】==先git pull

e82e8f48709a1ce3035b49cf2c122f22.png
在这里插入图片描述
ef8b0ff57b7d1650d62fd6b04e323bff.png
在这里插入图片描述

打开冲突文件,解决冲突 解决方法:需要和同事(谁先提交的)进行商量,看代码如何保留,将改好的文件再次提交即可

7b62525d971ddfb3a63883ba47506c5c.png
在这里插入图片描述

5.忽略文件

场景:在项目目录下有很多万年不变的文件目录,例如Css,js,images等,或者还有以谢目录即使有变动,我们也不想让其提交到远程仓库的文档,此时我们可以使用“忽略文件”机制来实现

忽略文件需要新建一个==名为.gitignore的文件==,该文件用于申明忽略文件或不忽略文件的规则,规则对当前目录及其子目录生效。

注意:该文件因为没有文件名,没办法直接在windows目录下直接创建,可以通过命令行GitBash来==touch XXX== 创建

55109307431c1def8d8d47c42a7094fc.png
在这里插入图片描述

常见规则写法有如下几种:| 规则写法 | 效果 | ---- | ---- | | /mtk | 过滤整个文件夹 | | *.zip | 过滤所有.zip文件 | | /mtk/do.c | 过滤某个具体文件 | | !index.phx | 不过滤具体某个文件 |

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值