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

相关推荐
i***48611 小时前
Nginx中$http_host、$host、$proxy_host的区别
运维·nginx·http
Fɪʀᴇᴡᴏʀᴋs2 小时前
Oceanbase数据库—基于社区版本的数据库集群管理
运维·数据库·oceanbase
HalvmånEver2 小时前
Linux:基础开发工具(五)
linux·运维·服务器
q***58192 小时前
基础篇:Linux安装redis教程(详细)
linux·运维·redis
小二·2 小时前
Linux 高频面试题(50道 + 详细答案)
linux·运维·服务器
z***39622 小时前
Nginx中如何配置WebSocket代理?
运维·websocket·nginx
忆林5202 小时前
请求服务任何资源(静态/动态)都返回主页数据?多nginx针对单域名的多服务配置
运维·nginx
Splashtop高性能远程控制软件3 小时前
行业观察 | 微软修复63个漏洞,包含零日与CVSS 9.8关键漏洞
运维·安全·microsoft·自动化·远程桌面·splashtop
q***4643 小时前
离线安装 Nginx
运维·数据库·nginx
HalvmånEver4 小时前
Linux:基础开发工具(六)
linux·运维·服务器