jenkins+私服maven+私服gitlab(nexus)构
前言:本文章讲述搭建maven和gitlab私服,以及和jenkins整合起来搭建devops平台,最终实现直接打包分发到各服务器上并运行。
一.安装包软件(linux环境):
maven(nexus):nexus-3.28.0-01-unix.tar.gz;服务器ip为:192.168.115.135
gitlab:gitlab-ce-10.0.0-ce.0.el7.x86_64.rpm;服务器ip为:192.168.115.134
jenkins: jenkins.war (2.289.3 LTS);服务器ip为:192.168.115.136
二.安装部署
2.1 maven安装部署:
tar -zxvf nexus-3.28.0-01-unix.tar.gz
因为使用root命令启动maven时会提示不能使用root用户,因此需要修改nexus-3.28.0-01/bin目录下的nexus文件,修改如下:
root_as_user=root
run_as_root=false
启动maven:nexus-3.28.0-01/bin/nexus start
启动会比较慢,在完全启动后在浏览器中输入:http://192.168.115.135:8081/打开maven管理后端,截图如下:
使用默认的用户名密码登录:
用户名为:admin,密码位于sonatype-work目录下admin.password中
登录成功后配置私服maven对应的外网阿里云maven仓库地址:
2.2 gitlab安装部署:
使用rpm命令安装gitlab安装包
rpm -ivh gitlab-ce-10.0.0-ce.0.el7.x86_64.rpm
安装完成后需要将url访问的地址修改为本机ip地址,配置地址为/etc/gitlab/gitlab.rb文件中,gitlab默认端口为8081,此处我将端口号修改为了8091:
修改完gitlab配置后需要重启gitlab生效(重启会花费较多时间),重启命令为:/opt/gitlab/bin/gitlab-ctl start
重启成功后访问gitlab的url地址(如果在启动过程中则提示502错误):
gitlab访问地址为:http://192.168.115.134:8091/
使用管理员账号登录gitlab,默认用户名为root,密码为安装过程中配置的密码。管理员可以添加用户和配置ssh秘钥等信息(后面在jenkins配置中会用到)
2.3 jenkins安装部署:
使用nohup jar -jar命令将jenkins启动起来,启动命令如下:
nohup java -jar jenkins.war &
启动成功后通过浏览器访问jenkins页面:
登录密码为自己设定的密码,用户名默认为admin
2.3.1 安装插件plugins:
需要安装的插件为GitLab Plugin,Maven Integration plugin,Publish Over SSH.操作如下:
以上三个软件都一样的操作,安装插件完成后需要重启jenkins,安装会花费较多时间,有时候会出现安装其实成功了,但是前面界面卡顿但是linux后端日志已经表示安装和重启成功了,此时可以刷新页面查看插件是否安装成功。
2.3.2 配置插件:
在jenkins上配置git和maven,截图如下:
2.3.2.1.maven插件配置:
该配置需要在jenkins部署的linux服务器上面配置apache-maven,我使用的apache-maven-3.8.1-bin.tar.gz安装包,仅需要将该安装包解压即可,解压命令为:
tar -zxvf apache-maven-3.8.1-bin.tar.gz,
并且将解压后的文件夹中的setting.xml进行修改,修改为连接之前安装的maven私服地址,setting.xml配置可以参考附录setting.xml:
2.3.2.2.git插件配置:
该配置需要先到部署jenkins的linux服务器上安装git(如果可以访问外网使用yum install git即可,在安装过程中提示缺少什么就安装什么),git安装完成后git命令所在的目录为/usr/bin/git.
2.3.2.3 将jenkins服务器ssh免密方式推送打包(如jar包)文件到对应服务器上的免密配置
首先:需要在部署jenkins的linux服务器上面生成私钥和公钥,生成私钥和公钥命令为:
ssh-keygen -t rsa
生成的私钥和公钥地址位于/root/.ssh/下,如果不是使用root命令操作的私钥和公钥的地址可能不一样。
将生成的公钥id_rsa.pub发送到对应运行系统(如jar文件)的服务器的authorized_keys中,操作命令如下:
ssh-copy-id -p 22 -i ~/.ssh/id_rsa.pub root@192.168.115.134
# 然后会让输入密码
操作完成后可以在192.168.115.134服务器的/root/.ssh/authorized_keys文件中看到192.168.115.136服务器的公钥id_rsa.pub信息。在192.168.115.136服务器上通过ssh
192.168.115.134命令如果可以免密跳转到192.168.115.134服务器上则表示配置成功。
其次:在jenkins上配置ssh免密登录信息,截图如下:
最后配置需要免密接收系统(如jar系统)的服务器信息:
三.jenkins新建任务(job)
1.登录jenins中台,按照以下截图添加任务:
在gitlab上生成access token操作如下:
在gitlab上生成的access token后,再到jenkins中新建任务的gitlab的部分通过"添加"按钮完成添加,添加完成并在credentials选择后不会再报错,配置正常后显示如下:
配置需要打包的gitlab分支(branch)名称(根据自己需要填写分支名称):
添加打包前的操作,将保存jenkins打包后的jar文件保存目录下部分文件删除(根据自己需要去配置,我是因为后面自动在对应的系统上直接启动打包后的jar文件需要才如此操作)
添加打包后的处理操作(将打包好的jar文件名称修改为加上.#45(45为构造id,通过系统变量build_display_name获取),在此处修改文件名称也是为了后面在对应的服务器上自动启动jar文件做准备,大家可以根据自己的需求去选择是否需要):
添加通过ssh免密将打包好的文件(如jar)发送到对应的服务器上并且启动运行:
最后保存后并且启动对应的任务即可:
下面举一个启动任务的例子,截图如下:
启动后在该页面的左下角会出现进度:
点击上图中红色框部分会出现下图中内容:
继续点击上图中左下角任务会显示以下视图:
最后看上图中右边的日志查看是否打包成功,并且可以到对应的服务器上查看系统(jar文件)是否正常运行:
附录:
setting.xml:
<?xml version="1.0" encoding="UTF-8"?>
<settings xmlns="http://maven.apache.org/SETTINGS/1.2.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.2.0 http://maven.apache.org/xsd/settings-1.2.0.xsd">
<pluginGroups>
</pluginGroups>
<proxies>
</proxies>
<servers>
<server>
<id>default</id>
<username>admin</username>
<password>maven系统的密码</password>
</server>
</servers>
<mirrors>
<mirror>
<id>default</id>
<mirrorOf>*</mirrorOf>
<url>http://192.168.115.135:8081/repository/maven-public/</url>
</mirror>
</mirrors>
<profiles>
<profile>
<id>default</id>
<repositories>
<repository>
<id>public</id>
<url>http://192.168.115.135:8081/repository/maven-public/</url>
<releases>
<enabled>true</enabled>
</releases>
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>
</repositories>
</profile>
</profiles>
<activeProfiles>
<activeProfile>default</activeProfile>
</activeProfiles>
</settings>