CICD 持续集成与持续交付

目录

[一 CICD是什么](#一 CICD是什么)

[1.1 持续集成(Continuous Integration)](#1.1 持续集成(Continuous Integration))

[1.2 持续部署(Continuous Deployment)](#1.2 持续部署(Continuous Deployment))

[1.3 持续交付(Continuous Delivery)](#1.3 持续交付(Continuous Delivery))

[二 git工具使用](#二 git工具使用)

[2.1 git简介](#2.1 git简介)

[2.2 git 工作流程](#2.2 git 工作流程)

[三 部署git](#三 部署git)

[3.1 安装git](#3.1 安装git)

[3.2 初始化](#3.2 初始化)

[四 git的使用方法](#四 git的使用方法)

[4.1 常用方法](#4.1 常用方法)

[4.1 常用方法](#4.1 常用方法)

[4.2 git对于文件如何忽略](#4.2 git对于文件如何忽略)

[五 gitlab代码仓库](#五 gitlab代码仓库)

[5.1 gitlab简介](#5.1 gitlab简介)

[5.2 gitlab 的部署实施](#5.2 gitlab 的部署实施)

[5.2.1 部署gitlab](#5.2.1 部署gitlab)

[5.2.2 配置gitlab](#5.2.2 配置gitlab)

[5.2.3 登陆gitlab](#5.2.3 登陆gitlab)

[5.3 在gitlab中新建项目](#5.3 在gitlab中新建项目)

[六 jenkins](#六 jenkins)

[6.1 jenkins 简介](#6.1 jenkins 简介)

[6.2 部署 jenkins](#6.2 部署 jenkins)

[6.3 jenkins 与gitlab的整合](#6.3 jenkins 与gitlab的整合)


一 CICD是什么

CI/CD 是指持续集成(Continuous Integration)和持续部署(Continuous Deployment)或持续交付(Continuous Delivery)

1.1 持续集成(Continuous Integration)

持续集成是一种软件开发实践,团队成员频繁地将他们的工作集成到共享的代码仓库中。其主要特点包括:

  1. 频繁提交代码:开发人员可以每天多次提交代码,确保代码库始终保持最新状态。
  2. 自动化构建:每次提交后,自动触发构建过程,包括编译、测试、静态分析等。
  3. 快速反馈:如果构建失败或测试不通过,能够快速地向开发人员提供反馈,以便及时修复问题。

1.2 持续部署(Continuous Deployment)

持续部署是在持续集成的基础上,将通过所有测试的代码自动部署到生产环境中。其特点如下:

  1. 自动化流程:从代码提交到生产环境的部署完全自动化,无需人工干预。
  2. 高频率部署:可以实现频繁的部署,使得新功能能够快速地提供给用户。
  3. 风险控制:需要有强大的测试和监控体系来确保部署的稳定性和可靠性。

1.3 持续交付(Continuous Delivery)

持续交付与持续部署类似,但不一定自动部署到生产环境,而是随时可以部署。其重点在于确保软件随时处于可发布状态。

CI/CD 的好处包括:

  1. 提高开发效率:减少手动操作和等待时间,加快开发周期。
  2. 尽早发现问题:通过频繁的集成和测试,问题能够在早期被发现和解决。
  3. 降低风险:减少了大规模部署时可能出现的问题,提高了软件的质量和稳定性。
  4. 增强团队协作:促进团队成员之间的沟通和协作,提高团队的整体效率。

常见的 CI/CD 工具包括 Jenkins、GitLab CI/CD、Travis CI 等。这些工具可以帮助团队实现自动化的构建、测试和部署流程。

二 git工具使用

2.1 git简介

Git 是一个分布式版本控制系统,被广泛用于软件开发中,以管理代码的版本和变更。主要特点:

  • 分布式
    • 每个开发者都有完整的代码仓库副本,这使得开发者可以在离线状态下进行工作,并且在网络出现问题时也不会影响开发。
    • 即使中央服务器出现故障,开发者仍然可以在本地进行开发和查看项目历史。
  • 高效的分支管理
    • Git 中的分支创建和切换非常快速和简单。开发人员可以轻松地创建新的分支来进行新功能的开发或修复 bug,而不会影响主分支。
    • 合并分支也相对容易,可以使用多种合并策略来满足不同的需求。
  • 快速的版本回退
    • 如果发现某个版本存在问题,可以快速回退到之前的版本。
    • 可以查看每个版本的详细变更记录,方便了解代码的演进过程。
  • 强大的提交管理
    • 每个提交都有一个唯一的标识符,可以方便地引用和查看特定的提交。
    • 提交可以包含详细的提交信息,描述本次提交的更改内容。
  • 支持协作开发
    • 开发者可以将自己的更改推送到远程仓库,供其他开发者拉取和合并。
    • 可以处理多个开发者同时对同一文件进行修改的情况,通过合并冲突解决机制来确保代码的完整性。

Git必看秘籍:Git - Book

2.2 git 工作流程

Git 有三种状态:已提交(committed)、已修改(modified) 和 已暂存(staged)。

  • 已修改表示修改了文件,但还没保存到数据库中。
  • 已暂存表示对一个已修改文件的当前版本做了标记,使之包含在下次提交的快照中。
  • 已提交表示数据已经安全地保存在本地数据库中。

这会让我们的 Git 项目拥有三个阶段:工作区、暂存区以及 Git 目录。

三 部署git

3.1 安装git

#在rhel9的系统中默认自带git
[root@getlab-node1 ~]# dnf install git  -y
[root@getlab-node1 ~]# mkdir zhang
[root@getlab-node1 ~]# cd zhang/


#设定命令补全功能
[root@getlab-node1 zhang]# echo "source  /usr/share/bash-completion/completions/git" >> ~/.bashrc
[root@getlab-node1 zhang]# source  ~/.bashrc

3.2 初始化

获取 Git 仓库通常有两种方式:

  • 将尚未进行版本控制的本地目录转换为 Git 仓库。
  • 从其它服务器克隆 一个已存在的 Git 仓库。比如: git clone

初始化版本库

[root@getlab-node1 zhang]# git init
提示:使用 'master' 作为初始分支的名称。这个默认分支名称可能会更改。要在新仓库中
提示:配置使用初始分支名,并消除这条警告,请执行:
提示:
提示:	git config --global init.defaultBranch <名称>
提示:
提示:除了 'master' 之外,通常选定的名字有 'main'、'trunk' 和 'development'。
提示:可以通过以下命令重命名刚创建的分支:
提示:
提示:	git branch -m <name>
已初始化空的 Git 仓库于 /root/zhang/.git/

#设定用户信息
[root@getlab-node1 zhang]# git config --global user.name "haha"
[root@getlab-node1 zhang]# git config --global user.email "haha@qq.com"

[root@getlab-node1 zhang]# ls -a
.  ..  .git
[root@getlab-node1 zhang]# ls ./.git/
branches  config  description  HEAD  hooks  info  objects  refs

#查看文件状态
[root@getlab-node1 zhang]# git status 
位于分支 master

尚无提交

无文件要提交(创建/拷贝文件并使用 "git add" 建立跟踪)

[root@getlab-node1 zhang]# git status -s		#简化输出

.git目录是git跟踪管理版本库的,没事别瞎溜达

四 git的使用方法

4.1 常用方法

4.1 常用方法

#提交到暂存区
git add README.md 

#提交暂存区的数据
git commit -m "add README.md"

 #撤销修改
git checkout -- README.md

#从暂存区撤销
git restore --staged README.md 

#撤销工作区中删除动作
git checkout -- haha.txt

#查看提交动作
git reflog   

#版本回退到删除之前
git reset 33c058b

[root@getlab-node1 zhang]# echo haha > README.md
[root@getlab-node1 zhang]# git status 
位于分支 master

尚无提交

未跟踪的文件:
  (使用 "git add <文件>..." 以包含要提交的内容)
	README.md

提交为空,但是存在尚未跟踪的文件(使用 "git add" 建立跟踪)

[root@getlab-node1 zhang]# git status -s
?? README.md          #??	新建文件未添加到版本库

#提交到暂存区
[root@getlab-node1 zhang]# git add README.md 
[root@getlab-node1 zhang]# git status -s
A  README.md              #A 已添加到暂存区

#提交暂存区的数据
[root@getlab-node1 zhang]# git commit -m "add README.md"
[master(根提交) 1f98d1a] add README.md
 1 file changed, 1 insertion(+)
 create mode 100644 README.md
[root@getlab-node1 zhang]# git status -s    #无任何显示,标识已经提交到版本库

#再次修改
[root@getlab-node1 zhang]# echo >> README.md 

[root@getlab-node1 zhang]# git status -s
 M README.md                        #右M 表示文件在工作区被修改

#提交到暂存区
[root@getlab-node1 zhang]# git add README.md 
[root@getlab-node1 zhang]# git status -s
M  README.md

#提交暂存区的数据
[root@getlab-node1 zhang]# git commit -m "README.md v2"
[master 8a9949f] README.md v2
 1 file changed, 1 insertion(+)
[root@getlab-node1 zhang]# git status -s

#查看已暂存和未暂存的修改变化
git diff

再次修改

[root@getlab-node1 zhang]# vim README.md
haha

haha

[root@getlab-node1 zhang]# git status -s
 M README.md             #右M 表示文件在工作区被修改

 #撤销修改
[root@getlab-node1 zhang]# git checkout -- README.md
[root@getlab-node1 zhang]# cat README.md 
haha

#从新修改
[root@getlab-node1 zhang]# echo haha> README.md
[root@getlab-node1 zhang]# git add README.md 
[root@getlab-node1 zhang]# git status -s
M  README.md          #左M表示文件已经在版本库中并被跟踪,

#从暂存区撤销
[root@getlab-node1 zhang]# git restore --staged README.md 
[root@getlab-node1 zhang]# git status -s
 M README.md

#从新提交
[root@getlab-node1 zhang]# git add README.md
[root@getlab-node1 zhang]# git status -s
M  README.md

#更新
[root@getlab-node1 zhang]# git commit -m "update v1"
[master e51ef6c] update v1
 1 file changed, 1 deletion(-)
[root@getlab-node1 zhang]# git status -s


#更新文件
[root@getlab-node1 zhang]# echo haha >> README.md
[root@getlab-node1 zhang]# git add README.md
[root@getlab-node1 zhang]# echo haha >> README.md
[root@getlab-node1 zhang]# git status -s
MM README.md                    #MM表示有一部分在暂存区,还有一部分没有提交

#如果现在提交只能提交在暂存区中的部分
[root@getlab-node1 zhang]# git commit -m "update v2"
[master 63411dc] update v2
 1 file changed, 1 insertion(+)
[root@getlab-node1 zhang]# git status -s
 M README.md               #右M还在

#查看已暂存和未暂存的修改变化
[root@getlab-node1 zhang]# git diff
diff --git a/README.md b/README.md
index f247ec3..6b10261 100644
--- a/README.md
+++ b/README.md
@@ -1,2 +1,4 @@
 haha
 haha
+haha
+haha

#跳过使用暂存区,只能在提交过的在版本库中存在的文件使用如果文件状态是"??"不能用此方法
[root@getlab-node1 zhang]# git commit -a -m "update v3"
[master b2ed96f] update v3
 1 file changed, 2 insertions(+)

#撤销工作区中删除动作
[root@getlab-node1 zhang]# touch haha.txt
[root@getlab-node1 zhang]# git add haha.txt
[root@getlab-node1 zhang]# git commit  -m "add haha.txt"
[master 33c058b] add haha.txt
 1 file changed, 0 insertions(+), 0 deletions(-)
 create mode 100644 haha.txt
[root@getlab-node1 zhang]# git status -s
[root@getlab-node1 zhang]# git checkout -- haha.txt
[root@getlab-node1 zhang]# ls
haha.txt  README.md

#从版本库中删除文件
[root@getlab-node1 zhang]# git rm haha.txt
rm 'haha.txt'
[root@getlab-node1 zhang]# git status -s
D  haha.txt        #左D表示文件删除动作被提交到暂存区

[root@getlab-node1 zhang]# git commit -m "delete haha.txt"
位于分支 master
无文件要提交,干净的工作区
[root@getlab-node1 zhang]# git status -s


#恢复从版本库中被删除的文件
[root@getlab-node1 zhang]# git log    #查看操作日志
commit 1282fe5f0af2892ec977a646cf54a519b4e15cb1 (HEAD -> master)
Author: haha <haha@qq.com>
Date:   Thu Sep 12 19:42:39 2024 +0800

    delete lee.txt

commit 33c058b8be9c0da32e4e508330ea323899b6191f
Author: haha <haha@qq.com>
Date:   Thu Sep 12 19:35:12 2024 +0800

    add haha.txt

commit b2ed96fb7c40a4581e412c8224507fe739a973be
Author: haha <haha@qq.com>
Date:   Thu Sep 12 19:34:34 2024 +0800

    update v3

commit 63411dcad59cdfcec1aa62d746d412eb9614c934
Author: haha <haha@qq.com>
Date:   Thu Sep 12 19:33:28 2024 +0800


[root@getlab-node1 zhang]# git reflog   #查看提交动作
1282fe5 (HEAD -> master) HEAD@{0}: commit: delete lee.txt
33c058b HEAD@{1}: commit: add haha.txt
b2ed96f HEAD@{2}: commit: update v3
63411dc HEAD@{3}: commit: update v2
e51ef6c HEAD@{4}: commit: update v1
8a9949f HEAD@{5}: commit: README.md v2
1f98d1a HEAD@{6}: commit (initial): add README.md

#版本回退到删除之前
[root@getlab-node1 zhang]# git reset 33c058b

4.2 git对于文件如何忽略

在做软件开发时对源码编译会产生一些临时文件,我们在提交时需要忽略这些临时文件

[root@getlab-node1 zhang]# mkdir dir1/
[root@getlab-node1 zhang]# touch dir1/.file2
[root@getlab-node1 zhang]# git status -s
?? dir1/

[root@getlab-node1 zhang]# echo .file1 > .gitignore
[root@getlab-node1 zhang]# git status -s
?? .gitignore
?? dir1/

[root@getlab-node1 zhang]# echo ".*" > .gitignore
[root@getlab-node1 zhang]# git status -s

五 gitlab代码仓库

5.1 gitlab简介

  • GitLab 是一个用于仓库管理系统的开源项目,使用 Git 作为代码管理工具,并在此基础上搭建起来的 web 服务。
  • GitLab 具有很多功能,比如代码托管、持续集成和持续部署(CI/CD)、问题跟踪、合并请求管理等。它可以帮助开发团队更好地协作开发软件项目,提高开发效率和代码质量。

官网:https://about.gitlab.com/install/

中文站点: GitLab下载安装_GitLab安装和配置_GitLab最新中文官网免费版下载-极狐GitLab

官方包地址:gitlab/gitlab-ce - Packages · packages.gitlab.com

5.2 gitlab 的部署实施

5.2.1 部署gitlab

部署gitlab需要内存大于4G

#在安装包之前需配置好软件仓库来解决依赖性
[root@getlab-node1 ~]# yum install -y curl policycoreutils-python-utils openssh-server perl

[root@getlab-node1 ~]# dnf install gitlab-ce-17.1.6-ce.0.el9.x86_64.rpm -y

5.2.2 配置gitlab

#修改配置文件
[root@getlab-node1 ~]# cd /etc/gitlab/
[root@getlab-node1 gitlab]# ls
gitlab.rb
[root@getlab-node1 gitlab]# vim gitlab.rb
32 external_url 'http://172.25.254.80'

#修改配置文件后需利用gitlab-crt来生效,
[root@CICD-node1 gitlab]# gitlab-ctl reconfigure

#执行命令成功后会把所有组件全部启动起来

5.2.3 登陆gitlab

用户名默认为 root 。如果在安装过程中指定了初始密码,则用初始密码登录,如果未指定密码,则系统会随机生成一个密码并存储在 /etc/gitlab/initial_root_password 文件中, 查看随机密码并使用 root 用户名登录。

注意:出于安全原因,24 小时后,/etc/gitlab/initial_root_password 会被第一次 gitlab-ctl reconfigure 自动删除,因此若使用随机密码登录,建议安装成功初始登录成功之后,立即修改初始密码。

#查看原始密码
[root@CICD-node1 gitlab]# 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` environment variable or via `gitlab_rails['initial_root_password']` setting in `gitlab.rb`, it was provided before database was seeded for the first time (usually, the first reconfigure run).
#          2. Password hasn't been changed manually, either via UI or via command line.
#
#          If the password shown here doesn't work, you must reset the admin password following https://docs.gitlab.com/ee/security/reset_user_password.html#reset-your-root-password.

Password: jN9lq6NSP8a2V+4n57djzWlEGP7RZ43DSIse8sXJGTQ=      #密码

# NOTE: This file will be automatically deleted in the first reconfigure run after 24 hours.

登陆

设置语言

选项在下面

设置密码

5.3 在gitlab中新建项目

#生成sshd密钥
[root@getlab-node1 gitlab]# ssh-keygen
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa): 
Enter passphrase (empty for no passphrase): 
Enter same passphrase again: 
Your identification has been saved in /root/.ssh/id_rsa
Your public key has been saved in /root/.ssh/id_rsa.pub
The key fingerprint is:
SHA256:biLSHPSri2ATy4Hj4bjyPNznfK6Ih3x/1bAM7YoEq+c root@getlab-node1
The key's randomart image is:
+---[RSA 3072]----+
|                 |
|                 |
|    .    .       |
|.  ...  . o      |
|o+  .o. S+ +     |
|=.=o...o  = .    |
|oX.++.o.oo       |
|o+B+==oo+        |
|o.=*E===.        |
+----[SHA256]-----+

[root@getlab-node1 gitlab]# cd
[root@getlab-node1 ~]# cat .ssh/id_rsa.pub
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQCvOH0VlHeeMR8w3g677WL6WWQE3VMsS2fETfE/2/yKWXi+0iWXzxRZJq0NFxF3js0Uu64Yfobg94eO99FQcI6K6TfJQzaiMR/G3e0No5F0ydQ08U/Te1DzFv4lOoExWCd8EZg/MfmEmvgHhVdC3QmFyiZVPw/90ljCJErrZCrWPs9v8FhWEPWc4C6ZJ2ZFwgDQrNuTD7dnKCTTAgcFUZ40CSpIV72E07LerUdX7YgVvmnoGQ7V0Gs2AzOnDh+9Zwlpb9/NHWkgwRYTiLM12IH7bgSRUcsPs32yaOXf8msHwqCYm1kEysm4fTw06nTvYvDLwB20f3qDTEvV06aRz0jiw8eKlXG1r8z4UZVf6EY/8nT/BZv/HiFSyqZxHfYSV6zh/7qahOVbN1Fnr/52PFDYCmbJYPUXn0O3IXa9vHnwyQhw3k/DK/5feJxqDDMrO+8Ujlzx1iWRfBtt9J9CVtWnS296o5gsirg/jaUf2EmCtRqCn0crYXhCs6uGnolwWR8= root@getlab-node1

上传公钥到gitlab中

下载项目

[root@getlab-node1 ~]# git clone  git@172.25.254.80:root/hahaha.git
正克隆到 'hahaha'...
The authenticity of host '172.25.254.80 (172.25.254.80)' can't be established.
ED25519 key fingerprint is SHA256:ov5ncy/2ZvbULX/pM00/gNAp6EIEv1j6jwYEnCtTeX8.
This key is not known by any other names
Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
Warning: Permanently added '172.25.254.80' (ED25519) to the list of known hosts.
remote: Enumerating objects: 3, done.
remote: Counting objects: 100% (3/3), done.
remote: Compressing objects: 100% (2/2), done.
remote: Total 3 (delta 0), reused 0 (delta 0), pack-reused 0 (from 0)
接收对象中: 100% (3/3), 完成.

[root@getlab-node1 ~]# ls -R
./hahaha:
README.md

[root@getlab-node1 ~]# cd hahaha/
[root@getlab-node1 hahaha]# ls
README.md

[root@getlab-node1 hahaha]# git remote -v
origin	git@172.25.254.80:root/hahaha.git (fetch)
origin	git@172.25.254.80:root/hahaha.git (push)

#文件提交

[root@getlab-node1 ~]# cd hahaha/
[root@getlab-node1 hahaha]# ls
README.md
[root@getlab-node1 hahaha]# git remote -v
origin	git@172.25.254.80:root/hahaha.git (fetch)
origin	git@172.25.254.80:root/hahaha.git (push)
[root@getlab-node1 hahaha]# echo haha1 > haha
[root@getlab-node1 hahaha]# git add haha 
[root@getlab-node1 hahaha]# git commit -m "add haha"
[main aff2e07] add haha
 1 file changed, 1 insertion(+)
 create mode 100644 haha
[root@getlab-node1 hahaha]# git push -u origin main
枚举对象中: 4, 完成.
对象计数中: 100% (4/4), 完成.
使用 4 个线程进行压缩
压缩对象中: 100% (2/2), 完成.
写入对象中: 100% (3/3), 260 字节 | 260.00 KiB/s, 完成.
总共 3(差异 0),复用 0(差异 0),包复用 0
To 172.25.254.80:root/hahaha.git
   92afb73..aff2e07  main -> main
分支 'main' 设置为跟踪 'origin/main'。

六 jenkins

6.1 jenkins 简介

  • Jenkins是开源CI&CD软件领导者, 提供超过1000个插件来支持构建、部署、自动化, 满足任何项目的需要。
  • Jenkins用Java语言编写,可在Tomcat等流行的servlet容器中运行,也可独立运行

CI(Continuous integration持续集成)持续集成强调开发人员提交了新代码之后,立刻进行构建、(单元)测试。

CD(Continuous Delivery持续交付) 是在持续集成的基础上,将集成后的代码部署到更贴近真实运行环境(类生产环境)中

6.2 部署 jenkins

软件下载:Download and deploy

jenkins需要部署在新的虚拟机

jenkins需要部署在新的虚拟机中,建议最少4G内存,4核心cpu

#注意:两台主机做解析(jenkins和getlab)

[root@jenkins ~]# vim /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4

::1         localhost localhost.localdomain localhost6 localhost6.localdomain6

172.25.254.90   jenkins
172.25.254.80   getlab-node1

[root@getlab-node1 ~]# /etc/hosts
127.0.0.1   localhost localhost.localdomain localhost4 localhost4.localdomain4

::1         localhost localhost.localdomain localhost6 localhost6.localdomain6

172.25.254.90   jenkins
172.25.254.80   getlab-node1

#安装依赖包
[root@jenkins ~]# yum install fontconfig java-17-openjdk git

#安装jenkins
[root@jenkins ~]# dnf install jenkins-2.476-1.1.noarch.rpm

#启动jenkins
[root@jenkins ~]# systemctl enable --now jenkins.service

#查看原始密码
[root@jenkins ~]# cat /var/lib/jenkins/secrets/initialAdminPassword
b2e1dcd091e744f88dc67f388e8bd88e

#清除文件的方法
[root@jenkins ~]# systemctl stop jenkins.service 
[root@jenkins ~]# rm -rf /var/lib/jenkins/*
[root@jenkins ~]# systemctl start jenkins.service 

#查看jenkins配置文件
[root@jenkins ~]# cd /var/lib/jenkins/
[root@jenkins jenkins]# ls
config.xml                        logs                      secrets
hudson.model.UpdateCenter.xml     nodeMonitors.xml          updates
hudson.plugins.git.GitTool.xml    plugins                   userContent
identity.key.enc                  queue.xml.bak             users
jenkins.telemetry.Correlator.xml  secret.key
jobs                              secret.key.not-so-secret

[root@jenkins jenkins]# vim hudson.model.UpdateCenter.xml
<?xml version='1.1' encoding='UTF-8'?>
<sites>
  <site>
    <id>default</id>
    <url>https://updates.jenkins.io/update-center.json</url>
  </site>
</sites>

[root@jenkins jenkins]# cd updates/
[root@jenkins updates]# vim default.json 

部署插件

#由于网络问题,直接导入插件包
[root@jenkins ~]# tar zxf plugins.tar.gz -C /var/lib/jenkins/
[root@jenkins ~]# systemctl restart jenkins.service 

建议修改admin的密码,在admin的设置中修改即可

修改密码方法:

6.3 jenkins 与gitlab的整合

这个错误的原因是因为本机没有gitlab上的sshkey

[root@jenkins ~]# ssh-keygen
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa): 
Enter passphrase (empty for no passphrase): 
Enter same passphrase again: 
Your identification has been saved in /root/.ssh/id_rsa
Your public key has been saved in /root/.ssh/id_rsa.pub
The key fingerprint is:
SHA256:xzD7SdNTNuwG16h2hnchlhDwiQwqj08D6bz86Z1QY50 root@jenkins
The key's randomart image is:
+---[RSA 3072]----+
|       . ..o.    |
|    . . o o o..o |
|   + .  oo o.+B..|
|  o =   .=...O...|
|   + + +SE= * * .|
|  . + + .+ + * . |
|   o o    o      |
|    . + .        |
|    .+ o         |
+----[SHA256]-----+
[root@jenkins ~]# cat /root/.ssh/id_rsa.pub
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQC7qa28BbQXEi94LUVEnSTo2O5cQbqQwi2sKErSi/UhbhMVyUIcm36ggx4x/AoaSClSWNRxEZp3g6uV+txxtk3CyL23P9WHAjOPHHOVU82PWBxRMzMdLQiXMzh70OF3VXBqRt6i0ZxpoKj03ZuW3gAo8T2mSVMiITMyHcAGKTNM9LjNrRVzNqxfYbYC5RmvGFPJ73y+JxRZVb9sAxWkDwpVm4J3ORDV2T4lR7z4itpnHymcYED9Xcu/j+P2psYMx04/1nKBVpjEMnUYAPBs2UiaYEF0u0/KDprX8Oh1VwVcImaNTQoCHwjYp0oCwLK0ThKt839Nl+Ixnmw5tzsYXy8gGgu4cS+LlnrPg8Ys2lb9Vrre3g7KRtn06UlDoV6wGXULrtUIN5B8KP3iy6DPkGbJ6MLLeulVeimzzxtQyrtacm9EHVrjZprqRE4QxO0bIO37tnmJOAxJ9GchxOSFQFrV4eL4ND9ZIRMlcGivrAtWHu832s6jtlC76RzW5XEiaCc= root@jenkins

把此密钥添加到gitlab上即可

添加密钥凭据

查看密钥

[root@jenkins ~]# cat /root/.ssh/id_rsa
-----BEGIN OPENSSH PRIVATE KEY-----
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
-----END OPENSSH PRIVATE KEY-----

添加完成后报错依然存在,因为ssh首次连接主机是需要签名认证,需要手动输入yes

原因:没有输入这个yes

另一种解决方法

[root@jenkins ~]# vim /etc/ssh/ssh_config
Host *
    StrictHostKeyChecking no

还有两太主机之间一定要做好解析

返回浏览器,刷新一下

查看结果

等一分钟

相关推荐
安静读书16 小时前
持续集成与持续部署:CI/CD简介
运维·ci/cd
安静读书2 天前
持续集成与持续部署:CI/CD实现教程
ci/cd
AliCloudROS3 天前
2分钟在阿里云ECS控制台部署个人应用(图文示例)
阿里云·ci/cd·持续部署
天草二十六_简村人4 天前
jenkins用户在执行scp的时候如何做免密登录
运维·ci/cd·node.js·jenkins·php·devops
Lalolander4 天前
通过华为鲲鹏认证发行上市的集成平台产品推荐
大数据·人工智能·科技·安全·ci/cd·华为·持续集成
golitter.4 天前
CI/CD认识
运维·ci/cd
莫尔道嘎老范5 天前
vue+vite前端项目ci过程中遇到的问题
前端·vue.js·ci/cd
小技与小术6 天前
CICD持续集成与持续交付
ci/cd·云原生·kubernetes
杨哥带你写代码6 天前
Spring Boot编程训练系统:敏捷开发与持续集成
spring boot·ci/cd·敏捷流程
qq_4337169510 天前
编写第一个 Appium 测试脚本:从安装到运行!
自动化测试·软件测试·jmeter·ci/cd·职场和发展·appium·jenkins