Jenkins
目錄
- Jenkins
- jenkins簡介
- jenkins作業原理
- jenkins特點
- CI/CD是什么
- 使用tomcat容器安裝jenkins
- jenkins流水線專案發布流程
jenkins簡介
Jenkins官網
Jenkins是一個開源CI&CD軟體、提供友好操作界面的持續集成(CI)工具;
起源于Hudson(Hudson是商用的),主要用于持續、自動的構建/測驗軟體專案、監控外部任務的運行;Jenkins用Java語言撰寫,可在Tomcat等流行的servlet容器中運行,也可獨立運行;通常與版本管理工具(SCM)、構建工具結合使用,
常用的版本控制工具:SVN、GIT
構建工具有:Maven、Ant、Gradle
jenkins作業原理
將源代碼從SVN/Git版本控制系統中拷貝一份到本地,然后根據設定的腳本進行build(構建);整個系統的關鍵就是build腳本,build腳本告訴Jenkins在一次集成中需要執行的任務,
jenkins特點
(1)易安裝:僅僅一個 Jenkins.war,從官網下載該檔案后,直接運行,無需額外的安裝,更無需安裝資料庫
(2)易配置:提供友好的 GUI 配置界面
(3)變更支持:Jenkins 能從代碼倉庫(SVN/Git)中獲取并產生代碼更新串列,并輸出到編譯輸出資訊中
(4)支持永久鏈接:用戶是通過 Web 來訪問 Jenkins 的,而這些 Web 頁面的鏈接地址都是永久鏈接地址,可以在各種檔案中直接使用該鏈接;
(5)集成 E-Mail/RSS/IM:當完成一次集成時,可通過這些工具實時收取集成結果(構建一次集成需要花費一定時間,有了這個功能,就可以在等待結果程序中,干別的事情);
(6)JUnit/TestNG 測驗報告:也就是用以圖表等形式提供詳細的測驗報表功能;
(7)支持分布式構建:Jenkins 可以把集成構建等作業分發到多臺計算機中完成;
(8)檔案指紋資訊:Jenkins 會保存構建集成所產生的 jars 檔案、集成構建使用了哪個版本;
(9)支持第三方插件:Jenkins 支持 第三方插件,這使得 Jenkins 功能變得越來越強大
CI/CD是什么
CI持續集成
1、簡介
CI 持續集成(全稱:Continuous integration),中文意思是持續集成是一種軟體開發時間;持續集成強調開發人員提交了新代碼之后,立刻進行構建、(單元)測驗;根據測驗結果,我們可以確定新代碼和原有代碼能否正確地集成在一起,
假設一個應用程式,其代碼存盤在GitLab的Git倉庫中,開發人員每天都要多次推送代碼更改,對于每次向倉庫的推送,你都可以創建一組腳本來自動構建和測驗你的應用程式,從而減少了向應用程式引入錯誤的機會,這種做法稱為持續集成,對于提交給應用程式(甚至是開發分支)的每項更改,它都會自動連續進行構建和測驗,以確保所引入的更改通過你為應用程式建立的所有測驗,準則和代碼合規性標準,
2、CI作業模式

3、持續集成的優勢
(1)易于定位錯誤:
每一次的代碼集成都需要執行相關的測驗作業,持續集成頻繁的集成次數天然的將復雜的代碼邏輯切割為了小塊,也就使得每一次測驗中遇到的錯誤能夠更加容易的被定位,
(2)易于控制開發流程:
更為細致的作業提交也就意味著更容易判斷當前的作業進度,這對于管理者規劃開發流程而言提供了一個有效的參考,同時也為開發人員省下了匯報作業的時間,
CD持續交付
1、簡介
CD 持續交付(全稱:Continuous Delivery), 中文意思是:持續交付 是在 CI持續集成 的基礎上,將集成后的代碼部署到更貼近真實運行環境(類生產環境)中;比如,我們完成單元測驗后,可以把代碼部署到連接資料庫的Staging環境中更多的測驗,如果代碼沒有問題,可以繼續手動部署到生產環境,
2、CD作業模式

3、CD持續部署
簡介
CD 持續部署(全稱:Continuous Deployment),是 CI持續集成 ,CD持續交付的延伸,自動將交付的應用部署到生產環境,能及時收到用戶反饋,降低部署的風險;
持續部署是持續交付的下一步,在持續交付的基礎上,由開發人員或運維人員自助式的定期向生產環境部署穩定的構建版本,持續部署的目標是代碼在任何時刻都是可部署的,并可自動進入到生產環境,
作業模式:

