Linux系统下Jenkins+码云持续集成环境搭建与配置

Linux上yum安装并配置Jenkins

在Red Hat系(如Red Hat Enterprise Linux(RHEL),CentOS,Fedora或Scientific Linux)上安装Jenkins(yum方式)。

前提条件

Jenkins依赖Jdk、Maven、Git, 在服务器上,首先配置 Jdk环境(注意版本兼容),Maven环境, 装好Git。

说明: 由于Gitlab 对内存要求太高, 我的云服务器是2G内存, 所以使用的是码云+Jenkins来实现持续集成。

附上Jenkins和Jdk的兼容关系:

  • 2.54(2017-04)和更新版本:Java 8
  • 1.612(2015-05)及更新版本:Java 7

安装

运行以下命令:

sudo wget -O /etc/yum.repos.d/jenkins.repo https://pkg.jenkins.io/redhat-stable/jenkins.repo
sudo rpm --import https://pkg.jenkins.io/redhat-stable/jenkins.io.key

如果你之前从Jenkins导入了密钥,则“rpm --import”将失败,因为你已经有了密钥。可以忽略它并继续前进。
接下来运行install命令安装:

yum install jenkins

启动/停止

sudo service jenkins start/stop/restart

设置允许开机启动

sudo chkconfig jenkins on

注意:

  • 如果收到以下错误消息,请确保已安装Java:

    Starting jenkins (via systemctl):  Job for jenkins.service failed. See 'systemctl status jenkins.service' and 'journalctl -xn' for details.
                                                               [FAILED]
    
  • 如果遇到以下问题:

    Starting Jenkins bash: /usr/bin/java: No such file or directory
                                                       [FAILED]
    

    解决方案:去 /etc/init.d/ 打开 jenkins 文件

    vim /etc/init.d/jenkins
    

    你会发现:

    candidates="
    /etc/alternatives/java
    /usr/lib/jvm/java-1.6.0/bin/java
    /usr/lib/jvm/jre-1.6.0/bin/java
    /usr/lib/jvm/java-1.7.0/bin/java
    /usr/lib/jvm/jre-1.7.0/bin/java
    /usr/lib/jvm/java-1.8.0/bin/java
    /usr/lib/jvm/jre-1.8.0/bin/java
    /usr/bin/java
    "
    

    这些是Jenkins查找java的路径,如果你安装的java不存在于上述任何路径中, 就需要在上面的Jenkins文件中添加该路径。

    candidates="
    你的jdk安装路径,如/home/java/jdk1.8.0_191/bin/java 
    /etc/alternatives/java
    /usr/lib/jvm/java-1.6.0/bin/java
    /usr/lib/jvm/jre-1.6.0/bin/java
    /usr/lib/jvm/java-1.7.0/bin/java
    /usr/lib/jvm/jre-1.7.0/bin/java
    /usr/lib/jvm/java-1.8.0/bin/java
    /usr/lib/jvm/jre-1.8.0/bin/java
    /usr/bin/java
    "
    

防火墙以及云服务器白名单

  • 修改防火墙允许8080端口访问(PS: 当然也可以直接永久关闭防火墙,一了百了 /奸笑)

    vim /etc/sysconfig/iptables
    
  • 加入

    -A INPUT -m state --state NEW -m tcp -p tcp --dport 8080 -j ACCEPT
    
  • 重启防火墙生效

    sudo service iptables restart
    
  • 如果使用是阿里云之类的云服务器, 需要在控制台添加安全组规则, 外网才能访问。

