当前位置: 首页 > news >正文

【jenkins部署】一文弄懂自动打包部署(前后台)

这里写目录标题

  • 序言
  • 软件安装
    • jdk
    • maven
      • 配置maven阿里镜像以及本地库位置
    • git安装
  • 安装jenkins
    • 插件安装
    • 环境配置
    • 创建项目
      • 配置gitee
        • 生成gitee WebHook
    • maven打包
    • 验证是否打包成功
    • 连接远程服务器并重启服务
    • 远程服务器生成私钥
    • 配置ssh
    • 项目配置ssh
    • 脚本
    • vue项目打包
      • nodejs安装
        • 下载
        • 配置环境变量
        • 验证
        • 镜像加速
      • nodeJS插件安装
      • 配置nodeJS环境变量
      • 创建vue项目
        • 添加nodeJS信息
        • 设置shell脚本
        • 前台代码部署到另外一台服务器

序言

软件开发中,会分多个环境,开发环境、测试环境、预发布环境、生产环境,软件部署如果是纯人工一个个通过jar的方式,会有如下问题:

  • 服务器过多,容易出错

  • 修改配置,可能会存在未修改到位的情况

  • 服务器部署权限一般只有开发服务器人才有权限,涉及到服务器的安全

    今年,我们看看持续构建的一个工具jenknins,看看他是如何怎么部署的

软件安装

jdk

rpm -qa |grep java   ###查看是否安装java
rpm -qa | grep java | xargs rpm -e --nodeps  ###卸载java
yum list java-1.8*   ####查看是否安装jdk1.8的包
yum install java-1.8.0-openjdk* -y   ###一键安装
java -version  ###查看jdk配置
  • 新手不建议使用这种方式,建议自己配置环境变量

maven

  • 是为了jenkins打包需要

maven离线下载

tar -zxvf apache-maven-3.9.1-bin.tar.gz###修改目录
mv apache-maven-3.9.1 maven###设置环境变量
vim /etc/profile###设置maven环境变量
MAVEN_HOME=/root/maven
export MAVEN_HOME
export PATH=${PATH}:${MAVEN_HOME}/bin####查看maven的版本,是否配置成功
mvn -v
  • /root/project/maven 是maven的安装后的路径,根据自己的地址配置

配置maven阿里镜像以及本地库位置

###cd到maven下面的conf
cd conf
###打开文件
vim settings.xml###配置本地卡路径
<localRepository>/root/project/maven-local</localRepository>####配置阿里云镜像
<mirror><id>alimaven</id><mirrorOf>central</mirrorOf><name>aliyun maven</name><url>http://maven.aliyun.com/nexus/content/repositories/central/</url>
</mirror>

image.png
image.png

  • 放入到mirros标签里面

git安装

  • 安装git是为了jenkins拉取代码
yum install git
git --version

安装jenkins

使用离线安装

####下载jenkins
wget https://mirrors.aliyun.com/jenkins/war-stable/2.332.3/jenkins.war###启动jenkins  9090是jenkins端口 
nohup java -jar /usr/local/jenkins/jenkins.war --httpPort=9090 > /var/log/jenkins.log 2>&1 &

image.png
image.png

  • 把密码放到上图中

image.png

  • 下载插件40分钟左右

    image.png

插件安装

image.png

  • 安装gitee、maven、ssh等插件

环境配置

image.png

  • name随便写
  • maven_home 写maven的安装路径

创建项目

image.png
image.png

  • 名字以实际的项目名为准

image.png

  • 保存构建的天数,意思就是代码构建版本保留多久
  • 构建最大个数为3,就是构建的历史记录最大为多少,如下图

image.png

配置gitee

image.png

  • 输入gitee地址
  • 指定分支的dev,可以改成对应的版本
  • Credentials 输入对应的用户名

生成gitee WebHook

image.png
找到gitee的项目路径,点击管理
image.png
image.png

  • 找到webHook密码复制到下面

image.png

maven打包

image.png

  • clean package -U -Dmaven.test.skip=true
  • maven版本里面的文件可以随便写
  • 执行shell里面写一行 echo hello判断是否打包成功

验证是否打包成功

