- 自动化构建和部署:利用持续集成/持续部署(CI/CD)工具自动化构建、测试和部署过程。这样可以确保每次代码提交都可以快速地构建、测试和部署到生产环境。
- 版本控制:使用版本控制系统(如Git)来管理代码,并确保团队成员能够轻松地合作、追踪变更并回滚不必要的更改。
- 自动化测试:实施自动化测试,包括单元测试、集成测试和端到端测试,以确保代码质量和系统稳定性。自动化测试可以在代码提交后快速运行,提供及时的反馈。
- 基础设施即代码:使用基础设施即代码(IaC)工具(如Terraform、Ansible)来自动化基础设施的配置和管理。这样可以确保环境一致性,并使得基础设施的部署过程可重复且可靠。
- 持续监控和反馈:建立监控系统来实时监测应用程序和基础设施的运行状况,并采取预防性和响应性措施来处理问题。同时,收集用户反馈和性能指标,以不断改进产品。
- 持续改进:定期回顾和评估团队的工作流程和实践,寻找改进的机会并采取行动。通过不断迭代和优化,实现持续改进和提升交付效率。
在Devops实施过程中将Jenkins与GitLab结合使用是一种常见的做法,特别是在实现持续集成和持续交付(CI/CD)方面。
一、Devops基本环境部署
部署环境:centos7.6 服务两台:
jenkins 192.168.0.108 4核心8G
gitlab 192.168.0.109 4核心8G
(建议购买腾讯云2核8G轻量级服务)
1.1: 部署jenkins
官网地址:https://www.jenkins.io/download/
选择安装稳定长期支持版本(LTS)
sudo wget -O /etc/yum.repos.d/jenkins.repo https://pkg.jenkins.io/redhat-stable/jenkins.repo
sudo rpm --import https://pkg.jenkins.io/redhat-stable/jenkins.io-2023.key
yum install fontconfig java-17-openjdk
yum install jenkins
部署完成后启动jenkins,访问端口192.168.0.108:8080,选择安装基础软件。(jenkins启动需要一定时间)
部署问题:部署过程中如出现ca报错重新安装根证书的软件包
yum install -y ca-certificates
1.2:部署Gitlab
官网地址:https://about.gitlab.com/install/#centos-7
sudo yum install -y curl policycoreutils-python openssh-server perl
sudo systemctl enable sshd
sudo systemctl start sshd
sudo firewall-cmd --permanent --add-service=http
sudo firewall-cmd --permanent --add-service=https
sudo systemctl reload firewalld
添加Gitlab源
curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.rpm.sh | sudo bash
因为安装的是社区版需要修改yum源
在/etc/yum.reop/gitlab_gitlab-ee.repo文件中的gitlab-ee修改为gitlab-ce
sed -i 's/\/gitlab-ee/\/gitlab-ce/g' /etc/yum.repos.d/gitlab_gitlab-ee.repo
安装gitlab
sudo EXTERNAL_URL="192.168.0.109" yum install -y gitlab-ce
随机密码存储在/etc/gitlab/initial_root_password
注:使用yum list gitlab-ce --showduplicates | sort -r可以查看多个版本的gitlab可自行选择安装。
二、流水线基础介绍
安装声名式插件Pipline: Declarative
@Library('jenkinslib') _
string workspace = "/opt/jenkins/workspace"
pipeline {
agent {node { label "master" //指定运行节点,any在任何节点上执行Pipline,none没指定的时候默认,label在指 定节点上运行。node可以指定额外多个选项
customWorkspace "${workspace}" //运行工作目录}}
options {
timestamps() //日志会有时间
skipDefaultCheckout() // 流水线定义中跳过默认的代码检出步骤
disableConcurrentBuilds() //禁止并行
timeout(time: 1, unit: 'HOURS') //流水线超时设置1小时 }
//stages(可添加多个阶段)此处添加GetCode、Build、CodeScan三个阶段
stages {
//下载代码
stage("GetCode"){ //阶段名称
steps{ //步骤
timeout(time:5, unit:"MINUTES"){ //步骤超市时间
script { //获取运行代码
println('获取代码')}}}}
stage("Build"){
steps{
timeout(time:20, unit:"MINUTES"){
script{
println('应用打包')}
}}}
//代码扫描
stage("CodeScan"){
steps{
timeout(time:30, unit:"MINUTES"){
script{
print("代码扫描")}
}}}
//构建后操作
post {
always{ //总是执行脚本片段
script{
println("always")
}}
//currentBuild是Jenkins Pipeline中的一个特殊全局变量,代表当前正在执行的构建(build)对象