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
首次登录 默认安装 -
选择“Install suggested plugins”安装默认的插件,下面Jenkins就会自己去下载相关的插件进行安装。
自动安装插件 -
安装完成之后, 创建管理员账号, 配置项目访问的根路径, 然后完成。让我们登录进来看看:
Jenkins主页
配置Jenkins实现持续集成
- 安装插件
-
进入菜单"系统管理"-->"插件管理"-->"Installed"
安装插件
-
配置Jdk, Maven, Git
-
进入菜单"系统管理" --> "全局工具配置"
全局工具配置
全局工具配置
-
-
新建项目
新建一个maven项目 -
跳转项目配置页(配置过程中如果缺少插件需要去安装,可点击"Apply"按钮保存已输入的配置信息)
项目配置
这里也可以通过主页点击项目名,然后选择"配置"来进入此页面
-
配置流程 "general" --> "Source Code Management(源码管理)" --> "Build Triggers(构建触发器)" --> "build" --> "Post-build Actions(构建后操作)"
general
源码管理说明: 配置你的码云项目所在的地址和邮箱以及私钥(通过旁边的add添加,下面放图)
源码管理
添加凭据
构建触发器说明: 这一栏选择Gitee webhook打钩(若没有说明没有安装码云的插件), 下面提示一个URL需要用到(关联码云项目的),另外点击"生成"按钮生成的密码也会在关联码云时用到。
构建触发器
如图,关联码云项目,点击添加按钮,填写上图中的url和生成的密码
码云WebHooks
设置仅在build成功的时候运行
仅在build成功时运行
构建后操作:
构建后操作
如果看不到下面这个选项,说明你没有安装"Deploy to container"插件:
构建后操作
因为需要自动构建然后部署到tomcat, 所以要提供拥有足够权限的角色(账号密码),来操作tomcat部署war包; 进入到tomcat的conf文件夹下打开tomcat-user.xml,然后加上角色(username,password可以随意,其它的照写,加到<tomcat-user>标签内)
tomcat-user.xml
另外, tomcat8 (包含) 以上, 还需要修改tomcat下的webapps/manager/META-INF/context.xml文件,如图:
webapps/manager/META-INF/context.xml
然后配置上最后的tomcat,大功告成:
构建后操作