image.png
image.png
image.png

  • 注意第一次构建,会下载很多的依赖包
  • 显示success说明打包成功
  • /root/.jenkins/workspace/test/target 显示的说明是jar包的存放路径

image.png

  • 到这里,万里长征已经只差最后一步咯,jar包已经生成,只需要把这个jar包发送到远程服务器,备份并启动就行

连接远程服务器并重启服务

远程连接服务器

把打包的应用发布到远程服务器

远程服务器生成私钥

jenkins服务器和服务部署的服务器不在一条服务器,需要生成ssh秘钥

ssh-keygen -t rsa -C "xxx@163.com"
查看秘钥cat /root/.ssh/id_rsa
  • xxx@163.com可以写你的邮箱地址
  • 一直按回车就行
  • 把秘钥复制下来

image.png

  • 去掉第一行和最后一行进行复制

配置ssh

系统设置-》系统配置 一直向下拉
image.png

  • 放入远程服务器的私钥

image.png

  • name随便输入
  • Hostname 服务器的ip
  • username 服务器的账号
  • Remote Directory ssh的根目录(操作命令,都是基于该目录来的)
  • 点击test,返回success说明ssh免登录成功

项目配置ssh

点击项目,修改ssh配置
image.png

  • sourse file是jenkins的jar位置
  • Remove prefix是去掉前缀
  • Remote Direcotory 这里写的/,表示以配置的ssh根目录为准,之前社长配置的是/root/downlod
  • exec command是重启脚本,这里暂时只打印echo hello这一句话

image.png
image.png

  • 到这里gitee上的代码,已通过jenkins下载到jenkins的workspaces上编程成一个jar(maven打包)
  • 通过ssh,把对应jar,传输到远程服务器上
  • 编写重启的脚本(1 kill进程,把之前的文件备份,再把该文件移动过来,再java -jar启动)

脚本

vim test.sh

  • 编写test脚本
#!/bin/sh
#这里可替换为你自己的执行程序,其他代码无需更改
APP_NAME=iopace.jar
####ssh根目录
SSH_PATH=/root/download
###配置项目的路径
PROJECT_PATH=/root/download/bak
echo " ==备份项目,并移动项目---"
####备份jar按bak存放
cp -R $PROJECT_PATH/$APP_NAME $PROJECT_PATH/"$APP_NAME".bak
rm -rf $PROJECT_PATH/$APP_NAME
cp -R  $SSH_PATH/$APP_NAME $PROJECT_PATH/$APP_NAMEecho "  =====关闭Java应用======"
PROCESS=`ps -ef |grep $APP_NAME |grep -v grep|grep hg-learn.jar|awk '{print $2}'`
for i in $PROCESS
doecho "Kill the $1 process [ $i ]"kill -9 $i
done
echo "  =====启动Java应用======"
nohup java -jar  -Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=9091 -Duser.timezone=GMT+08 $PROJECT_PATH/$APP_NAME  --spring.profiles.active=dev -Xdebug > /dev/null 2>&1 &

chmod +x test.sh

  • 给脚本执行权限

vue项目打包

nodejs安装

下载

#下载(下载路径)
wget https://nodejs.org/dist/v16.6.0/node-v16.6.0-linux-x64.tar.gz
#解压
tar zxvf node-v16.6.0-linux-x64.tar.gz
# 改名
mv node-v16.6.0-linux-x64 node16
#赋权
chmod 777 node16

配置环境变量

# 打开环境变量
vim /etc/profile
#set nodejs env(路径一定要配置对)
export NODE_HOME=/usr/local/software/nodeJs/node16
export PATH=$NODE_HOME/bin:$PATH
# 重新加载环境变量
source /etc/profile

验证


node -v
npm -v

在这里插入图片描述

镜像加速

  • nodeJS可以理解为就是后台的maven,在配置maven的时间我们配置了阿里云镜像,为什么?就是因为maven默认的是国外镜像,导致下载很慢,nodejs也是同理,所以我们需要配置国内镜像
npm install -g cnpm --registry=https://registry.npm.taobao.org
#校验是否成功
cnpm -v

在这里插入图片描述

nodeJS插件安装

在这里插入图片描述- 安装NodeJS插件

配置nodeJS环境变量

在这里插入图片描述

