Linux 系统Jenkins安装

1、背景

为什么要用Jenkins?

  1. 比自己写脚本方便,不用关心边边角角,只需添加核心编译脚本,节约开发人员注意力和精力
  2. 可以让不懂相关开发的测试或项目经理来生成版本,保证源码的完整性。
    比如:由于项目需要,找了外包人员,在谈妥交源码后,平时的软件版本是由外包人员生成测试,并且验收通过后,最终交源码的时候,外包人员可能会觉得你们没有相关技术人员,随便删除一些核心代码。或者是离职程序员隐藏不提交代码直接跑路(你的带队方式比版本管理更需要改变)。用了Jenkins之后,版本是从代码仓库git或svn拉取,从源码生成软件版本,至少保证了源码的完整性。严重声明:这样并不能杜绝程序员留后门或者留坑
  3. 支持android、ios、以及服务器应用程序(包括但不限于javaweb的war)的打包(经过确认ios打包需要xcode,而xcode除了mac系统外是无法安装的,所以不会介绍ios的打包过程)

2、安装

下载最新的centos下安装包,下载地址安装文档
注:需要依赖jdk1.8,这里不再赘述。

[root@centos]# rpm -ih jenkins-2.150.3-1.1.noarch.rpm

 

警告:jenkins-2.150.3-1.1.noarch.rpm: 头V4 DSA/SHA1 Signature, 密钥 ID d50582e6: NOKEY
################################# [100%]
正在升级/安装...
################################# [100%]

安装成功之后,一些主要文件目录:
/usr/lib/jenkins/jenkins.war
/etc/sysconfig/jenkins 配置文件
/var/log/jenkins/jenkins.log 日志文件

修改配置文件
[root@centos]# vim /etc/sysconfig/jenkins

 

#修改端口,默认8080
JENKINS_PORT="8088"

启动
[root@centos]# systemctl restart jenkins

 

Job for jenkins.service failed because the control process exited
 with error code. See "systemctl status jenkins.service" and 
"journalctl -xe" for details.

启动失败,查看原因
[root@centos]# systemctl status -l jenkins.service

 

● jenkins.service - LSB: Jenkins Automation Server
   Loaded: loaded (/etc/rc.d/init.d/jenkins; bad; vendor preset: disabled)
   Active: failed (Result: exit-code) since 一 2019-02-18 16:06:22 CST; 1min 4s ago
     Docs: man:systemd-sysv-generator(8)
  Process: 8477 ExecStart=/etc/rc.d/init.d/jenkins start (code=exited, status=1/FAILURE)

2月 18 16:06:22 localhost.localdomain systemd[1]: Starting LSB: Jenkins Automation Server...
2月 18 16:06:22 localhost.localdomain runuser[8482]: pam_unix(runuser:session): session opened for user root by (uid=0)
2月 18 16:06:22 localhost.localdomain jenkins[8477]: Starting Jenkins bash: /usr/bin/java: 没有那个文件或目录
2月 18 16:06:22 localhost.localdomain runuser[8482]: pam_unix(runuser:session): session closed for user root
2月 18 16:06:22 localhost.localdomain jenkins[8477]: [失败]
2月 18 16:06:22 localhost.localdomain systemd[1]: jenkins.service: control process exited, code=exited status=1
2月 18 16:06:22 localhost.localdomain systemd[1]: Failed to start LSB: Jenkins Automation Server.
2月 18 16:06:22 localhost.localdomain systemd[1]: Unit jenkins.service entered failed state.
2月 18 16:06:22 localhost.localdomain systemd[1]: jenkins.service failed.

Jenkins bash: /usr/bin/java: 没有那个文件或目录
因为我安装jdk的目录不是默认的目录,所以需要修改配置文件。

查找java安装目录
[root@centos]# whereis java

 

java: 
/usr/lib/java 
/etc/java 
/usr/share/java 
/usr/java/jdk1.8.0_161/bin/java
/usr/java/jdk1.8.0_161/jre/bin/java

