Git
发表于:2023-09-28 | 分类: 工具
字数统计: 4.8k | 阅读时长: 18分钟 | 阅读量:

1. Git 概述

Git 是一个免费的、开源的分布式版本控制系统,可以快速高效地处理从小型到大型的各种项目。

Git 易于学习,占地面积小,性能极快。 它具有廉价的本地库,方便的暂存区域和多个工作流分支等特性。其性能优于 Subversion、CVS、Perforce 和 ClearCase 等版本控制工具。

版本控制工具

集中式版本控制工具

CVS、SVN(Subversion)、VSS……

集中化的版本控制系统都有一个单一的集中管理的服务器,保存所有文件的修订版本,而协同工作的人们都通过客户端连到这台服务器,取出最新的文件或者提交更新。多年以来,这已成为版本控制系统的标准做法。

好处:每个人都可以在一定程度上看到项目中的其他人正在做些什么。而管理员也可以轻松掌控每个开发者的权限,并且管理一个集中化的版本控制系统,要远比在各个客户端上维护本地数据库来得轻松容易。

缺点:中央服务器的单点故障。如果服务器宕机一小时,那么在这一小时内,谁都无法提交更新,也就无法协同工作。

分布式版本控制工具

Git、Mercurial、Bazaar、Darcs……

分布式版本控制工具,客户端提取的不是最新版本的文件快照,而是把代码仓库完整地镜像下来(本地库)。这样任何一处协同工作用的文件发生故障,事后都可以用其他客户端的本地仓库进行恢复。因为每个客户端的每一次文件提取操作,实际上都是一次对整个文件仓库的完整备份。

解决了集中式版本控制系统的缺陷:

  1. 服务器断网的情况下也可以进行开发(因为版本控制是在本地进行的)
  2. 每个客户端保存的也都是整个完整的项目(包含历史记录,更加安全)

Git 和代码托管中心

代码托管中心是基于网络服务器的远程代码仓库,一般我们简单称为远程库。

局域网:GitLab

互联网 :GitHub(外网);Gitee 码云(国内网站)

Git 的安装

官网:Git (git-scm.com)

由于官网下载过慢且需要授权,我们可以使用淘宝npm的镜像地址:

CNPM Binaries Mirror (npmmirror.com)

Git 的安装只需要改一下安装路径,再如下图改一下环境配置信息,其它直接默认下一步即可。

bf7f1a21ba58b5314fc3abbe91efea26.png

桌面右键,选择 Git Bash Here 即可打开 Git Bash 命令行终端,在 Git Bash 终端里输入 git –version 查看 git 版本,说明 Git 安装成功。

2. 常用命令

命令名称 作用
git config –global user.name 用户名 设置用户签名
git config –global user.email 邮箱 设置用户签名
git init 初始化本地库
git status 查看本地库状态
git add 文件名 添加到暂存区
git commit -m “日志信息” 文件名 提交到本地库
git reflog 查看历史记录
git reset –hard 版本号 版本穿梭
git clone -b 分支名 地址 拉取指定分支代码

签名的作用是区分不同操作者身份。用户的签名信息在每一个版本的提交信息中能够看到,以此确认本次提交是谁做的。Git 首次安装必须设置一下用户签名,否则无法提交代码。

可以在当前用户目录的 .gitconfig 文件查看用户签名

这里设置用户签名和将来登录 GitHub(或其他代码托管中心)的账号没有任何关系。

Git 中的命令和 Linux 中的命令是通用的

系统 描述 名称 转义符
Windows 回车换行 CRLF \n\r
Linux 换行 LF \n

初始化本地库:

314015570847c684f63b39b49f3ef8e4.png

初始化本地库后,会在库目录创建 .git 的隐藏文件

查看本地库状态:

9f49ad434e470961afabc7741b7d6f74.png

添加文件后查看会提示检测到未追踪的文件,红色标注

添加暂存区:

4ebe9f579442ac5da439a35c3cf37a34.png

