Git入门教程(只需记住三个单词)

Git入门教程

教程视频

git的最主要的作用

  1. 版本控制

  2. 协助开发

一.版本控制分类

Git入门教程(只需记住三个单词)_第1张图片

1.本地版本控制

Git入门教程(只需记住三个单词)_第2张图片

 2.集中版本控制

Git入门教程(只需记住三个单词)_第3张图片

 所有的版本数据都存在服务器上,用户的本地只有自己以前所同步的版本,如果不连网的话,用户就看不到历史版本,也无法切换版本验证问题 ,或在不同分支工作。而且,所有数据都保存在单一的服务器上,有很大的风险这个服务器会损坏,这样就会丢失所有的数据,当然可以定期备份。代表产品:SVN,CVS,VSS

3.分布式版本控制

 Git入门教程(只需记住三个单词)_第4张图片

每个人都拥有全部的代码!安全隐患!
所有版本信息仓库全部同步到本地的每个用户,这样就可以在本地查看所有版本历史,可以离线在本地提交,只需在连网时push到相应的服务器或其他用户那里。由于每个用户那里保存的都是所有的版本数据,只要有一个用户的设备没有问题就可以恢复所有的数据,但这增加了本地存储空间的占用。不会因为服务器损坏或者网络问题,造成不能工作的情况!

4.与SVN最主要区别

SVN是集中式版本控制系统,版本库是集中放在中央服务器的,而工作的时候,用的都是自己的电脑,所以首先要从中央服务器得到最新的版本 ,然后工作,完成工作后,需要把自己做完的活推送到中央服务器。集中式版本控制系统是必须联网才能工作,对网络带宽要求较高。

Git是分布式版本控制系统,没有中央服务器,每个人的电脑就是一个完整的版本库,工作的时候不需要联网了,因为版本都在自己电脑上。协同的方法是这样的:比如说白己在电脑上改了文件A,其他人也在电脑上改了文件A,这时,你们两之间只需把各自的修改推送给对方,就可以互相看到对方的修改了。Git可以直接看到更新了哪些代码和文件!

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

二.Git基本配置

1.下载时的三个版本

Git 安装配置 | 菜鸟教程 (runoob.com)

Git入门教程(只需记住三个单词)_第5张图片

 2.查看配置信息

使用bash查看

git config -l #显示全部配置
git config --system --list #显示系统配置
git config --global --list #显示用户配置

使用GUI查看,这是在我的目录底下,你们去自己配置的目录底下找,搜索gitconfig
Git入门教程(只需记住三个单词)_第6张图片

 3.配置用户

git config --global user.name "galen"   #配置用户名
git config --global user.email [email protected] #配置邮箱

配置完成后使用上面的显示用户配置,看是否配置成功 

 三.Git理论

1.工作区域

基本概念:Git入门教程(只需记住三个单词)_第7张图片Git入门教程(只需记住三个单词)_第8张图片

 仓库区是有分支的一般不使用主分支,会创建其他分支,我们下面还会再讲Git入门教程(只需记住三个单词)_第9张图片

2.工作流程 

 一般是这样的:

1、在工作目录中添加、修改文件;

2、将需要进行版本管理的文件放入暂存区域;

3、将暂存区域的文件提交到git仓库。

因此,git管理的文件有三种状态:已修改(modified),已暂存(staged),已提交(committed)Git入门教程(只需记住三个单词)_第10张图片

四.Git的基本操作

1.创建仓库

1.六个常用单词

add,commit,push,pull,fetch/clone,checkout,前三个必须会

2.创建本地仓库的方法有两种:

  • 创建新的仓库

  • 克隆远程仓库

(1).创建新的仓库

# 使用当前目录作为 Git 仓库,我们只需使它初始化。
git init

该命令执行完后会在当前目录生成一个 .git 目录,注意要在你选择的目录底下打开git,创建仓库;

(2).克隆远程仓库项目,相当于SVN导出项目

git clone  
# 表示项目链接

 练习:可以自己上去 gitee 或者 github 上下载一个项目下来。

2.基本命令

 1.了解文件四种状态(知道就行)Git入门教程(只需记住三个单词)_第11张图片

 2.查看文件状态

git status 

  没有文件被跟踪Git入门教程(只需记住三个单词)_第12张图片

 有一个文件没有被跟踪Git入门教程(只需记住三个单词)_第13张图片

文件以进入暂存区,以被跟踪  

git add .
#使用此命令添加文件进入暂存区,使文件被告知

