jenkins自动发布java代码

时间:2023-12-24 16:41:19

注:本文来源于《KaliArch

jenkins笔记

一、相关概念

1.1 Jenkins概念:

Jenkins是一个功能强大的应用程序,允许持续集成和持续交付项目,无论用的是什么平台。这是一个免费的源代码,可以处理任何类型的构建或持续集成。集成Jenkins可以用于一些测试和部署技术。Jenkins是一种软件允许持续集成。

1.2 Jenkins目的:

1、持续、自动地构建/测试软件项目。
2、监控软件开放流程,快速问题定位及处理,提示开放效率。

1.3 特性:

开源的java语言开发持续集成工具,支持CI,CD。
易于安装部署配置:可通过yum安装,或下载war包以及通过docker容器等快速实现安装部署,可方便web界面配置管理。
消息通知及测试报告:集成RSS/E-mail通过RSS发布构建结果或当构建完成时通过e-mail通知,生成JUnit/TestNG测试报告。
分布式构建:支持Jenkins能够让多台计算机一起构建/测试。
文件识别:Jenkins能够跟踪哪次构建生成哪些jar,哪次构建使用哪个版本的jar等。
丰富的插件支持:支持扩展插件,你可以开发适合自己团队使用的工具,如git,svn,maven,docker等。

1.4 产品发布流程:

产品设计成型 -> 开发人员开发代码 -> 测试人员测试功能 -> 运维人员发布上线
持续集成
(Continuous integration,简称CI)
持续交付(Continuous
delivery)
持续部署(continuous
deployment)

二、安装部署

2.1 yum安装

最低配置: 不少于256M内存,不低于1G磁盘,jdk版本>=8
安装jdk1.8

yum install -y java-1.8.0-openjdk && \
wget -O /etc/yum.repos.d/jenkins.repo https://pkg.jenkins.io/redhat/jenkins.repo && \
rpm --import https://pkg.jenkins.io/redhat/jenkins.io.key &&\
yum clean all && yum makecache && \
yum install -y jenkins && \
systemctl start jenkins

less /var/log/jenkins/jenkins.log //查询admin密码
访问 http://ip:8080/ 进行安装
jenkins相关目录:
rpm -ql jenkins #查看jenkins安装相关目录
安装目录/var/lib/jenkins
配置文件
/etc/sysconfig/jenkins
日志目录
/var/log/jenkins

2.2 下载war包安装

yum install -y java-1.8.0-openjdk && mkdir -p /usr/local/jenkins/ && \
wget -c -O /usr/local/jenkins/jenkins.war http://mirrors.jenkins.io/war-stable/latest/jenkins.war &&\
nohup java -jar /usr/local/jenkins/jenkins.war &

密码查看:/root/.jenkins/secrets/initialAdminPassword
访问 http://ip:8080/ 进行安装

2.3 docker形式安装

yum install docker -y  && systemctl start docker && \
curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | sh -s && systemctl restart docker
docker search jenkins
docker pull docker.io/jenkins
docker run -d -p 8080:8080 docker.io/jenkins

docker exec -it 52873fa3dce4
/bin/bash

cat
/var/jenkins_home/secrets
 #查看密码
访问 http://ip:8080/ 进行安装

2.4 相关工具安装

工具安装可在jenkins的web界面系统管理---管理插件---可选插件勾选需要的,也可以手动安装。

a.git安装

yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel gcc-c++ perl-ExtUtils-MakeMaker wget autoconf -y
wget https://www.kernel.org/pub/software/scm/git/git-2.7.3.tar.gz
tar xf git-2.7.3.tar.gz
cd git-2.7.3
make configure
./configure --prefix=/usr/local/git
make profix=/usr/local/git
make install
echo "export PATH=$PATH:/usr/local/git/bin" > /etc/profile.d/git.sh
source /etc/profile.d/git.sh

b.maven安装

cd /usr/local/ && wget -c wget  http://mirror.bit.edu.cn/apache/maven/maven-3/3.5.2/binaries/apache-maven-3.5.2-bin.tar.gz &&\
tar -zxf apache-maven-3.5.2-bin.tar.gz && \
echo "export PATH=$PATH:/usr/local/apache-maven-3.5.2/bin" > /etc/profile.d/maven.sh && \
source /etc/profile.d/maven.sh

mvn --version 查看版本

c.svn安装

yum install subversion -y
mkdir /svnrepo
svnadmin create /svnrepo/project1 #创建一个新的Subversion项目

jenkins自动发布java代码
jenkins自动发布java代码
jenkins自动发布java代码
启动项目1:svnserve -d -r /svnrepo/project1/
启动整个项目:svnserve -d -r /svnrepo/

d.jdk安装

