【DevOps】Jenkins使用Pipline发布Web项目

使用Pipline发布Web项目

文章目录

资源列表

操作系统 主机名 配置 IP
CentOS 7.9 jenkins 2C4G 192.168.93.101
CentOS 7.9 gitlab 2C4G 192.168.93.102
CentOS 7.9 apache 2C4G 192.168.93.103

基础环境

  • 关闭防火墙
bash 复制代码
systemctl stop firewalld
systemctl disable firewalld
  • 关闭内核安全机制
bash 复制代码
setenforce 0
sed -i "s/^SELINUX=.*/SELINUX=disabled/g" /etc/selinux/config
  • 修改主机名
bash 复制代码
hostnamectl set-hostname jenkins
hostnamectl set-hostname gitlab
hostnamectl set-hostname apache

一、准备Gitlab

1.1、部署Gitlab

  • 这里省略步骤

1.2、创建demo项目

1.3、提交代码

  • 本次就在jenkins主机上进行测试了
bash 复制代码
# 下载Git命令
[root@jenkins ~]# yum -y install git


# 解压源代码
[root@jenkins ~]# tar -zxvf BlueLight.git.tar.gz


# 拉取代码仓库
[root@jenkins ~]# git clone http://192.168.93.102/root/demo.git


# 复制源代码到仓代码库
[root@jenkins ~]# mv -f BlueLight/* demo/


# 往main分支进行第一次推送
[root@jenkins ~]# cd demo/
[root@jenkins demo]# git config --global user.email "[email protected]"
[root@jenkins demo]# git config --global user.name "Your Name"
[root@jenkins demo]# git add .
[root@jenkins demo]# git commit -m "first commit"
[root@jenkins demo]# git push -u origin main

二、准备Jenkins

  • 这里省略

三、准备Apache

bash 复制代码
[root@apache ~]# yum -y install httpd
[root@apache ~]# systemctl start httpd

四、Jenkins的配置

4.1、Jenkins配置SSH主机

  • 点击"系统管理(System)"------>"系统配置"------>最下边"SSH Server下的新增"

4.2、Jenkins配置gitlab的密码

  • 点击"系统管理(System)------>"凭据管理(Credentials)"------>"全局"------>"Add Credentials"

4.3、Jenkins创建demo项目

4.4、配置流水线

  • 可以使用流水线语法,生产Pipeline的代码然后粘贴过来
  • 把生成的Pipeline命令替换进去,stage给本阶段起名叫拉取代码
  • 在生成一个流水线语法,
bash 复制代码
# 构建代码如下,需要进行修改
pipeline {
    agent any

    stages {
        stage('拉取代码') {
            steps {
                git branch: 'main', credentialsId: '5592dcbd-ca4d-4d75-8793-5f834c11014b', url: 'http://192.168.93.102/root/demo.git'
            }    
        }        
        stage('部署网站') {
            steps {
            sshPublisher(publishers: [sshPublisherDesc(configName: 'web', transfers: [sshTransfer(cleanRemote: false, excludes: '', execCommand: 'chmod -R 755 /var/www/html', execTimeout: 120000, flatten: false, makeEmptyDirs: false, noDefaultExcludes: false, patternSeparator: '[, ]+', remoteDirectory: '', remoteDirectorySDF: false, removePrefix: '', sourceFiles: '**/*')], usePromotionTimestamp: false, useWorkspaceInPromotion: false, verbose: false)])
            }
        }
    }
}

4.5、访问测试

4.6、将Pipeline放在gitlab仓库

  • 创建一个文件"Jenkins",将刚才的pipline代码填写到此文件

  • 注意:Jenkins首字母要大写(J)

4.7、重新配置Jenkins的流水线项目

  • 在定义中选择"Pipline script from SCM",SCM使用"Git",填写号仓库URL,然后保存
  • 备注:SCM叫做源代码控制

4.8、构建项目


相关推荐
咖啡教室几秒前
前端开发日常工作每日记录笔记(2019至2024合集)
前端·javascript
溪饱鱼4 分钟前
Nuxt3能上生产吗?
前端
咖啡教室16 分钟前
前端开发中JavaScript、HTML、CSS常见避坑问题
前端·javascript·css
lost_n_found2 小时前
Linux-CentOS从零搭建Jenkins(上),包教包会
jenkins
LaoZhangAI3 小时前
Claude MCP模型上下文协议详解:AI与外部世界交互的革命性突破【2025最新指南】
前端
LaoZhangAI3 小时前
2025最全Cursor MCP实用指南:15个高效工具彻底提升AI编程体验【实战攻略】
前端
Kagerou3 小时前
vue3基础知识(结合TypeScript)
前端
市民中心的蟋蟀3 小时前
第五章 使用Context和订阅来共享组件状态
前端·javascript·react.js
宁zz3 小时前
乌班图安装jenkins
运维·jenkins
逆袭的小黄鸭3 小时前
JavaScript 闭包:强大特性背后的概念、应用与内存考量
前端·javascript·面试