【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 "you@example.com"
[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、构建项目


相关推荐
培根芝士25 分钟前
使用 Canvas 替代 <video> 标签加载并渲染视频
前端·javascript·音视频
小螺号dididi吹1 小时前
菜鸟速通:React入门 01
前端·react.js·前端框架
Lstmxx1 小时前
解放前端生产力:我如何用 LLM 和 Bun.js 构建一个 YApi to TypeScript 的自动化代码生成服务
前端·ai编程·mcp
持续前行1 小时前
vue3 : 导出pdf , 除iframe之外 ,还有其他内容一并导出方式
前端·javascript·vue.js
唐某人丶1 小时前
前端仔如何在公司搭建 AI Review 系统
前端·人工智能·aigc
没有鸡汤吃不下饭1 小时前
排查vue项目线上才会出现的故障
前端·vue.js·nginx
吃饭睡觉打豆豆嘛1 小时前
React Router 传参三板斧:新手也能 5 秒做决定
前端
裘乡1 小时前
storybook配合vite + react生成组件文档
前端·react.js
Carolinemy1 小时前
ElementUI 之 el-table
前端·vue.js
裘乡1 小时前
vonage音视频基本使用--web@opentok/client
前端·音视频开发