使用tomcat容器安裝jenkins
部署tomcat,tomcat下載9.0版本的,10版本部署有bug,無法實作
tomcat下載9.0版本的下載地址
安裝jdk
[root@jenkins ~]# dnf -y install java-11-openjdk
下載tomcat,解壓tomcat,并部署安裝
root@jenkins ~]# wget https://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-9/v9.0.67/bin/apache-tomcat-9.0.67.tar.gz
[root@jenkins ~]# ls
anaconda-ks.cfg apache-tomcat-9.0.67.tar.gz
[root@jenkins ~]# tar xf apache-tomcat-9.0.67.tar.gz -C /usr/local/
[root@jenkins ~]# cd /usr/local/
[root@jenkins local]# ln -s apache-tomcat-9.0.67/ tomcat
關閉·防火墻,啟動tomcat,測驗能否訪問tomcat首頁
[root@jenkins local]# cd tomcat/
[root@jenkins tomcat]# systemctl stop firewalld.service
[root@jenkins tomcat]# vim /etc/selinux/config
SELINUX=disabled
[root@jenkins tomcat]# setenforce 0
[root@jenkins tomcat]# systemctl disable --now firewalld.service
Removed /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.
[root@jenkins tomcat]# bin/startup.sh
Using CATALINA_BASE: /usr/local/tomcat
Using CATALINA_HOME: /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME: /usr
Using CLASSPATH: /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Using CATALINA_OPTS:
Tomcat started.
訪問:

部署jenkins
下載jenkins到/usr/local/tomcat/webapps/目錄下
官網地址


[root@jenkins tomcat]# cd
[root@jenkins ~]# cd /usr/local/tomcat/webapps/
[root@jenkins webapps]# pwd
/usr/local/tomcat/webapps
下載下來后會自動解壓
[root@jenkins webapps]# wget http://mirrors.jenkins.io/war-stable/2.346.3/jenkins.war
[root@jenkins webapps]# ls
ROOT docs examples host-manager jenkins.war manager
啟動服務
[root@jenkins webapps]# cd /usr/local/tomcat/
[root@jenkins tomcat]# pwd
/usr/local/tomcat
[root@jenkins tomcat]# bin/catalina.sh stop
Using CATALINA_BASE: /usr/local/tomcat
Using CATALINA_HOME: /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME: /usr
Using CLASSPATH: /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Using CATALINA_OPTS:
NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.io=ALL-UNNAMED --add-opens=java.base/java.util=ALL-UNNAMED --add-opens=java.base/java.util.concurrent=ALL-UNNAMED --add-opens=java.rmi/sun.rmi.transport=ALL-UNNAMED
[root@jenkins tomcat]# bin/catalina.sh start
Using CATALINA_BASE: /usr/local/tomcat
Using CATALINA_HOME: /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME: /usr
Using CLASSPATH: /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Using CATALINA_OPTS:
Tomcat started.
瀏覽器訪問jinkins
直接在http://192.168.222.138:8080/后面加jinkins就可以訪問到

查看上圖框出來的檔案,該檔案中記錄這密碼,復制密碼并登錄
[root@jenkins tomcat]# cat /root/.jenkins/secrets/initialAdminPassword
41ec057f2f0643339e015d44019c63ab

自定義jenkins
選擇插件來安裝

選擇無,進行安裝,后期需要什么插件就安裝什么插件

創建管理員用戶admin,密碼為admin



此時登錄進去是英文界面,我們進行替換國內源

點擊 Advanced ---> 更新為國內源 ---> Submit
原國外插件源地址:https://updates.jenkins.io/update-center.json
國內插件源地址:https://mirror.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json


往下面翻

安裝簡體中文插件



用戶名和密碼都是admin


安裝Git GitHub GitLab Gitee插件
安裝完成后,會重啟jenkins


用戶界面
任務管理




全域工具配置
安裝jdk