登录

  • 在浏览器中访问(我的访问路径是http://47.98.216.253:8080/,端口默认8080)

  • 首次进入会要求输入初始密码如下图,

  • 初始密码在:/var/lib/jenkins/secrets/initialAdminPassword

    Linux系统下Jenkins+码云持续集成环境搭建与配置_第1张图片
    首次登录
    Linux系统下Jenkins+码云持续集成环境搭建与配置_第2张图片
    默认安装
  • 选择“Install suggested plugins”安装默认的插件,下面Jenkins就会自己去下载相关的插件进行安装。

    Linux系统下Jenkins+码云持续集成环境搭建与配置_第3张图片
    自动安装插件
  • 安装完成之后, 创建管理员账号, 配置项目访问的根路径, 然后完成。让我们登录进来看看:

    Linux系统下Jenkins+码云持续集成环境搭建与配置_第4张图片
    Jenkins主页

配置Jenkins实现持续集成

  • 安装插件
  • 进入菜单"系统管理"-->"插件管理"-->"Installed"


    Linux系统下Jenkins+码云持续集成环境搭建与配置_第5张图片
    安装插件
  • 配置Jdk, Maven, Git

    • 进入菜单"系统管理" --> "全局工具配置"


      Linux系统下Jenkins+码云持续集成环境搭建与配置_第6张图片
      全局工具配置

      Linux系统下Jenkins+码云持续集成环境搭建与配置_第7张图片
      全局工具配置
  • 新建项目


    Linux系统下Jenkins+码云持续集成环境搭建与配置_第8张图片
    新建一个maven项目
  • 跳转项目配置页(配置过程中如果缺少插件需要去安装,可点击"Apply"按钮保存已输入的配置信息)


    Linux系统下Jenkins+码云持续集成环境搭建与配置_第9张图片
    项目配置

    这里也可以通过主页点击项目名,然后选择"配置"来进入此页面

  • 配置流程 "general" --> "Source Code Management(源码管理)" --> "Build Triggers(构建触发器)" --> "build" --> "Post-build Actions(构建后操作)"


    Linux系统下Jenkins+码云持续集成环境搭建与配置_第10张图片
    general

    源码管理说明: 配置你的码云项目所在的地址和邮箱以及私钥(通过旁边的add添加,下面放图)


    Linux系统下Jenkins+码云持续集成环境搭建与配置_第11张图片
    源码管理

    Linux系统下Jenkins+码云持续集成环境搭建与配置_第12张图片
    添加凭据

    构建触发器说明: 这一栏选择Gitee webhook打钩(若没有说明没有安装码云的插件), 下面提示一个URL需要用到(关联码云项目的),另外点击"生成"按钮生成的密码也会在关联码云时用到。
    Linux系统下Jenkins+码云持续集成环境搭建与配置_第13张图片
    构建触发器

    如图,关联码云项目,点击添加按钮,填写上图中的url和生成的密码


    Linux系统下Jenkins+码云持续集成环境搭建与配置_第14张图片
    码云WebHooks

    设置仅在build成功的时候运行
    Linux系统下Jenkins+码云持续集成环境搭建与配置_第15张图片
    仅在build成功时运行

    构建后操作:
    Linux系统下Jenkins+码云持续集成环境搭建与配置_第16张图片
    构建后操作

    如果看不到下面这个选项,说明你没有安装"Deploy to container"插件:
    Linux系统下Jenkins+码云持续集成环境搭建与配置_第17张图片
    构建后操作

    因为需要自动构建然后部署到tomcat, 所以要提供拥有足够权限的角色(账号密码),来操作tomcat部署war包; 进入到tomcat的conf文件夹下打开tomcat-user.xml,然后加上角色(username,password可以随意,其它的照写,加到标签内)
    tomcat-user.xml

    另外, tomcat8 (包含) 以上, 还需要修改tomcat下的webapps/manager/META-INF/context.xml文件,如图:


    webapps/manager/META-INF/context.xml

    然后配置上最后的tomcat,大功告成:
    Linux系统下Jenkins+码云持续集成环境搭建与配置_第18张图片
    构建后操作

走到这一步,恭喜你,可以把项目构建起来,然后码云push代码测试一下了

你可能感兴趣的:(Linux系统下Jenkins+码云持续集成环境搭建与配置)