介绍
构建伟大,无所不能 -- Jenkins
Jenkins是开源CI&CD软件领导者, 提供超过1000个插件来支持构建、部署、自动化, 满足任何项目的需要。
最近入职新公司,出于项目需要,亟需搭建一套CI&CD的环境。虽然在之前公司也搭建过Jenkins的环境,但是由于公司背景不同,我们在服务器上的权限很低,搭建过程异常艰辛。 现在,且看拥有绝对权限的男人是如何搭建Jenkins的。
环境
Jenkins
Server: ubuntu 18
构建Server: ubuntu 18
详细教程
第1步 - 安装JDK1.8
oracle官网下载压缩包,点击链接。
2.解压
1 tar -zxvf jdk-8u171-linux-x64.tar.gz
3.移动到制定目录
1##将文件从下载目录 挪到/usr/local下2sudo mv jdk1.8.0_171 /usr/local/jdk1.8
4.设置环境变量
<code>vim /etc/profile</code>
在文件末尾加入
1export JAVA_HOME=/usr/local/jdk1.82export JRE_HOME=${JAVA_HOME}/jre3export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib4export PATH=.:${JAVA_HOME}/bin:$PATH
如果显示无法保存修改命令
1sudo vim /etc/profile
5.使配置生效
1source /etc/profile
6.检查是否生效
1 java -version
第2步 - 安装Jenkins
包含在默认Ubuntu软件包中的Jenkins版本往往落后于项目本身的最新版本。 为了利用最新的修复和功能,我们将使用项目维护的软件包来安装Jenkins。
首先,我们将存储库密钥添加到系统。
wget-q-O-https://pkg.jenkins.io/debian/jenkins-ci.org.key|sudo apt-key add-
添加密钥后,系统将返回OK。 接下来,我们将Debian包存储库地址附加到服务器的sources.list:
echodeb http://pkg.jenkins.io/debian-stable binary/ | sudo tee /etc/apt/sources.list.d/jenkins.list
当这两个都到位时,我们将运行update,以便apt-get将使用新的存储库:
sudo apt-getupdate
最后,我们将安装Jenkins及其依赖项,包括Java:
sudo apt-getinstall jenkins
以上安装不成功的朋友,是由于Jenkins官网的校验码出现了问题。
指定早期版本可以安装。
sudo apt-getinstall jenkins=2.138.1
现在Jenkins及其依赖项已经到位,我们将启动Jenkins服务器。
第2步 - 开始Jenkins
使用systemctl我们将启动Jenkins:
sudo systemctl start jenkins
由于systemctl不显示输出,我们将使用其status命令来验证它是否成功启动:
sudo systemctl status jenkins
如果一切顺利,输出的开始应显示服务处于活动状态,并配置为启动时启动:
● jenkins.service-LSB:Start Jenkins at boot time Loaded:loaded(/etc/init.d/jenkins;bad;vendor preset:enabled)Active:active(exited)since Thu2017-04-2016:51:13UTC;2min7s ago Docs:man:systemd-sysv-generator(8)
现在Jenkins正在运行,我们将调整防火墙规则,以便我们可以从网络浏览器到达Jenkins以完成初始设置。
第3步 - 打开防火墙
默认情况下,Jenkins在端口8080上运行,因此我们将使用ufw打开该端口:
sudo ufw allow 8080
检查UFW的状态可以看到新的规则。
sudo ufw status
我们应该看到,从任何地方都可以访问8080端口:
Status:activeTo Action From------------OpenSSH ALLOW Anywhere8080ALLOW AnywhereOpenSSH(v6)ALLOWAnywhere(v6)8080(v6)ALLOWAnywhere(v6)
现在,Jenkins已安装,防火墙允许我们访问它,我们可以完成初始设置。
第3步 - 设置Jenkins
要设置我们的安装,我们将使用服务器域名或IP地址访问Jenkins的默认端口8080:http:// ip_address_or_domain_name :8080
我们应该看到“解锁Jenkins”屏幕,显示初始密码的位置
在终端窗口中,我们将使用cat命令显示密码:
sudo cat/var/lib/jenkins/secrets/initialAdminPassword
我们将从终端复制32个字符的字母数字密码,并将其粘贴到“管理员密码”字段中,然后单击“继续”。 下一个屏幕提供安装建议的插件或选择特定插件的选项。
图片.png
我们将点击“安装建议的插件”选项,这将立即开始安装过程:
在此界面可能出现实例已下线的提示,如果插件无法安装请参考下面的步骤:
修改/var/lib/jenkins/updates/default.json
jenkins在下载插件之前会先检查网络连接,其会读取这个文件中的网址。默认是:
访问谷歌,这就很坑了,服务器网络又不能FQ,肯定监测失败呀,不得不说jenkins的开发者脑子锈了,所以将图下的google改为www.baidu.com即可,更改完重启服务。
2) 修改/var/lib/jenkins/hudson.model.UpdateCenter.xml
该文件为jenkins下载插件的源地址,改地址默认jenkins默认为:https://updates.jenkins.io/update-center.json,就是因为https的问题,此处我们将其改为http即可,之后重启jenkins服务即可。
其他国内备用地址(也可以选择使用):
https://mirrors.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json
http://mirror.esuni.jp/jenkins/updates/update-center.json
安装完成后,系统将提示您设置第一个管理用户。 可以跳过此步骤,并使用上面使用的初始密码作为admin继续,但是我们将花一点时间创建用户。
注意:默认Jenkins服务器未加密,因此使用此表单提交的数据不受保护。 当您准备好使用此安装时,请按照指南如何使用Nginx反向代理将SSL配置为Jenkins。 这将保护用户凭据和关于通过Web界面发送的构建的信息。
图片.png
一旦第一个管理员用户到位,你应该看到一个“Jenkins准备好了!” 确认屏幕。
图片.png
点击“开始使用Jenkins”来访问主要的Jenkins仪表板:
查看
sudo netstat -plntu
此时,Jenkins已经成功安装。
默认端口是8080,有时候由于端口占用需要修改如下:
1,检查 /etc/init.d/jenkins 脚本,修改 do_start 函数的 check_tcp_port 命令,端口号从 8080 换成 8082:
2,修改 /etc/default/jenkins 文件,将端口 8080 改成 8082
3,重启Jenkins
sudo systemctl restart jenkins