添加到暂存区后会以绿色标注;提示的代码是将暂存区的文件删除,对原文件没有影响。

可使用git ls-files查看暂存区的文件

提交到本地库:

7bf1ac047228ddb506523ab10c03b0a3.png

修改文件后查看状态:

39177e211be0113323f36fe7fc224dd0.png

git restore <file> 是恢复文件,放弃修改

历史版本:

查看历史版本:

1
2
git reflog 查看版本信息
git log 查看版本详细信息

0743fdd21a905b95725facddd87a19e2.png

版本穿梭:

1
git reset --hard 版本号

d24632d46aabb39f43ea7790de198368.png

Git 切换版本,底层其实是移动的 master 指针。

此时本地库的文件也切换成了第一版

3. Git分支操作

7b6fd9fab71d733f9d6149aba4b2d84e.png

分支:在版本控制过程中,同时推进多个任务,为每个任务,我们就可以创建每个任务的单独分支。使用分支意味着程序员可以把自己的工作从开发主线上分离开来,开发自己分支的时候,不会影响主线分支的运行。

优点:同时并行推进多个功能开发,提高开发效率。各个分支在开发过程中,如果某一个分支开发失败,不会对其他分支有任何影响。失败的分支删除重新开始即可。

命令名称 作用
git branch 分支名 创建分支
git branch -v 查看分支
git checkout 分支名 切换分支
git merge 分支名 把指定的分支合并到当前分支上
git branch -d 分支名 删除本地分支(不会影响远程仓库中的任何分支)

创建分支

a3a0b22a9428cf541f047edf7fd63d3b.png

创建的分支会将主分支master的内容复制一份

切换分支

816f9c441c41ca980bcf9420e3b88571.png

在master分支中修改文件并提交不会影响hot-fix分支的内容

合并分支

正常情况:

30c6677610fa6055b9b13a7853ef6663.png

合并冲突:

149832814173dded306c3270ee1967db.png
5eab95fcad7c33d2b9c8897d105bf6cd.png

此时需要我们使用vim手动打开文件进行合并;其中 <<…== 部分是当前分支提交保存的内容;==..>> 是 hot-fix 分支中提交保存的内容;

f0f01aa9365d25da1bf7ea0626d046fa.png

修改完后提交即可完成代码合并

注意:解决代码冲突时提交文件不能带文件名

分支的底层解释:master、hot-fix 都是指向具体版本记录的指针。当前所在的分支由 HEAD 决定。所以创建分支的本质就是多创建一个指针。 HEAD 如果指向 master,那么我们现在就在 master 分支上。 切换分支的本质就是移动 HEAD 指针。

Git 团队协作机制

团队内协作:

d800717a8fd6646fbe76a900ada76d3f.png

跨团队协作:

33c8072bcaf35e336ebb12e034f28465.png

4. GitHub 操作

GitHub: Let’s build from here · GitHub

创建远程仓库

19c000f352889834b8a98f40ad990ff8.png

点击加号中的 New repository

3c150df75ceb0cea184dcbac5b12fef2.png

输入仓库名后即可创建

e7d3abff4804311ac287c486a958a62d.png

远程仓库的地址以及连接协议

操作命令

命令名称 作用
git remote -v 查看当前所有远程地址别名
git remote add 别名 远程地址 起别名
git remote rm 别名 删除别名
git push 别名 分支 推送本地分支上的内容到远程仓库
git clone 远程地址 将远程仓库的内容克隆到本地
git pull 远程库地址别名 远程分支名 将远程仓库对于分支最新内容拉下来后与当前本地分支直接合并

由于远程仓库地址不方便使用,我们可以设置别名:

a74b4b812615213c3bd8e521228deba9.png

推送本地分支内容时遇到的问题:

  1. Linux系统中ctrl+v操作会给系统中输入特殊字符^?,偏偏这样的字符在git-bash中又看不到,所以克隆错误的链接就出现了这样报错信息。