某些情况下会遇到openjdk无法编译java程序,或在编译中存在异常,需要我们手动安装jdk,首先去Oracle官网下载对应版本的jdk

tar -zxvf jdk-8u121-linux-x64.gz -C /usr/local && \
ln -sv /usr/local/jdk1.8.0_121 /usr/local/jdk1.8 && \
echo "export PATH=$PATH:/usr/local/jdk1.8/bin" >/etc/profile.d/java.sh
source /etc/profile.d/java.sh

三、WEB界面配置

3.1 密码破解

 cd /var/lib/jenkins/users/admin          #此为admin用户的目录,也可以对应自己创建的用户
vim config.xml //定位到<passwordHash>那一行
删除改行,改为
<passwordHash>#jbcrypt:$2a$10$pDQks0ytOkCfmpdgpLygrOC3uY7i/XnZHBKRQDhrBPwKoN2f5Kz8C</passwordHash>

重启一下jenkins
新密码为admin

3.2 maven配置

针对之前手动安装的maven需要在web界面配置进行结合。
系统管理---全局工具配置(Maven
Configuration)配置:
jenkins自动发布java代码
此处为手动安装的maven,需要取消自动安装maven,name可以自定义,MAVEN_HOME指定下载安装的maven具体文件目录
jenkins自动发布java代码

3.3 GIT配置

手动安装的git,web界面只需添加具体可执行路径即可
jenkins自动发布java代码

3.4 jdk配置

对应手动安装的jdk,需要web配置java_home路径
jenkins自动发布java代码

3.5 邮件配置

jenkins有内置的邮件功能但由于其对于成功的发布不会发送邮件可定制化程度低,在此直接配置插件邮件(Editable
Email
Notification),2.32以上版本的jenkins,常用的插件都已经在最初部署的时候安装了(如果你当初选择的是suggest的plugins)。
可以使用qq邮件服务器或163等其他邮件服务器,在此配置使用163邮箱,首先需要开启163邮箱的smtp服务。
jenkins自动发布java代码
需要记录此处开启smtp时的密码。
在jenkins
系统管理---系统设置---Extended E-mail Notification
jenkins自动发布java代码
在默认的触发器
Default Triggers
标签下,可以勾选邮件通知触发的情况,如任何情况下均需要选择always,也可以在仅失败情况下发送,也可以对应的邮件接受人不通,进行邮件分类。
以下的内容,如邮件主题,内容均可自定义,可以参考url:
至此全局插件邮件已经配置完毕,需要在具体的项目中使用此邮件进行发送通知。

四、实战php程序自动发布

4.1 插件安装

系统管理---管理插件---已安装
检查是否有“Git
plugin”和“Publish Over SSH”两个插件,如果没有,则需点击“可选插件”,找到它并安装
安装好两个插件后,点击“系统管理”--
“系统设置”

4.2 SSH配置

系统管理---系统设置---Publish over SSH
在key内填写jenkins服务器的私钥,如果没有需要先在jenkins服务器生成私钥与公钥。ssh-keygen -t rsa回车后会在登录用户的家目录下生成一个.ssh
的目录,此目录下存在id_rsa私钥与id_rsa.pub公钥。且讲公钥发布至代码发布的目标服务器上ssh-copy-id -i /root/.ssh/id_rsa.pub
root@IP

SSH Server配置
name:需要将php程序发布到目标服务器的名称,可自定义
Hostname:填写目录服务器的IP地址
Username:使用那个用户进行发布,此处为进行密钥互信的用户
Remote
Directory:此出为发布到目标服务器的相对根路径,建议填写/,防止后续填写路径异常。
jenkins自动发布java代码
注:如果为多台目标服务器,可以继续添加,如果目标服务器存在代理,也可设置proxy

4.3 构建项目

新建Item---填入项目名称---选择构建一个*风格的软件项目---确定
源码管理选择git
Repository
URL
填写具体git上的仓库url,如果为私有,需要继续添加Credentials,如果为公有直接填写url即可,Credentials为none,