[root@centos]# vim /etc/rc.d/init.d/jenkins
这里的修改方式是错误的,正确的修改方式见下文

 

#源文件
candidates="
/etc/alternatives/java
/usr/lib/jvm/java-1.8.0/bin/java
/usr/lib/jvm/jre-1.8.0/bin/java
/usr/lib/jvm/java-1.7.0/bin/java
/usr/lib/jvm/jre-1.7.0/bin/java
/usr/bin/java
"
#修改后
candidates="
/usr/lib/java 
/etc/java 
/usr/share/java 
/usr/java/jdk1.8.0_161/bin/java
/usr/java/jdk1.8.0_161/jre/bin/java
"

[root@centos]# systemctl restart jenkins

 

Warning: jenkins.service changed on disk. Run 'systemctl daemon-reload' to reload units.
Job for jenkins.service failed because the control process exited with error code. See "systemctl status jenkins.service" and "journalctl -xe" for details.

按照提示reload一下
[root@centos]# systemctl daemon-reload
重启
[root@centos]# systemctl restart jenkins
又失败,查看原因
[root@centos]# systemctl status -l jenkins.service

 

● jenkins.service - LSB: Jenkins Automation Server
   Loaded: loaded (/etc/rc.d/init.d/jenkins; bad; vendor preset: disabled)
   Active: failed (Result: exit-code) since 一 2019-02-18 16:25:58 CST; 1min 53s ago
     Docs: man:systemd-sysv-generator(8)
  Process: 9103 ExecStart=/etc/rc.d/init.d/jenkins start (code=exited, status=1/FAILURE)

2月 18 16:25:58 localhost.localdomain systemd[1]: Starting LSB: Jenkins Automation Server...
2月 18 16:25:58 localhost.localdomain runuser[9108]: pam_unix(runuser:session): session opened for user jenkins by (uid=0)
2月 18 16:25:58 localhost.localdomain jenkins[9103]: Starting Jenkins bash: /usr/lib/java: 是一个目录
2月 18 16:25:58 localhost.localdomain runuser[9108]: pam_unix(runuser:session): session closed for user jenkins
2月 18 16:25:58 localhost.localdomain jenkins[9103]: [失败]
2月 18 16:25:58 localhost.localdomain systemd[1]: jenkins.service: control process exited, code=exited status=1
2月 18 16:25:58 localhost.localdomain systemd[1]: Failed to start LSB: Jenkins Automation Server.
2月 18 16:25:58 localhost.localdomain systemd[1]: Unit jenkins.service entered failed state.
2月 18 16:25:58 localhost.localdomain systemd[1]: jenkins.service failed.

Starting Jenkins bash: /usr/lib/java: 是一个目录
这个深坑浪费我半小时,一开始还以为是一个目录代表修改成功了,活活被自己蠢哭。

查看了/usr/lib/java发现真的是个空目录,还得修改配置文件,把所有非真实java路径目录都删除,只留2个真实地址
[root@centos]# vim /etc/rc.d/init.d/jenkins

 

#第1次修改后
candidates="
/usr/lib/java 
/etc/java 
/usr/share/java 
/usr/java/jdk1.8.0_161/bin/java
/usr/java/jdk1.8.0_161/jre/bin/java
"
#第2次修改后
candidates="
/usr/java/jdk1.8.0_161/bin/java
/usr/java/jdk1.8.0_161/jre/bin/java
"

[root@centos]# systemctl daemon-reload
[root@centos]# systemctl restart jenkins
 

设置开机启动
[root@centos]# systemctl enable jenkins
开放端口
[root@centos]# firewall-cmd --permanent --add-port=8088/tcp
[root@centos]# firewall-cmd --reload

浏览器访问(换成本机IP) http://192.168.1.91:8088

 

复制密码到浏览器框里
[root@centos]# cat /var/lib/jenkins/secrets/initialAdminPassword

一直默认选项直到设置完管理员账号密码。



作者:我已不是少年郎
链接:https://www.jianshu.com/p/ed73f1f07682
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

Guess you like

Origin blog.csdn.net/weixin_41585557/article/details/103977607