1
2
3
16958@DESKTOP-0B9HUJ1 MINGW64 /h/GitSpace (master)
$ git push GitTest master
fatal: protocol '–https' is not supported

解决方案:删除别名重新设置

  1. 由于没有配置信任的服务器HTTPS验证。默认cURL(一个网络数据传输项目,通常说 cURL 是指 curl 命令行工具)被设为不信任任何CAs,就是说,它不信任任何服务器验证。
1
2
3
16958@DESKTOP-0B9HUJ1 MINGW64 /h/GitSpace (master)
$ git push GitTest master
fatal: unable to access 'https://github.com/LeamonPuer/GitTest.git/': SSL certificate problem: unable to get local issuer certificate

解决方案:

1
git config --global http.sslverify false 

连接远程库会在计算机建立凭据,可以在win10中的凭据管理器中查看

克隆远程仓库到本地

在新文件夹中克隆仓库到本地;clone会做三个操作:

  1. 拉取代码
  2. 初始化本地仓库
  3. 创建别名:origin

邀请加入团队

点击 Settings 进入此页面:

983e9b633fc3a3e7c4c16a0f6ac4aa04.png

点击 Add people:

f4c806533887874cd508dd14b1bbd0d9.png

在搜索栏搜索用户发送邀请即可(也可以通过其它社交软件发送邀请连接)

跨团队协作

将远程仓库的地址复制发给邀请跨团队协作的人,在地址栏输入收到链接后点fork可以叉到自己的本地仓库,修改完成后可以点击 Pull requests请求发送给原团队(对方会审核你修改的代码,可以通过聊天室沟通信息)

b2fac4eb15c81e29d7d170fe7ab3567a.png

fd50a3d4ee15faa9e3b89544ce95e73c.png

SSH免密登录:

我们可以看到远程仓库中还有一个 SSH 的地址,因此我们也可以使用 SSH 进行访问。

83dcf22e32192a67f34a90f44326bd03.png

操作:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
--进入当前用户的家目录
16958@DESKTOP-0B9HUJ1 MINGW64 ~
$ pwd
/c/Users/16958
--删除.ssh 目录
16958@DESKTOP-0B9HUJ1 MINGW64 ~
$ rm -rvf .ssh/
--运行命令生成.ssh 秘钥目录
16958@DESKTOP-0B9HUJ1 MINGW64 ~
$ ssh-keygen -t rsa -C 1695812011@qq.com
Generating public/private rsa key pair.
Enter file in which to save the key (/c/Users/16958/.ssh/id_rsa):
Created directory '/c/Users/16958/.ssh'.
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /c/Users/16958/.ssh/id_rsa
Your public key has been saved in /c/Users/16958/.ssh/id_rsa.pub
The key fingerprint is:
SHA256:TcOXbMLknWYwaeTcw9w17lsd/IiIpWlzWQDdLg7HYtk 1695812011@qq.com
The key's randomart image is:
+---[RSA 3072]----+
| .+*o ..|
| B+X.+o..|
| =@./ .+ |
| =BE@.o..+|
| .S==.. ..+|
| . o. o|
| . |
| |
| |
+----[SHA256]-----+

16958@DESKTOP-0B9HUJ1 MINGW64 ~
$ cd .ssh/

16958@DESKTOP-0B9HUJ1 MINGW64 ~/.ssh
$ ll -a
total 21
drwxr-xr-x 1 16958 197609 0 Dec 3 09:27 ./
drwxr-xr-x 1 16958 197609 0 Dec 3 09:27 ../
-rw-r--r-- 1 16958 197609 2602 Dec 3 09:27 id_rsa
-rw-r--r-- 1 16958 197609 571 Dec 3 09:27 id_rsa.pub