创建vue项目

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

  • 构建的版本保留2天,最多存在3个构建版本
    在这里插入图片描述
  • 输入项目的git地址
  • 指定分支 master可以动态修改成其他的分支
    在这里插入图片描述
    在这里插入图片描述
  • 点击生成webHook密码,记住框起来的两个地址,需要在gitee上配置
    在这里插入图片描述
  • 填入上面记住的两个信息
    在这里插入图片描述
  • 点击测试,没有报错,说明连接成功

添加nodeJS信息

在这里插入图片描述

  • 如果nodeJS配置没有问题,下拉可以选择到我们配置好的nodeJS环境变量

设置shell脚本

echo $PATH
node -v
npm -v
#npm install -g cnpm --registry=https://registry.npm.taobao.org
#cnpm install node-sass
#cnpm install chromedriver --chromedriver_cdnurl=http://cdn.npm.taobao.org/dist/chromedriver
#npm install
#cnpm  install vue-awesome-swiper --save
#cnpm  install vue-ba --save
npm run build --dev
  • 打印当前地址,输入node的版本信息
  • npm run build --dev dev就是前端的不同环境的名称,可以动态切换
  • 实际上就是在jenkins的工作目录下生成一个dist的文件夹
    在这里插入图片描述
    到这里我们已经实现把前台项目编译成文件夹运行咯,在实际部署过程中,可能存在jenkins和前台不是一台服务器的情况,所以我们还需要多操作一步

前台代码部署到另外一台服务器

