在Debian系统上集成Jenkins以实现持续集成和持续部署(CI/CD)是一个常见的需求,以下是一个详细的步骤指南,帮助你完成这一过程:
Jenkins需要Java运行时环境(JRE)才能正常运行。
sudo apt update
sudo apt install openjdk-11-jdk
验证Java安装成功:
java -version
下载Jenkins的GPG key并添加到系统:
wget -q -O - https://pkg.jenkins.io/debian/jenkins.io.key | sudo apt-key add -
将Jenkins Debian repository添加到系统中:
echo "deb http://pkg.jenkins.io/debian-stable binary/" | sudo tee /etc/apt/sources.list.d/jenkins.list
更新系统软件包列表并安装Jenkins:
sudo apt update
sudo apt install jenkins
启动Jenkins服务并设置为开机自启动:
sudo systemctl enable jenkins
sudo systemctl start jenkins
检查Jenkins服务状态:
sudo systemctl status jenkins
首次访问Jenkins时,访问 http://your-server-ip:8080,输入初始密码(可以在 /var/lib/jenkins/secrets/initialAdminPassword
中找到)。
进入Jenkins管理界面,进入 Manage Jenkins
- Plugin Manager
,安装以下插件:
创建一个新的Pipeline任务,选择 Pipeline script from SCM
,配置Git仓库地址与凭据。在Pipeline脚本中定义整个构建、测试和部署流程。
示例Pipeline脚本:
pipeline {
agent any
stages {
stage('拉取代码') {
steps {
git 'https://github.com/your-repo.git'
}
}
stage('运行测试') {
steps {
sh 'python -m pytest tests/'
}
}
stage('构建打包') {
steps {
sh 'python setup.py build'
}
}
stage('部署') {
steps {
sh './deploy.sh'
}
}
}
post {
always {
mail to: 'team@example.com', subject: "构建完成", body: "构建 ${currentBuild.fullDisplayName} 已完成"
}
}
}
编写Python脚本来监控服务状态,并在检测到异常时发送报警通知。
示例监控脚本:
import time
import requests
from datetime import datetime
def check_service():
try:
response = requests.get("http://your-service.com/health")
if response.status_code != 200:
send_alert("服务异常")
except Exception as e:
send_alert(f"监控异常: {str(e)}")
def send_alert(message):
# 这里可以接入企业微信或钉钉告警
print(f"[ ] 告警: {message}")
while True:
check_service()
time.sleep(300) # 每5分钟检查一次
在Jenkins中配置环境变量(如 JAVA_HOME
和 M2_HOME
)和凭据(如Git仓库的SSH密钥)。
提交代码更改到Git仓库,触发Jenkins流水线,验证自动化部署是否按预期工作。
使用Docker安装Jenkins对于新手比较友好,也是官方推荐的第一种安装方式:
docker network create jenkins
docker run --name jenkins-docker --rm --detach \
--privileged --network jenkins --network-alias docker \
--env DOCKER_TLS_CERTDIR=/certs \
--volume jenkins-docker-certs:/certs/client \
--volume jenkins-data:/var/jenkins_home \
--publish 2376:2376 \
docker:dind --storage-driver overlay2
docker build -t myjenkins-blueocean:2.479.1-1 .
docker run --name jenkins-blueocean --restart=on-failure --detach \
--network jenkins --env DOCKER_HOST=tcp://docker:2376 \
--env DOCKER_CERT_PATH=/certs/client --env DOCKER_TLS_VERIFY=1 \
--publish 8080:8080 --publish 50000:50000 \
--volume jenkins-docker-certs:/certs/client:ro \
myjenkins-blueocean:2.479.1-1