節點管理
jenkins流水線專案發布流程
環境說明:
| 主機名稱 | ip地址 | 需要的應用服務 | 工具包 | 系統 |
|---|---|---|---|---|
| jenkins | 192.168.222.138 | tomcat、jenkins | git maven | RHEL8/centos8 |
| node2 | 192.168.222.139 | tomcat | 無 | RHEL8/centos8 |
1、關閉防火墻和selinux
[root@jenkins ~]# systemctl stop firewalld.service
[root@jenkins ~]# vim /etc/selinux/config
SELINUX=disabled
[root@jenkins ~]# setenforce 0
[root@jenkins ~]# systemctl disable --now firewalld.service
Removed /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.
2、在jenkins上部署服務tomcat和jenkins(上面已經部署),重新部署,登錄web界面時選擇安裝推薦的插件,部署好后,設定國內源
安裝jdk
[root@jenkins ~]# dnf -y install java-11-openjdk
下載tomcat,解壓tomcat,并部署安裝
root@jenkins ~]# wget https://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-9/v9.0.67/bin/apache-tomcat-9.0.67.tar.gz
[root@jenkins ~]# ls
anaconda-ks.cfg apache-tomcat-9.0.67.tar.gz
[root@jenkins ~]# tar xf apache-tomcat-9.0.67.tar.gz -C /usr/local/
[root@jenkins ~]# cd /usr/local/
[root@jenkins local]# ln -s apache-tomcat-9.0.67/ tomcat
啟動tomcat,測驗能否訪問tomcat首頁
[root@jenkins local]# cd tomcat/
[root@jenkins tomcat]# bin/startup.sh
Using CATALINA_BASE: /usr/local/tomcat
Using CATALINA_HOME: /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME: /usr
Using CLASSPATH: /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Using CATALINA_OPTS:
Tomcat started.
訪問:

部署jenkins
下載jenkins到/usr/local/tomcat/webapps/目錄下
官網地址


[root@jenkins tomcat]# cd
[root@jenkins ~]# cd /usr/local/tomcat/webapps/
[root@jenkins webapps]# pwd
/usr/local/tomcat/webapps
下載下來后會自動解壓
[root@jenkins webapps]# wget http://mirrors.jenkins.io/war-stable/2.346.3/jenkins.war
[root@jenkins webapps]# ls
ROOT docs examples host-manager jenkins.war manager
啟動服務
[root@jenkins webapps]# cd /usr/local/tomcat/
[root@jenkins tomcat]# pwd
/usr/local/tomcat
[root@jenkins tomcat]# bin/catalina.sh stop
Using CATALINA_BASE: /usr/local/tomcat
Using CATALINA_HOME: /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME: /usr
Using CLASSPATH: /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Using CATALINA_OPTS:
NOTE: Picked up JDK_JAVA_OPTIONS: --add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.io=ALL-UNNAMED --add-opens=java.base/java.util=ALL-UNNAMED --add-opens=java.base/java.util.concurrent=ALL-UNNAMED --add-opens=java.rmi/sun.rmi.transport=ALL-UNNAMED
[root@jenkins tomcat]# bin/catalina.sh start
Using CATALINA_BASE: /usr/local/tomcat
Using CATALINA_HOME: /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME: /usr
Using CLASSPATH: /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Using CATALINA_OPTS:
Tomcat started.
瀏覽器訪問jinkins
直接在http://192.168.222.138:8080/后面加jinkins就可以訪問到

查看上圖框出來的檔案,該檔案中記錄這密碼,復制密碼并登錄
root@jenkins tomcat]# cat /root/.jenkins/secrets/initialAdminPassword
fc3a1c3be0d94327a9ba48790f2ebfbb

使用推薦插件進行安裝






點擊 Advanced ---> 更新為國內源 ---> Submit
原國外插件源地址:https://updates.jenkins.io/update-center.json
國內插件源地址:https://mirror.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json


往下面翻

