jenkins+私服maven+私服gitlab(nexus)构

2021-08-15  本文已影响0人  wangjl_jimmy

前言:本文章讲述搭建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>

上一篇下一篇

猜你喜欢

热点阅读