Jenkins 从0基础到有点基础——如何安装

CICD是什么

CI/CD这个词听起来很高大上,其实说白了就是让代码从开发到上线这个过程变得自动化。

CI是Continuous Integration的缩写,中文叫持续集成。简单理解就是,开发人员每次提交代码后,系统会自动把所有人的代码合并在一起,然后跑一遍测试,看看有没有冲突或者bug。就像搭积木一样,每加一块都要检查一下整体结构是不是还稳固。

CD有两个意思,一个是Continuous Delivery(持续交付),另一个是Continuous Deployment(持续部署)。持续交付是说代码随时都处于可发布状态,就像工厂流水线上的产品,每个环节都质检过了,随时可以出厂。持续部署更进一步,直接自动发布到生产环境,完全不需要人工干预。

举个例子,以前我们部署一个网站,可能需要手动上传文件、重启服务、清缓存等等,一套流程下来半小时,还容易出错。有了CI/CD之后,开发人员只要把代码推送到Git仓库,剩下的事情全部自动完成:自动测试、自动打包、自动部署、自动重启服务,几分钟就搞定了。

CI/CD的核心思想就是"小步快跑,快速反馈"。与其攒一堆功能一次性发布(风险大),不如每个小功能都快速上线,出问题也能快速定位和修复。这样既提高了开发效率,又降低了上线风险,是现代软件开发的标配。

为什么选择Jenkins

官方文档:https://www.jenkins.io/zh/doc/book/installing/

说实话,CI/CD工具现在选择挺多的,GitLab CI、GitHub Actions、Azure DevOps什么的都不错。但是我最终还是选择了Jenkins,主要原因有几个:

Jenkins的插件生态真的很丰富,基本上你能想到的功能都有对应的插件。而且它是开源的,不用担心费用问题。最重要的是,Jenkins对PHP项目的支持很好,配置起来也比较灵活。

当然了,Jenkins也有它的缺点,比如界面看起来有点老旧,配置相对复杂一些。不过习惯了就好,功能强大才是硬道理。

环境准备和Jenkins安装

我们的服务器环境是debain13。Jenkins可以用Docker来部署,这样比较干净,也方便管理。

bash 复制代码
docker run \
  -u root \
  --rm \
  -d \
  -p 8080:8080 \
  -p 50000:50000 \
  -v jenkins-data:/var/jenkins_home \
  -v /var/run/docker.sock:/var/run/docker.sock \
  jenkinsci/blueocean

开始下载

我镜像一直下载失败,换了直接用软件包安装(记得安装java环境),文档地址:https://www.jenkins.io/zh/doc/book/installing/#war文件

复制代码
wget -q -O - https://pkg.jenkins.io/debian/jenkins.io.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

启动后访问http://your-server:8080,按照提示完成初始化配置。初始密码在容器日志里能找到:

必要插件安装

Jenkins装好后,需要安装一些必要的插件。进入"系统管理" -> "插件管理",安装以下插件(这些插件记得装!!!):

  • Git plugin(代码拉取)
  • Pipeline(流水线支持)
  • Blue Ocean(更好看的界面)
  • Publish Over SSH(SSH部署)
  • Build Timestamp(构建时间戳)
  • Email Extension(邮件通知)

插件安装完成后记得重启Jenkins。有时候插件之间会有依赖关系,Jenkins会自动帮你安装依赖的插件,这点还是很贴心的。

配置Git仓库连接

我们的代码托管在GitLab上,需要配置Jenkins能够拉取代码。在"系统管理" -> "全局工具配置"中配置Git路径,一般Jenkins会自动检测到。

然后在"系统管理" -> "系统配置"中添加Git凭据。我建议使用SSH密钥的方式,比较安全:

bash 复制代码
# 在Jenkins服务器上生成SSH密钥
ssh-keygen -t rsa -b 4096 -C "jenkins@yourcompany.com"

# 将公钥添加到GitLab的Deploy Keys中
cat ~/.ssh/id_rsa.pub

把私钥内容添加到Jenkins的凭据管理中,类型选择"SSH Username with private key"。

创建第一个Pipeline任务

选择测试hello world

点击立即构建,构建完成

写在最后

jenkins的搭建就讲完了,没什么技术含量。照着文档做就行了,要注意的是软件包和网络环境的问题。目前遇到的问题丢给ai都可以很好的解决!(学会用ai很重要!!!),下一期来讲讲jenkins如何来实现php环境的cicd(主要是我博客用的是php哈哈哈)


好了,今天的分享就到这里。如果这篇文章对你有帮助,别忘了点个赞、转发给需要的朋友。想了解更多运维实战经验,

记得关注@运维躬行录,我会持续分享一线的技术实践和踩坑经验。让我们一起在运维的路上越走越远!

个人博客:https://www.fuzhoupyy.work

相关推荐
我爱钱因此会努力3 小时前
初始化服务器
linux·运维·服务器·tcp/ip·centos
曦月合一4 小时前
解决由于没有远程桌面授权服务器可以提供许可证,远程会话被中断.的方法
运维·服务器·window server
angushine4 小时前
Shell脚本判断服务器SSH免密是否配置完成
运维·服务器·ssh
想唱rap4 小时前
C++list类的模拟实现
linux·运维·服务器·数据结构·c++·windows·list
思麟呀4 小时前
Linux的进程认识上
linux·运维·服务器
技术liul5 小时前
Centos 7 :VMware Tools 启动脚本未能在虚拟机中成功运行
linux·运维·centos
j七七5 小时前
5分钟搭微信自动回复机器人5分钟搭微信自动回复机器人
运维·服务器·开发语言·前端·python·微信
大锦终5 小时前
【Linux】HTTP协议
linux·运维·服务器·网络·http
ragnwang6 小时前
解决 Ubuntu 安装 NVIDIA 固件时的包冲突问题
linux·运维·ubuntu