3、先在jenkins主機上生成一個密鑰,傳給node2主機
[root@jenkins ~]# ssh-keygen
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa): //回車
Created directory '/root/.ssh'.
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:ZYs4NKha67nu0hX2GP7sXokv4f6IXMBNLCsS8iPKjCw root@jenkins
The key's randomart image is: //回車
+---[RSA 3072]----+
| |
| o |
|o o = o |
|.o o+* o + . |
|o *o+=+ S . |
|*= ++.oo . |
|E=.. +o.o |
|o..o o=+ |
| +*.o+=oo |
+----[SHA256]-----+
[root@jenkins ~]# ssh-copy-id -i ~/.ssh/id_rsa.pub [email protected]
/usr/bin/ssh-copy-id: INFO: Source of key(s) to be installed: "/root/.ssh/id_rsa.pub"
The authenticity of host '192.168.222.139 (192.168.222.139)' can't be established.
ECDSA key fingerprint is SHA256:anVVbTlEIzA1E8rB7IbLzaf7t9oQjB0qFP6Dd/ijnJI.
Are you sure you want to continue connecting (yes/no/[fingerprint])? yes
/usr/bin/ssh-copy-id: INFO: attempting to log in with the new key(s), to filter out any that are already installed
/usr/bin/ssh-copy-id: INFO: 1 key(s) remain to be installed -- if you are prompted now it is to install the new keys
[email protected]'s password:
Number of key(s) added: 1
Now try logging into the machine, with: "ssh '[email protected]'"
and check to make sure that only the key(s) you wanted were added.
可以提前做一個映射,防止訪問不了github
[root@jenkins ~]# vim /etc/hosts
[root@jenkins ~]# cat /etc/hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
20.205.243.166 github.com //添加
4、在node2上部署tomcat
[root@node2 ~]# systemctl stop firewalld.service
[root@node2 ~]# vim /etc/selinux/config
SELINUX=disabled
[root@node2 ~]# setenforce 0
[root@node2 ~]# systemctl disable --now firewalld.service
Removed /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.
[root@node2 ~]# dnf -y install java-11-openjdk
[root@node2 ~]# wget https://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-9/v9.0.67/bin/apache-tomcat-9.0.67.tar.gz
[root@node2 ~]# ls
anaconda-ks.cfg apache-tomcat-9.0.67.tar.gz
[root@node2 ~]# tar xf apache-tomcat-9.0.67.tar.gz -C /usr/local/
[root@node2 ~]# cd /usr/local/
[root@node2 local]# ln -s apache-tomcat-9.0.67/ tomcat
[root@node2 local]# ls tomcat/
BUILDING.txt LICENSE README.md RUNNING.txt conf logs webapps
CONTRIBUTING.md NOTICE RELEASE-NOTES bin lib temp work
[root@node2 local]# cd tomcat/
[root@node2 tomcat]# bin/catalina.sh start
Using CATALINA_BASE: /usr/local/tomcat
Using CATALINA_HOME: /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME: /usr
Using CLASSPATH: /usr/local/tomcat/bin/bootstrap.jar:/usr/local/tomcat/bin/tomcat-juli.jar
Using CATALINA_OPTS:
Tomcat started.
進行訪問:

可以提前做一個映射,防止訪問不了github
[root@node2 ~]# vim /etc/hosts
[root@node2 ~]# cat /etc/hosts
127.0.0.1 localhost localhost.localdomain localhost4 localhost4.localdomain4
::1 localhost localhost.localdomain localhost6 localhost6.localdomain6
20.205.243.166 github.com //添加
5、在node1中配置jenkins
創建任務

創建流水線任務

發布流水線的方法我在這里給大家介紹兩種,一種是腳本的方式,一種是使用文本引數的方式
首選都需要在jinkins所在服務器,也就是jenkins中安裝git和maven
[root@jenkins ~]# dnf -y install git maven
就是通過文本引數來實作流水線專案發布
添加文本引數

添加git下載資訊 http://github.com/lizhenliang/tomcat-java-demo.git

添加字符引數,打包


添加字符引數 定義tomcat路徑


添加文本引數 定義客戶端ip


撰寫流水線腳本
pipeline {
agent any
stages {
stage('pull code') {
steps {
git "http://github.com/lizhenliang/tomcat-java-demo.git"
}
}
stage('package') {
steps {
sh """
mvn clean
mvn package
"""
}
}
stage('deploy') {
steps {
sh """
scp target/ly-simple-tomcat-0.0.1-SNAPSHOT.war [email protected]:/usr/local/tomcat/webapps/
ssh [email protected] '/usr/local/tomcat/bin/catalina.sh stop && /usr/local/tomcat/bin/catalina.sh start'
"""
}
}
}
}

進行創建,并查看剛剛定義好的變數引數值

構建


在node2上面查看剛剛腳本創建的內容
[root@node2 ~]# cd /usr/local/tomcat/webapps/
[root@node2 webapps]# ls
ROOT examples ly-simple-tomcat-0.0.1-SNAPSHOT manager
docs host-manager ly-simple-tomcat-0.0.1-SNAPSHOT.war
進行訪問
http://192.168.222.139:8080/ly-simple-tomcat-0.0.1-SNAPSHOT/

轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/510964.html
標籤:Linux
上一篇:痞子衡嵌入式:淺談i.MXRT10xx系列MCU外接24MHz晶振的作用
下一篇:keepalived高可用