16958@DESKTOP-0B9HUJ1 MINGW64 ~/.ssh
$ cat id_rsa.pub
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDKMtpagypeO69I9WbYcWE/n4m7YucClMJv6uFsnBfCY5z6pzGB5F7laIGxwHbij6QE5kGA+9ApD5/2p3Rv72eKfw3xZXLL8NYqkiCyvXTQO7RfR4+Cj2G72RLUXg4WAOd+vOItjZpetL1R+0+1/X0ax3BVK86GQOsxcTAc95BUwllL63/9ttaRTjMZXlCeNdrfrUj+9Jedhnk4jFg2HOkHNljpnAvee6gqzV29hFnUgDBAM6wrf+2zIDLvzT2p3V+E+IXVLlgjNTckepSE5UUbXB5RN9woBSqv44meifwlg+GY+3XlVl8E6cFeXIJNF/IMCxCIhPzN7oCSoBf6J24FwmVT1pUxGSt2MipV8/nlD2BmueoXen9r118fYWd+R7Pt5UgzRa8gxlxmWH5o1iO1vhgLiAR9V4Cs0uuZY5BX5YiYlqop1rUc3nPRF4gmOeX2h/WVUB6dXIq5Cw6aUisbgYsgm7godTwcneazHD4EvatWTFIbhM+H5MiuVMh++PE= 1695812011@qq.com

16958@DESKTOP-0B9HUJ1 MINGW64 ~/.ssh
$

ssh-keyen 的作用是生成密匙对(公匙和密匙),-t 用来指定加密的类型,-C 后面加一段描述性字符串,网上很多人选择填邮箱,它真正的作用是让我们更好地去区分不同的密匙。

复制 id_rsa.pub 文件内容,登录 GitHub,点击用户头像→Settings→SSH and GPG keys

2b23afa652fc4428d7f9165cfe1725bb.png

接下来再往远程仓库 push 东西的时候使用 SSH 连接就不需要登录了。

6bfec57f7e36e482a9d02c3167707292.png

5. IDEA 集成 Git

配置 Git 忽略文件

像 idea 中会随工程创建的 .idea 文件以及一些 .iml 文件,与项目的实际功能无关,不参与服务器上部署运行。把它们忽略掉能够屏蔽 IDE 工具之间的差异。

创建忽略规则文件 xxxx.ignore(前缀名随便起,建议是 git.ignore)

这个文件的存放位置原则上在哪里都可以,为了便于让~/.gitconfig 文件引用,建议也放在用 户家目录下

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
# Compiled class file
*.class

# Log file
*.log

# BlueJ files
*.ctxt

# Mobile Tools for Java (J2ME)
.mtj.tmp/

# Package Files #
*.jar
*.war
*.nar
*.ear
*.zip
*.tar.gz
*.rar

# virtual machine crash logs, see http://www.java.com/en/download/help/error_hotspot.xml
hs_err_pid*
.classpath
.project
.settings
target
.idea
*.iml

在 .gitconfig 文件中引用忽略配置文件(此文件在 Windows 的家目录中)

1
2
3
4
5
6
7
8
[user]
name = Leamon
email = 1695812011@qq.com
[http]
sslverify = false
[core]
excludesfile = C:/Users/16958/git.ignore
#注意:这里要使用“正斜线(/)”,不要使用“反斜线(\)
  1. 定位Git程序

9168465921c2de450819b7f0400b9581.png

  1. 初始化本地库

a27a56778b1f7eb689139897a3050b36.png

  1. 添加到暂存区

初始化本地库后,所有的文件名称都变成了红色,需要我们添加到暂存区

c9b80dd9481e887ec9de0c57f67d2f8a.png

  1. 提交到本地库

添加到暂存区后所有的文件名称会变为绿色,提交本地库的操作也如上图;或使用更方便的窗口

bce0d8f510e2f22c2ec67800a6d764d9.png

1ae5e5dd7f28089ae662b0ea9a426cd0.png

可以填写提交版本的描述信息,提交后可能会报警告信息,提交失败

bf11dcb22f32ecaa2f6cdd0f0bfac11a.png

我们可以设置不检查代码:

24cb77427bcaa1df2bb14d6aa68eedf9.png

提交完成后,所有文件名都恢复正常颜色

可以在左下角打开 Git 窗口,切换或查看版本信息

  1. 创建分支

可以在窗口栏的 Git 中选择 Branches 或点击右下角的分支名称的 New Branch

  1. 切换分支

点击右下角的分支名称选择要切换的分支 Checkout,切换完成后右下角的分支名会改变

  1. 合并分支

点击右下角的分支名称选择要合并的分支 Merge into Current,合并到当前分支;代码冲突也都是图形化的界面,比较简单,不再演示

IDEA 集成 GitHub

设置 GitHub 账号

dd04ebed0935f89e6495f1969ead4d88.png

由于网络原因,我们一般不直接使用账号密码登录(在idea上很难登录成功),使用 Token 令牌

进入 GitHub 点击头像的 setting 进入设置界面,点击左方选项栏的最后一个选项:

88a9592a5ec755f413f89941c0b1e038.png

进入新的界面后又两种个人令牌:beta表示还在测试的功能,我们还是使用经典的个人令牌

53686259fd9dcea04d87086cca7948a6.png

创建个人令牌,是我自己的电脑,就直接设置令牌没有过期时间,权限全开

bf8a78c666e1ed2bda6847a45ba892b5.png

完成后会仅显示一次令牌,提前保存好

7a4db8b4f1dabe4df0fb3d4b19886b1a.png

在输入令牌连接时有个小插曲,弹出的证书直接 recept 即可

1
2
invalid authentication data ,software caused connetion abort;socket write error
验证数据无效,软件导致连接中断;套接字写入错误
  1. 分享工程到 GitHub:

8d4d161547bee7c816f555e1835e5b67.png

设置别名后直接提交即可,idea会帮我们创建远程库

  1. 推送本地库到远程库

由于https协议需要网络条件,我们在使用 push 时使用之前设置的 SSH 连接

bca8a3e44e6e644118d669089d67b779.png

注意:push 是将本地库代码推送到远程库,如果本地库代码跟远程库代码版本不一致,push 的操作是会被拒绝的。也就是说,要想 push 成功,一定要保证本地库的版本要比远程库的版本高!因此在动手改本地代码之前,一定要先检查下远程库跟本地代码的区别!如果本地的代码版本已经落后,切记要先 pull 拉取一下远程库的代码,将本地代码更新到最新以后,然后再修改,提交,推送!

  1. 拉取远程库到本地库

e1f8de0997149bf1393702404b8a25a0.png

翻译:将传入的更改合并到当前分支;根据传入的更改重新设置当前分支的基础

pull 和update project区别:

git pull 是 git fetch + git merge FETCH_HEAD 的缩写。

git pull就是先fetch,然后执行merge 操作,如果加—rebase参数,就是使用git rebase 代替git merge。

Idea update project 就是你可以选择到底是merge 还是 rebase 的git pull

注意:pull 是拉取远端仓库代码到本地,如果远程库代码和本地库代码不一致,会自动合并,如果自动合并失败,还会涉及到手动解决冲突的问题。

  1. 克隆远程库到本地

5cf9b0f7e95f37a8ff644c193b540eb7.png

6. 码云

众所周知,GitHub 服务器在国外,使用不是特别方便。

码云是开源中国推出的基于 Git 的代码托管服务中心,使用 方式跟 GitHub 一样,而且还是一个中文网站,如果你英文不是很好它是最好的选择。

Gitee - 基于 Git 的代码托管和研发协作平台

Gitee 支持绑定 GitHub、QQ等,由于是中文界面,就不多做介绍了

idea 集成码云

idea 默认不带码云插件,我们第一步要安装 Gitee 插件。

ec87aac1b4f8a7792a64cb1ef3e89708.png

云服务器在国内,用 HTTPS 链接即可,没必要用 SSH 免密链接。

码云提供了直接复制 GitHub 项目的功能,方便我们做项目的迁移和下载。

