使用tomcat容器安装jenkins
部署tomcat,tomcat下载https://mirrors.tuna.tsinghua.edu.cn/apache/tomcat,此时下载9.0版本的,10版本部署有bug,无法实现。
安装jdk
[root@localhost ~]# dnf -y install lrzsz java-11-openjdk
解压tomcat,并部署安装
[root@localhost ~]# ls
anaconda-ks.cfg apache-tomcat-9.0.67.tar.gz
[root@localhost ~]# tar -xzf apache-tomcat-9.0.67.tar.gz -C /usr/local/
[root@localhost ~]# cd /usr/local/
[root@localhost local]# ls
apache-tomcat-9.0.67 etc include lib64 sbin src
bin games lib libexec share
[root@localhost local]# ln -s apache-tomcat-9.0.67/ tomcat
[root@localhost local]# ls
apache-tomcat-9.0.67 etc include lib64 sbin src
bin games lib libexec share tomcat
启动tomcat,测试能否访问tomcat首页
[root@localhost local]# 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@localhost local]# cd tomcat/webapps/
[root@localhost webapps]# pwd
/usr/local/tomcat/webapps
[root@localhost webapps]#
下载下来后会自动解压
[root@localhost webapps]# wget http://mirrors.jenkins.io/war-stable/2.346.3/jenkins.war
[root@localhost webapps]# ls
docs examples host-manager jenkins jenkins.war manager ROOT
[root@localhost webapps]#
浏览器访问jinkins
查看上图框出来的文件,该文件中记录这密码,复制密码并登录
[root@localhost webapps]# cat /root/.jenkins/secrets/initialAdminPassword
7f5abae0949d4798a99016c94da76187
[root@localhost webapps]#
此时登录进去是英文界面,我们进行替换国内源
点击 Advanced —> 更新为国内源 —> Submit
原国外插件源地址:https://updates.jenkins.io/update-center.json
国内插件源地址:https://mirror.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json
要是倒数第二个卡这可以在地址栏后面加一个restart
安装Git GitHub GitLab Gitee插件
安装完成后,会重启jenkins
用户界面
任务管理
全局工具配置
安装jdk
节点管理
Jenkins流水线项目发布流程
主机名称 | ip地址 | 需要的应用服务 | 工具包 | 系统 |
---|---|---|---|---|
jinkins | 192.168.64.128 | tomcat、jenkins | git maven | rhel8 |
node | 192.168.64.134 | tomcat | 无 | rehel8 |
关闭防火墙和selinux
在node1上部署服务tomcat和jenkins(上面已经部署),重新部署,登录web界面时选择安装推荐的插件,部署好后,设置国内源
[root@jenkins ~]# mount /dev/cdrom /mnt/
mount: /mnt: WARNING: device write-protected, mounted read-only.
[root@jenkins ~]# yum -y install lrzsz java-11-openjdk git maven
[root@jenkins ~]# tar -xzf apache-tomcat-9.0.67.tar.gz -C /usr/local/[root@jenkins ~]# cd /usr/local/
[root@jenkins local]# ls
apache-tomcat-9.0.67 etc include lib64 sbin src
bin games lib libexec share
[root@jenkins local]# ln -s apache-tomcat-9.0.67/ tomcat
[root@jenkins local]# 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.
[root@jenkins local]#
[root@jenkins local]# ls
apache-tomcat-9.0.67 etc include lib64 sbin src
bin games lib libexec share tomcat
[root@jenkins local]# cd tomcat/
[root@jenkins tomcat]# ls
bin CONTRIBUTING.md logs RELEASE-NOTES webapps
BUILDING.txt lib NOTICE RUNNING.txt work
conf LICENSE README.md temp
[root@jenkins tomcat]# cd webapps/
[root@jenkins webapps]# wget http://mirrors.jenkins.io/war-stable/2.346.3/jenkins.war
[root@jenkins webapps]# cat /root/.jenkins/secrets/initialAdminPassword
715017e7cec84651a8f250c51b5a9709
[root@jenkins webapps]#
先在node1主机上生成一个密钥,传给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:5zBBVRwLvamfewOEoOkSW/pviOLUDSzGwaZHlZGPjvM root@jenkins.example.com
The key's randomart image is:
+---[RSA 3072]----+
| o+ ..o+o. |
| . .o .. .o. |
| = o o.. ..o |
| = oo = .. + |
|. =oo* S .o |
| ooo=o. =. . |
| .o.+.. .. o |
| .. E o . o o |
| ... o. .o . |
+----[SHA256]-----+
[root@jenkins ~]# ssh-copy-id -i ~/.ssh/id_rsa.pub root@192.168.64.134
/usr/bin/ssh-copy-id: INFO: Source of key(s) to be installed: "/root/.ssh/id_rsa.pub"
The authenticity of host '192.168.64.134 (192.168.64.134)' can't be established.
ECDSA key fingerprint is SHA256:vTa7Xf2qgLXK3hE60eo062dA59dZNTlyaHNn43dIUAE.
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
root@192.168.64.134's password:
Number of key(s) added: 1
Now try logging into the machine, with: "ssh 'root@192.168.64.134'"
and check to make sure that only the key(s) you wanted were added.
[root@jenkins ~]#
[root@jenkins ~]# ssh root@192.168.64.134
Activate the web console with: systemctl enable --now cockpit.socket
Last login: Fri Sep 30 13:21:52 2022 from 192.168.64.1
[root@node ~]# exit
logout
Connection to 192.168.64.134 closed.
[root@jenkins ~]#
在node2上部署tomcat
[root@node ~]# ls
anaconda-ks.cfg apache-tomcat-9.0.67.tar.gz
[root@node ~]# tar -xzf apache-tomcat-9.0.67.tar.gz -C /usr/local/
[root@node ~]# cd /usr/local/
[root@node local]# ls
apache-tomcat-9.0.67 etc include lib64 sbin src
bin games lib libexec share
[root@node local]# ln -s apache-tomcat-9.0.67/ tomcat
[root@node local]# ls tomcat/
bin CONTRIBUTING.md logs RELEASE-NOTES webapps
BUILDING.txt lib NOTICE RUNNING.txt work
在node1中配置jenkins
//创建任务
创建流水线任务
发布流水线的方法我在这里给大家介绍两种,一种是脚本的方式,一种是使用文本参数的方式
第一种方法:使用脚本
pipeline {
agent any
stages {
stage(‘pull code’) {
steps {
git ‘http://github.com/lizhenliang/tomcat-java-demo.git’
}
}
}
}
蓝色为正在构建
绿色为构建成功
也可以看构建日志
构建日志中记录这pull到哪里了
添加第二部分脚本执行
Stage(‘package’) {
Steps {
sh “”"
mvn clean
mvn package
“”"
}
}
再次进行构建–此时构建时间非常长
第二次构建就是为了安装软件包,生成站点,站点在/root/.jenkins/workspace/test/target/目录下,通过日志文件可以看到
该目录下就有个压缩文件为ly-simple-tomcat-0.0.1-SNAPSHOT.war
要是不成功也可以去虚拟机里使用 'mvn clean package’命令构建
第三次构建的时候,就是需要把这个文件使用scp的方式发送给node2的tomcat中
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 root@192.168.64.134:/usr/loc
al/tomcat/webapps/
ssh root@192.168.64.134 ‘/usr/local/tomcat/bin/catalina.sh stop && /usr/local/tomcat/bin/catalina.sh start’
“”"
}
}
}
}
通过日志文件,我们可以看到将站点发送到node2的tomcat中了
[root@node local]# cd tomcat/webapps/
[root@node webapps]# ls
docs ly-simple-tomcat-0.0.1-SNAPSHOT ROOT
examples ly-simple-tomcat-0.0.1-SNAPSHOT.war
host-manager manager
[root@node webapps]# pwd
/usr/local/tomcat/webapps
[root@node webapps]#
访问node2的tomcat
能够成功访问该页面,说明我们此次jenkins流水线项目部署成功
第二种方法呢,就是通过文本参数来实现流水线项目发布
为了实验效果呢,我们首先把node2中刚刚接收到的站点给删除掉
新建流水线项目test
添加文本参数
添加git下载信息 http://github.com/lizhenliang/tomcat-java-demo.git
添加字符参数,打包
添加字符参数 定义tomcat路径
添加文本参数 定义客户端ip
编写流水线脚本
pipeline {
agent any
stages {
stage(‘pull code’) {
steps {
git “KaTeX parse error: Expected 'EOF', got '}' at position 12: {git_url}" }̲ } stage(‘packa…{maven_package}.war root@
c
l
i
e
n
t
i
p
:
{client_ip}:
clientip:{tomcat_path}/webapps/
ssh root@
c
l
i
e
n
t
i
p
′
{client_ip} '
clientip′{tomcat_path}/bin/catalina.sh stop && ${tomcat_path}/bin/catalina.sh start’
“””
}
}
}
}
刚刚定义好的变量参数值
构建
[root@node webapps]# ls
docs ly-simple-tomcat-0.0.1-SNAPSHOT ROOT
examples ly-simple-tomcat-0.0.1-SNAPSHOT.war
host-manager manager
[root@node webapps]#
验证