Git入门教程(只需记住三个单词)_第14张图片

3.提交的本地仓库

git commit -m "提交信息"

Git入门教程(只需记住三个单词)_第15张图片

如果是这样,表示提交成功; 

4.提交时忽略文件

有些时候我们不想把某些文件纳入版本控制中,比如数据库文件,临时文件等:

规则如下:

  1. 忽略文件中的空行或以井号(#)开始的行将会被忽略。

  2. 可以使用Linux通配符。例如:星号(*)代表任意多个字符,问号(?)代表一个字符,方括号 ([abc])代表可选字符范围,大括号({string1,string2,…})代表可选的字符串等。

  3. 如果名称的最前面有一个感叹号(!),表示例外规则,将不被忽略。

  4. 如果名称的最前面是一个路径分隔符(/),表示要忽略的文件在此目录下,而子目录中的文件不 忽略。

  5. 如果名称的最后面是一个路径分隔符(/),表示要忽略的是此目录下该名称的子目录,而非文件 (默认文件或目录都忽略)。

    ​
    #为注释
    *.txt      #忽略所有 .txt结尾的文件
    !lib.txt   #但lib.txt除外
    /temp      #仅忽略项目根目录下的TODO文件,不包括其它目录temp
    build/     #忽略build/目录下的所有文件
    doc/*.txt  #会忽略 doc/notes.txt 但不包括 doc/server/arch.txt
    
    ​

  五.链接代码托管平台(如.码云,GitHub)

1.首先需要生成公钥

ssh-keygen -t rsa

回车默认 

Git入门教程(只需记住三个单词)_第16张图片

产生两个文件 ,第一个是私钥,第二个是公钥Git入门教程(只需记住三个单词)_第17张图片

 把第二个文件中的内容粘贴的代码托管平台ssh公钥中

 Git入门教程(只需记住三个单词)_第18张图片

 2.链接代码托管平台

使用克隆远程仓库的命令Git入门教程(只需记住三个单词)_第19张图片

有验证,全部yes Git入门教程(只需记住三个单词)_第20张图片

 链接成功

六.与编译器链接 (如.idea)

把项目创建到git的目录中,并把库目录中的文件全部拷贝到项目文件中Git入门教程(只需记住三个单词)_第21张图片Git入门教程(只需记住三个单词)_第22张图片

 注意观察idea的变化Git入门教程(只需记住三个单词)_第23张图片

链接成功,显示了记录时间Git入门教程(只需记住三个单词)_第24张图片

 接下来配置忽略文件.gitignore,有一些编译器已经添加好了,下面的只需要粘贴复制

*.class
*.log
*.lock

# Package Files #
*.jar
*.war
*.ear
target/

# idea
.idea
*.iml

*velocity.log*

### IntelliJ IDEA ###
*.ipt
*.iws

tmp/

#trbrl
*trbel.xml*

 添加进缓存区

Git入门教程(只需记住三个单词)_第25张图片

 添加进本地仓库

Git入门教程(只需记住三个单词)_第26张图片

 添加进远程仓库Git入门教程(只需记住三个单词)_第27张图片

如果代码不小心被你删除可以用,恢复最近的一次提交

git checkout HEAD name 
# name表示文件名

七.GIT分支(协助开发)

可以理解多线程:主线程在走,不影响子影响。

它们是平行,互不影响。

但是,他们可以进行合并。

在合并的时候就需要做一些处理了Git入门教程(只需记住三个单词)_第28张图片

我这个仓库只有一个主分支 

Git入门教程(只需记住三个单词)_第29张图片

 他这个仓库有四个分支,主分支,一到三代版本分支Git入门教程(只需记住三个单词)_第30张图片

关于分支的代码 

# 列出所有本地分支
git branch
# 列出所有远程分支
git branch -r
# 新建一个分支,但依然停留在当前分支
git branch [branch-name]
# 新建一个分支,并切换到该分支
git checkout -b [branch]
# 合并指定分支到当前分支
$ git merge [branch]
# 删除分支
$ git branch -d [branch-name]
# 删除远程分支
$ git push origin --delete [branch-name]
$ git branch -dr [remote/branch]

Git入门教程(只需记住三个单词)_第31张图片

八.Git命令大全与它的故事

Git 大全 - Gitee.com

提交第一行代码 - Gitee.com


深入 git 必看:git 是如何被创造的?讲述 git 的诞生史、核心思想及其父:Linus Torvalds - 简书 (jianshu.com)

你可能感兴趣的:(Linux与Git入门教程,git)