具体上传下载等操作没有太大区别,不再赘述

7. GitLab

GitLab 是一个使用 MIT 许可证的基于网络的 Git 仓库管理工具,具有 wiki 和 issue 跟踪功能,使用 Git 作为代码管理工具,并在此基础上搭建起来的 web 服务。

The One DevOps Platform | GitLab

官网进不去,这里直接使用清华大学开源软件镜像站 | Tsinghua Open Source Mirror

  1. 安装脚本:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
sudo rpm -ivh /mnt/hgfs/EdgeDown/git/资料/gitlab-ce-15.6.1-ce.0.el7.x86_64.rpm

sudo yum install -y curl policycoreutils-python openssh-server cronie

sudo lokkit -s http -s ssh

sudo yum install -y postfix

sudo service postfix start

sudo chkconfig postfix on

curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ce/script.rpm.sh | sudo bash

sudo EXTERNAL_URL="http://gitlab.example.com" yum -y install gitlab-ce

这里我没有远程传输文件,使用了共享文件夹,这里有个坑,Windows下文件夹命名有个空格,路径容易错,改回来

yum 安装时会检测更新,最好在镜像网站中下载最新版,否则下载巨慢,或许可以修改网络 YUM 源

如果脚本安装有问题可以先更新一下sudo工具并安装以下lokkit:

1
2
yum install sudo
yum install lokkit

安装过程中可能还有一些小问题:

1
2
3
4
5
6
7
8
9
10
Another app is currently holding the yum lock; waiting for it to exit...
另一个应用程序是:PackageKit
内存: 31 M RSS (451 MB VSZ)
已启动: Wed Aug 17 09:08:40 2022 - 00:59之前
状态:睡眠中,进程ID:2833
(可能是系统自动升级正在运行,yum在锁定状态中,要等待那个进程结束退出)
解决办法:
1.ps aux | grep yum (查询有关yum的进程进行关闭)
命令:kill -s 9 2833 pid
2.rm -f /var/run/yum.pid (强制关掉yum进程,并重新运行yum)
  1. 初始化 GitLab 服务:

安装完成后(脚本执行完毕),可以执行以下命令:

1
gitlab-ctl reconfigure

显示 gitlab Reconfigured! 表示初始化成功
(2g运行内存,4个核心,20g空间)

  1. 启动 GitLab 服务
1
gitlab-ctl start
  1. 访问 GitLab

直接在浏览器的地址栏中输入IP地址即可访问(虚拟机必须要关闭防火墙)

第一次访问需要输入账号密码,账号默认 root,密码需要在 /etc/gitlab/initial_root_password 中查看(该文件24小时后自动删除!)

1
2
3
4
5
6
7
8
[root@hadoop100 ~]# cat /etc/gitlab/initial_root_password
# WARNING: This value is valid only in the following conditions
# 1. If provided manually (either via `GITLAB_ROOT_PASSWORD` environmen, it was provided before database was seeded for the first time (usually, the fi# 2. Password hasn't been changed manually, either via UI or via command line.
#
sword following https://docs.gitlab.com/ee/security/reset_user_password.html#reset-your-root-password.

Password: kQHoxSzX4lmhfyGB9QhABvOIMjHUUJo/jtgj0HFnUAQ=
# NOTE: This file will be automatically deleted in the first

根据该文件提供的密码可以实现第一次登录,当然这个密码太长

修改密码:

1
gitlab-rails console -e production

a5dae567906092f8954119d5dc2d3380.png

1
2
3
4
5
6
7
>user = User.where(id: 1).first #查看id为1的账号
>或者 user = User.where(name:"root").first

>user.password='123456789' #修改密码为12345678
>user.password_confirmation='123456789' #确认密码
>user.save! #保存
>quit #退出‘’

IDEA 集成 GitLab 需要安装 GitLab 插件

e3647150143b97be953df3d9fae6cf18.png

上一篇:
定时任务
下一篇:
Maven