在这里插入图片描述

  • ssh server name是我们在项目ssh阶段已配置好的
    在这里插入图片描述
  • Sources files实际上就是针对于jenkins的workspaces来说的,是相对路径dist/*的意思就是dist文件夹的内容,我都需要
  • Remove prefix不需要去掉前缀,因为是文件夹,所以不需要配置
  • Remote diretory 上传路径,这里的/是相对于ssh配置的路径来说的(ssh我配置的是/root/download)
  • exec command 就是需要执行的命令,后台打包有讲解,可以参考编写
    到这里jenkins打包成vue就成功咯

相关文章:

【jenkins部署】一文弄懂自动打包部署(前后台)

这里写目录标题序言软件安装jdkmaven配置maven阿里镜像以及本地库位置git安装安装jenkins插件安装环境配置创建项目配置gitee生成gitee WebHookmaven打包验证是否打包成功连接远程服务器并重启服务远程服务器生成私钥配置ssh项目配置ssh脚本vue项目打包nodejs安装下载配置环境变…...

应届生投腾讯,被面试官问了8个和 ThreadLocal 相关的问题。

问&#xff1a;谈一谈ThreadLocal的结构。 ThreadLocal内部维护了一个ThreadLocalMap静态内部类&#xff0c;ThreadLocalMap中又维护了一个Entry静态内部类&#xff0c;和Entry数组。 Entry类继承弱引用类WeakReference&#xff0c;Entry类有一个有参构造函数&#xff0c;参数…...

Linux命令scp用法

本文主要讲的是scp用法如果哪里不对欢迎指出&#xff0c;主页https://blog.csdn.net/qq_57785602?typeblogscp 可以在win系统使用&#xff0c;本文百分之八十写的是win系统怎么使用&#xff0c;在本地上到服务器文件,从服务器下载文件到本地用工具连接到公司服务器时&#xff…...

数据质量怎么监控

目录 一、任务基线级别 二、任务级别 & 表级别 三、字段级别 1. 对指标字段的监控 2. 对维度字段的监控 四、报表级别监控 五、总结 跑了几场面试&#xff0c;数据质量怎么监控是经常被问到的问题&#xff0c;仅次于自我介绍。 因为数据行业发展了几年&#xff0c;数…...

.NET Core 实现Excel的导入导出

.NET Core 使用NPOI实现Excel的导入导出前言NPOI简介一、安装相对应的程序包1.1、在 “管理NuGet程序包” 中的浏览搜索&#xff1a;“NPOI”二、新建Excel帮助类三、调用3.1、增加一个“keywords”模型类&#xff0c;用作导出3.2、添加一个控制器3.3、编写导入导出的控制器代码…...

排好队,一个一个来:宫本武藏教你学队列(附各种队列源码)

文章目录前言&#xff1a;理解“队列”的正确姿势一个关于队列的小思考——请求处理队列的两大“护法”————顺序队列和链式队列数组实现的队列链表实现的队列循环队列关于开篇&#xff0c;你明白了吗&#xff1f;最后说一句前言&#xff1a; 哈喽&#xff01;欢迎来到黑洞晓…...

C语言--动态内存管理1

目录前言动态内存函数介绍mallocfreecallocrealloc常见的动态内存错误对NULL指针的解引用操作对动态开辟空间的越界访问对非动态开辟内存使用free释放使用free释放一块动态开辟内存的一部分对同一块动态内存多次释放动态开辟内存忘记释放&#xff08;内存泄漏&#xff09;对通讯…...

HTTPS 的工作原理

1、客户端发起 HTTPS 请求 这个没什么好说的&#xff0c;就是用户在浏览器里输入一个 https 网址&#xff0c;然后连接到 server 的 443 端口。 2、服务端的配置 采用 HTTPS 协议的服务器必须要有一套数字证书&#xff0c;可以自己制作&#xff0c;也可以向组织申请&#xf…...

游戏开发中建议使用半兰伯特光照

游戏开发中建议使用半兰伯特光照模型 在基本光照模型中求出漫反射部分的计算公式: 漫反射 = 入射光线的颜色和强度(c light) * 材质漫反射系数 (m diffuse)* 表面法线(n) * 其光源防线 (I) 在shader中为了不让 n和i的点乘结果为负数,即使用了saturate函数让值截取在[0,1]区…...

JavaScript到底如何存储数据?

1.var的迷幻操作 普遍的观点&#xff1a;JavaScript中的基本数据类型是保存在栈空间&#xff0c;而引用数据类型则是保存在堆空间里, 是否正确&#xff1f; 浏览器环境下JavaScript变量类型的运行实践结果: var a 10;console.log(a);console.log(window.a); console.log(wind…...

python实战应用讲解-【numpy专题篇】numpy应用案例(一)(附python示例代码)

目录 用Python分析二手车的销售价格 用Python构建GUI应用的铅笔草图 需要的包 实现步骤 完整代码 用Python分析二手车的销售价格 如今&#xff0c;随着技术的进步&#xff0c;像机器学习等技术正在许多组织中得到大规模的应用。这些模型通常与一组预定义的数据点一起工作…...

网络割接项目

某企业准备采购2台华为设备取代思科旧款设备,针对下列问题作出解答。 (1)做设备替换的时候,如何尽可能保证业务稳定性,请给出解决方案。 a)对现网拓扑进行分析,分析现网拓扑的规划(链路类型、cost、互联IP、互联接口等信息)、分析现网流量模型(路由协议、数据流向特…...

SpringBoot整合数据可视化大屏使用

1 前言 DataV数据可视化是使用可视化应用的方式来分析并展示庞杂数据的产品。DataV旨让更多的人看到数据可视化的魅力,帮助非专业的工程师通过图形化的界面轻松搭建专业水准的可视化应用,满足您会议展览、业务监控、风险预警、地理信息分析等多种业务的展示需求, 访问地址:h…...

蓝桥杯Web前端练习题-----水果拼盘

一、水果拼盘 介绍 目前 CSS3 中新增的 Flex 弹性布局已经成为前端页面布局的首选方案&#xff0c;本题可以使用 Flex 属性快速完成布局。 准备 开始答题前&#xff0c;需要先打开本题的项目代码文件夹&#xff0c;目录结构如下&#xff1a; ├── css │ └── style.…...

[攻城狮计划]如何优雅的在RA2E1上运行RT_Thread

文章目录[攻城狮计划]|如何优雅的在RA2E1上运行RT_Thread准备阶段&#x1f697;开发板&#x1f697;开发环境&#x1f697;下载BSP&#x1f697;编译烧录连接串口总结[攻城狮计划]|如何优雅的在RA2E1上运行RT_Thread &#x1f680;&#x1f680;开启攻城狮的成长之旅&#xff0…...

1.linux操作命令

1. pwd -> 打印当前绝对工作路径。 2. ls -> 查看目录的文件名 ls -> 默认列出当前目录的全部文件名 ls . -> 列出当前目录的全部文件名(.代表当前目录) ls / -> 列出根目录下的全部文件命名 ls -a -> 列出当前目录下全部文件名(包括隐藏…...

STL--vector

vector 头文件 #include<vector>向量的定义&#xff1a; vector<int> vec&#xff1b;//定义一个vec型的向量a vector<int> vec(5); //定义一个初始大小为5的向量 vector<int> vec(5,1); //初始大小为5&#xff0c;值都为1的向量二维数组&#xff1…...

Java每日一练(20230324)

目录 1. 链表插入排序 &#x1f31f;&#x1f31f; 2. 最接近的三数之和 &#x1f31f;&#x1f31f; 3. 寻找旋转排序数组中的最小值 &#x1f31f;&#x1f31f; &#x1f31f; 每日一练刷题专栏 &#x1f31f; Golang每日一练 专栏 Python每日一练 专栏 C/C每日一…...

你掌握了吗?在PCB设计中,又快又准地放置元件

在印刷电路板设计中&#xff0c;设置电路板轮廓后&#xff0c;将零件(占地面积)调用到工作区。然后将零件重新放置到正确的位置&#xff0c;并在完成后进行接线。 组件放置是这项工作的第一步&#xff0c;对于之后的平滑布线工作是非常重要的工作。如果在接线工作期间模块不足…...

springboot学生综合测评系统

031-springboot学生综合测评系统演示录像2022开发语言&#xff1a;Java 框架&#xff1a;springboot JDK版本&#xff1a;JDK1.8 服务器&#xff1a;tomcat7 数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09; 数据库工具&#xff1a;Navicat11 开发软件&…...

【Unity3D】法线贴图和凹凸映射

1 法线贴图原理 表面着色器中介绍了使用表面着色器进行法线贴图&#xff0c;实现简单快捷。本文将介绍使用顶点和片元着色器实现法线贴图和凹凸映射&#xff0c;实现更灵活。 本文完整代码资源见→法线贴图和凹凸映射。 1&#xff09;光照原理 Phong 光照模型和 Blinn Phong 光…...

代码误写到master分支(或其他分支),此时代码还未提交,如何转移到新建分支?

问题背景 有时候&#xff0c;我们拿到需求&#xff0c;没仔细看当前分支是什么&#xff0c;就开始撸代码了。完成了需求或者写到一半发现开发错分支了。 比如此时新需求代码都在master分支上&#xff0c;提交必然是不可能的&#xff0c;所有修改还是要在新建分支上进行&#x…...

java多线程之线程安全(重点,难点)

线程安全1. 线程不安全的原因:1.1 抢占式执行1.2 多个线程修改同一个变量1.3 修改操作不是原子的锁(synchronized)1.一个锁对应一个锁对象.2.多个锁对应一个锁对象.2.多个锁对应多个锁对象.4. 找出代码错误5. 锁的另一种用法1.4 内存可见性解决内存可见性引发的线程安全问题(vo…...

如何免费使用chatGPT4?无需注册!

Poe体验真滴爽首先提大家问一个大家最关心的问题如何在一年内赚到一百万&#xff1f;用个插件给他翻译一下体验地址效果是非常炸裂的&#xff0c;那么我就将网址分分享给大家https://poe.com/前提&#xff1a;要有魔法&#xff0c;能够科学shangwangChatGPT-3 随便问GPT-4 模型…...

Android Flutter在点击事件上添加动画效果

在Android App的开发项目中&#xff0c;我们需要在点击事件上实现一个动画效果来提高用户的体验度。比如闲鱼底部中间按钮的那种。该怎么实现呢&#xff1f; 一起来看看吧 实现效果如图&#xff1a; ​实现思路 根据UI的设计图&#xff0c;对每个模块设计好动画效果&#xff0…...

VSCode嵌入式开发环境搭建

Vscode开发环境搭建 看这个链接就可以了&#xff0c;后面下载调试有点问题看下3.3。 在VSCode上部署STM32F1的开发环境 1. MXCube配置工程生成Makefile文件 借助正确的编译工具链进行编译&#xff0c; 2. 编译工具链搭建 编译工具链使用GCC的ARM版本 arm-none-eabi-gcc &am…...

数据结构之栈的使用

栈是计算机科学中一个重要的数据结构。它是一种特殊的线性表&#xff0c;只允许在一端进行进出操作。这一端被称为栈顶&#xff0c;另外一端被称为栈底。栈的特点是后进先出&#xff0c;即最后进入栈的元素会先被弹出栈。栈的应用广泛&#xff0c;例如在编译器中&#xff0c;栈…...

QMessageBox手动添加按钮并绑定按钮的信号

视频展示效果&#xff08;结合代码看效果更佳哦&#xff0c;代码在最下面&#xff09;&#xff1a; QMessageBox手动添加有重试效果的按钮效果图&#xff1a; 点击详细文本之后展开如下图&#xff1a; 图标可选&#xff1a; QMessageBox::Critical错误图标QMessageBox::NoIco…...

【C++进阶】位图和布隆过滤器

文章目录位图位图概念位图使用场景位图的结构构造setresettest完整代码布隆过滤器布隆过滤器概念布隆过滤器结构构造setresettest完整版代码位图 位图概念 所谓位图&#xff0c;就是用每一位来存放某种状态&#xff0c;适用于海量数据&#xff0c;数据无重复的场景。通常是用…...

Android开发-Android UI与布局

01 Android UI 1.1 UI 用户界面(User Interface&#xff0c;简称 UI&#xff0c;亦称使用者界面)是系统和用户之间进行交互和信息交换的媒介&#xff0c;它实现信息的内部形式与人类可以接受形式之间的转换。软件设计可分为两个部分&#xff1a;编码设计与UI设计。 1.2 Andr…...

wordpress 图片插件/seo是啥

history对象保存用户上网的历史记录&#xff0c;从窗口被打开的那一刻算起。历史记录对象是窗口对象下的一个子对象&#xff0c;它实际上是一个对象数组&#xff0c;包含了一系列的用户访问过的URL地址。保存着用户的上网历史记录&#xff0c;用于浏览器工具栏中的"Back t…...

网站建设设计广州/如何写好一篇软文

HDR技术 HDR技术就是为了增强画质表现力而存在的&#xff0c;HDR全称为High Dynamic Range&#xff0c;翻译过来就是高动态范围影像&#xff0c;这是一种获取以及处理一个场景下所有的可见光亮度范围的数码处理方法。进一步说动态范围的定义&#xff0c;是指一个场景的最亮和最…...

广州推广型网站建设/制作网页的流程步骤

路由器之家网今天精心准备的是《在线闪字》&#xff0c;下面是详解&#xff01;闪字在线制作有没有那种一笔一笔写出来的闪字&#xff1f;或者能制作很可爱很温暖闪字的网站&#xff1f;很急啊&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;&#xff01;...有没…...

河南企业网站建设/百度企业查询

华为荣耀4C从EMUI3.0安卓4.4升级到4.0 安卓版本升级到6.0&#xff0c;荣耀畅玩4C—升级教程。测试型号是CHM-TL00H &#xff0c;原系统版本是 EMUI系统3.0.安卓4.4&#xff0c;因为新版的微信以及其他APP很多都要求安卓5.0以上了&#xff0c;所以查询了网上的方法将老的华为荣耀…...

广州建网站比较有名的公司/怎样宣传自己的产品

“程序员是现存最大的手工艺人群体&#xff0c;黑客与画家的共同之处&#xff0c;在于他们都是创作者&#xff0c;都试图创作出优秀的作品。” 硅谷“创业教父”保罗 格雷厄姆如是说。 从一定角度来看&#xff0c;编程确实可以看作是一种艺术创作活动。那么我们其实可以认为&a…...

wordpress后台修改文章浏览数/最新消息新闻头条

KeepalivedLVSMysql-Cluster(7.1.10)的安装配置NDB Cluster的硬件需求&#xff1a; 管理节点:对硬件没什么要求&#xff0c;差 一点的机器完全能够胜任 数据节点:可以选择大内存&#xff0c;cpu也相对来讲不错 的&#xff0c;尤其是以后ndbmtd对多核Cpu的支持 Mysql节 点&#…...