谈谈jenkins我的粗浅理解
听说Jenkins已经挺长时间了,探运维方面的知识有欠缺,通过几天的简单摸索和资料收集,将一些理解整理成文字,记录一下,也供入门的同学参考一下。
1. jenkins做什么用的
jenkins的定义很多,但是站在使用者的角度来看,jenkins的作用是下载源码后自动部署用的一个平台。它可以同时管理多个项目的部署,一次部署成功,即可反复更新部署。简化平台部署过程中的细节问题,降低部署人员的技术门槛。实现更傻瓜化的应用更新。
2.jenkins是怎么做到的
jenkins是一个web平台,它有很多插件。通过插件,扩展它的功能,对于java开发应用的部署来讲,必须安装的是maven,git,当然也少不了java的sdk环境。一个jenkins的部署过程大体是这样的,第一步pull源码,第二步用maven打包源码,第三部,备份应用服务器上的包和文件,第四部,将刚刚打包好的新包scp到应用服务器,第五步重启应用服务上的应用。
当然这中间还涉及到很多细节问题。比如
- scp 到应用服务器,如何做到免密登录
- shell脚本的权限不足问题,如何及保障账号密码的安全,又让jenkins能有权限更新包,有权限重启动服务;
当然如项目更加复杂,肯定还有更多细节的问题。但是这些都不是jenkins的知识了。属于linux的操作知识,我们刚刚开始,一切从简单开始,扩展的技能,就是游戏里面的dlc,不影响主线情节了。
以上是我们粗浅理解一下jenkins,有说的不对的地方,还请高手指点。
1. 安装java环境(网上自己找)
2. 安装Jenkins
wget -q -O - https://pkg.jenkins.io/debian/jenkins-ci.org.key | sudo apt-key add -
sudo sh -c 'echo deb http://pkg.jenkins.io/debian-stable binary/ > /etc/apt/sources.list.d/jenkins.list'
sudo apt-get update
sudo apt-get install jenkins
3.安装 git 环境
sudo apt-get install git
4. 安装 maven 环境
sudo apt-get install maven
5. 启动Jenkins
启动命令:
sudo systemctl start jenkins
重启命令
sudo systemctl restart jenkins
6. 设置Jenkins
要设置我们的安装,我们将使用服务器域名或IP地址访问Jenkins的默认端口8080 : http:// ip_address_or_domain_name :8080
我们应该看到“解锁Jenkins”屏幕,显示初始密码的位置:
在终端窗口中,我们将使用cat命令显示密码:
sudo cat /var/lib/jenkins/secrets/initialAdminPassword
我们将从终端复制32个字符的字母数字密码,并将其粘贴到“管理员密码”字段中,然后单击“继续”。 下一个屏幕提供安装建议的插件或选择特定插件的选项。
我们将点击“安装建议的插件”选项,这将立即开始安装过程:
安装完成后,系统将提示您设置第一个管理用户。 可以跳过此步骤,并使用上面使用的初始密码作为admin继续,但是我们将花一点时间创建用户。
一旦第一个管理员用户到位,你应该看到一个“Jenkins准备好了!” 确认屏幕。
点击“开始使用Jenkins”来访问主要的Jenkins仪表板:
此时,Jenkins已经成功安装。
使用jenkins时候常见的问题:
1.在Jenkins执行shell命令的时候如果出现权限不足的情况:
可以修改一下sudo权限来解决。
vim /etc/sudoers
Defaults visiblepw
Defaults:jenkins !requiretty
%jenkins ALL=(ALL) NOPASSWD: ALL
2.不想使用了,卸载jenkins的方法
//服务
sudo apt-get remove jenkins
//安装包,注意这里如果不是ubuntu那就yum
sudo apt-get remove --auto-remove jenkins
//配置和数据
sudo apt-get purge jenkins
sudo apt-get purge --auto-remove jenkins
后续
后续如果想真正在一个项目中使用jenkins来管理应用的部署,那么至少应该有两台服务器,一台部署jenkins下载编译打包源码,一台用于跑应用。
你也需要做好两台服务器间的通讯配置,比如公钥,用户组,目录的权限设定等;
你还需要考虑定期更换密码和公钥,确保通讯的安全等;
还必须要考虑应用服务器对外暴露的端口和nginx代理之间的配合问题。
其实后续还是有很多需要考虑的问题,而且在不同的项目里面,应用的规模不同,细节实现的方案不同,也需要规划(比如你打包好是准备用scp复制到应用服务器,还是远程执行sh脚本,到jenkins服务器上wget到本地),技术的坑就越挖越深了,花时间填坑本身就是一个乐趣。技术宅,要加油。