【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、构建项目


相关推荐
Moment8 分钟前
给大家推荐一个超好用的 Marsview 低代码平台 🤩🤩🤩
前端·javascript·github
小满zs12 分钟前
Zustand 第三章(状态简化)
前端·react.js
普宁彭于晏13 分钟前
元素水平垂直居中的方法
前端·css·笔记·css3
恋猫de小郭25 分钟前
为什么跨平台框架可以适配鸿蒙,它们的技术原理是什么?
android·前端·flutter
云浪28 分钟前
元素变形记:CSS 缩放函数全指南
前端·css
明似水43 分钟前
用 Melos 解决 Flutter Monorepo 的依赖冲突:一个真实案例
前端·javascript·flutter
独立开阀者_FwtCoder1 小时前
stagewise:让AI与代码编辑器无缝连接
前端·javascript·github
清沫1 小时前
Cursor Rules 开发实践指南
前端·ai编程·cursor
江城开朗的豌豆1 小时前
JavaScript篇:对象派 vs 过程派:编程江湖的两种武功心法
前端·javascript·面试
不吃糖葫芦31 小时前
App使用webview套壳引入h5(二)—— app内访问h5,顶部被手机顶部菜单遮挡问题,保留顶部安全距离
前端·webview