构建后够操作
选择(Send
files or execute commands over SSH)
SSH
Server选择目标服务器如:php-server
Source
files:/ #将git拉去下来的原始文件
Remote
directory:/var/www/html #发布到目标服务器的制定目录
Exec
command:chown apache:apache -R /var/www/html/* #制定后续的操作
jenkins自动发布java代码

此时可以选择Editable Email Notification来构建邮件通知。
在此处,之前的邮件主题,内容均可以自定义,在高级里面,选择邮件接受人。
jenkins自动发布java代码

点击保存,并立即构建,可以点击console output查看日志
jenkins自动发布java代码
jenkins自动发布java代码
此时打开php程序发现程序文件已经成功发布到目标服务器上
jenkins自动发布java代码
此时可以查看邮件也已经发送成功。
jenkins自动发布java代码

©著作权归作者所有:来自51CTO博客作者KaliArch的原创作品,如需转载,请注明出处,否则将追究法律责任

jenkins自动发布java代码

jenkins笔记(1)进行实战java代码发布,此利用github私有仓库拉去,jenkins利用maven编译源码后讲包发布致web服务器。

一、git私有仓库创建

可参考GIT笔记中远程仓库搭建部分,此处java源码使用zrlog,将源码pull到github上,将jenkins公钥配置到github上,即可下一波。

二、web服务器tomcat配置

在需要将代码发布的web服务器上需要配置tomcat的manager页面。

yum install java-1.8.0-openjdk.x86_64 -y && \
wget -c -O /usr/local/apache-tomcat-9.0.2.tar.gz && \ http://mirrors.tuna.tsinghua.edu.cn/apache/tomcat/tomcat-9/v9.0.2/bin/apache-tomcat-9.0.2.tar.gz && \
cd /usr/local/ && tar -xf apache-tomcat-9.0.2.tar.gz &&\
  • 1
  • 2
  • 3

此时tomcat已经安装成功,需要配置manager页面。

需要在/usr/local/tomcat/conf/tomcat-users.xml 添加以下内容。

<role rolename="admin"/>
<role rolename="admin-gui"/>
<role rolename="admin-script"/>
<role rolename="manager"/>
<role rolename="manager-gui"/>
<role rolename="manager-script"/>
<role rolename="manager-jmx"/>
<role rolename="manager-status"/>
<user name="admin" password="kaliarch" roles="admin,manager,admin-gui,admin-script,manager-gui,manager-script,manager-jmx,manager-status" />
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

jenkins自动发布java代码

修改完毕如上图,添加manager的role角色权限,其次需要修改manger页面的源控访问,添加jenkins的ip为白名单内。

修改/usr/local/tomcat/webapps/manager/META-INF/context.xml

默认tomcat的manager页面只允许本地的和ipv6的地址,此处我的jenkins服务器ip为:172.20.6.0/24,可根据实际情况来定,支持网段,不要开放全部开放0.0.0.0,以防黑客入侵。

jenkins自动发布java代码

配置完成后需要启动tomcat/usr/local/tomcat/bin/startup.sh

此时,我们可以进行测试web服务器的tomcatmanager界面,http://IP:8080/manager/index.html

填写配置文件内的用户名:admin,密码:kaliarch
jenkins自动发布java代码

三、创建发布项目

发布java,需要安装两个插件,Maven
Integration plugin 和 Deploy to container Plugin,若没有安装则需要安装这两个插件
安装完插件后,需要重启jenkins。

3.1 新建item

输入项目名称,选择构建一个maven项目,确定。

jenkins自动发布java代码

3.2 配置源码管理

源码管理选择git,填入仓库url

jenkins自动发布java代码
此时发现会出现报错信息,因为此仓库为我的私有仓库,需要配置Credentials,点开add,
Add Credentials的 Kind选择SSH Username with private
key,Username选择之前在github上传的公钥用户的用户名,此次为root,Private
Key为jenkins服务器登录github的本地私钥,查看私钥cat /root/.ssh/id_rsa
复制粘贴到Key区域,完成添加。此时可以发现报错已经消失。
jenkins自动发布java代码

3.3 配置发布到web服务器

添加增加构建后操作,选择Deploy
war/ear to a container,WAR/EAR
files填写**/*.war,Containers选择增加容器,增加tomcat
8.x,Credentials点add,此处填写的为tomcat的manager页面的用户名密码,此处为admin/kaliarch,
jenkins自动发布java代码
tomcat url填写web服务器的tomcaturl,
jenkins自动发布java代码

3.4 配置邮件信息通知

添加增加构建后操作,选择Editable
Email Notification,利用插件邮件来发送通知。

可以根据需求自定义邮件主题与内容,此处添加信息接受人,由于全局配置了always,在高级设置内,填写接受人邮箱。
jenkins自动发布java代码

3.5 信息查看

点击保存,并立即构建,可以查看日志信息。

jenkins自动发布java代码

登录web服务器,查看war包已经发布完成。

jenkins自动发布java代码
打开web页面进行测试。
jenkins自动发布java代码

查看邮件通知。

jenkins自动发布java代码

至此,java程序已经完成发布,之后修改代码后可以提交到github,然后通过jenkins自动发布即可。

--------------------- 本文来自 KaliArch 的CSDN 博客
,全文地址请点击:https://blog.csdn.net/qq_26848099/article/details/79400753?utm_source=copy

==============================