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

这篇具有很好参考价值的文章主要介绍了【jenkins部署】一文弄懂自动打包部署(前后台)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

序言

软件开发中,会分多个环境,开发环境、测试环境、预发布环境、生产环境,软件部署如果是纯人工一个个通过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 &

####开通防火墙9090端口
 firewall-cmd --zone=public --add-port=9090/tcp --permanent
 
 ####更新防火墙配置
 firewall-cmd --reload

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部署】一文弄懂自动打包部署(前后台)
把打包的应用发布到远程服务器
【jenkins部署】一文弄懂自动打包部署(前后台)

远程服务器生成私钥

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脚本
source /etc/profile
#!/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_NAME


echo "  =====关闭Java应用======"
PROCESS=`ps -ef |grep $APP_NAME |grep -v grep|grep hg-learn.jar|awk '{print $2}'`
for i in $PROCESS
do
  echo "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

  • 给脚本执行权限
  • 注意: source /etc/profile 脚本里面一定要增加这一行,主要是为了解决jenkins使用shell脚本执行nohup java -jar包失败问题(2023/06/08发现的问题修正),社长查了一些资料,发现大部分的文章都是增加BUILD_ID=dontKillMe,但是我这边还是启动项目失败,但是通过ssh启动脚本是可以启动项目的,怀着问题,我查阅了大量的资料,功夫不负有心人,终于被我找到问题所在了,如果jenkins和命令打包的脚本不是同一台服务器的话,需要在shell脚本里面增加source /etc/profile,不然jenkins在读取环境变量的时候,会出问题。

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

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

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

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

nodeJS插件安装

【jenkins部署】一文弄懂自动打包部署(前后台)- 安装NodeJS插件

配置nodeJS环境变量

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

创建vue项目

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

  • 构建的版本保留2天,最多存在3个构建版本
    【jenkins部署】一文弄懂自动打包部署(前后台)
  • 输入项目的git地址
  • 指定分支 master可以动态修改成其他的分支
    【jenkins部署】一文弄懂自动打包部署(前后台)
    【jenkins部署】一文弄懂自动打包部署(前后台)
  • 点击生成webHook密码,记住框起来的两个地址,需要在gitee上配置
    【jenkins部署】一文弄懂自动打包部署(前后台)
  • 填入上面记住的两个信息
    【jenkins部署】一文弄懂自动打包部署(前后台)
  • 点击测试,没有报错,说明连接成功
添加nodeJS信息

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

  • 如果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部署】一文弄懂自动打包部署(前后台)
    到这里我们已经实现把前台项目编译成文件夹运行咯,在实际部署过程中,可能存在jenkins和前台不是一台服务器的情况,所以我们还需要多操作一步
前台代码部署到另外一台服务器

【jenkins部署】一文弄懂自动打包部署(前后台)文章来源地址https://www.toymoban.com/news/detail-478411.html

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

到了这里,关于【jenkins部署】一文弄懂自动打包部署(前后台)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Jenkins的环境部署,(打包、发布、部署、自动化测试)

    一、Tomcat环境安装 1.安装JDK(Java环境) JDK下载地址:Java Downloads | Oracle 安装好后在系统环境变量里配置环境变量: ①添加JAVA_HOME 变量名:JAVA_HOME 变量值:C:Program FilesJavajdk1.8.0_181(根据自己的实际路径配置) ②添加CLASSPATH 变量名:CLASSPATH 变量值:.;%JAVA_HOME%libdt.jar;%J

    2024年01月18日
    浏览(45)
  • 基于Jenkins自动打包并部署docker环境

    目录 1、安装docker-ce 2、阿里云镜像加速器 3、构建tomcat 基础镜像  4、构建一个Maven项目 实验环境 操作系统 IP地址 主机名 角色 CentOS 7.5 192.168.200.111 git git服务器 CentOS 7.5 192.168.200.112 Jenkins git客户端 jenkins服务器 CentOS 7.5 192.168.200.113 docker web服务器 在192.168.200.113上创建远程目录

    2024年02月11日
    浏览(51)
  • 基于Jenkins自动打包并部署Tomcat环境

    目录 1、配置git主机 2、配置jenkins主机 3、配置web主机 4、新建Maven项目 5、验证 Jenkins 自动打包部署结果 Jenkins 的工作原理是先将源代码从 SVN/Git 版本控制系统中拷贝一份到本地,然后根据设置的脚本调用Maven进行 build(构建)。整个系统的关键就是 build 脚本,build 脚本告诉

    2024年02月11日
    浏览(47)
  • 17.Jenkins完成自动化 拉取,编译,打包,部署

    1.1安装gitee插件到jenkins  gitee默认不允许内网触发。----必须要配置内网穿透 NATAPP -       思考: 我们的项目和jenkins是不是都在一台服务器上。因为jenkins它所在的服务器非常耗费资源,因为jenkins本身要集成很多软件。如果这时项目也部署到当作jenkins所在的服务器,势必会导致

    2024年02月04日
    浏览(48)
  • 【K8S专题】八、Jenkins 自动打包部署配置

      项目部署有多种方式,从最原始的可运行 jar 包直接部署到 JDK 环境下运行,到将可运行的 jar 包放到 docker 容器中运行,再到现在比较流行的把可运行的 jar 包和 docker 放到 k8s 的 pod 环境中运行。每一种新的部署方式都是对原有部署方式的改进和优化,这里不着重介绍每种

    2024年02月15日
    浏览(39)
  • 前端项目打包和自动化部署(jenkins+gitee+nginx)

    1. 传统的开发模式 在传统的开发模式中,开发的整个过程是按部就班就行: 但是这种模式存在很大的弊端: 工作的不协调:开发人员在开发阶段,测试和运维人员其实是处于等待的状态。等到测试阶段,开发人员等待测试反馈bug,也会处于等待状态。 线上bug的隐患:项目准

    2024年02月01日
    浏览(47)
  • Jenkins+Maven+Gitlab+Tomcat 自动化构建打包,部署

    1、安装服务 Jenkins工具、环境、插件配置 全局变量配置 Manage JenkinstoolsJDK 安装 安装插件 Deploy to container 安装此插件,才能将打好的包部署到tomcat上     配置国内mvn源 创建maven项目 1  2   3    4    5    6    7    8     9 10  

    2024年02月05日
    浏览(58)
  • 轻松拿捏Jenkins(Linux)+Java11+Docker自动化打包部署

    注:本文由笔者小白亲手实践写作,涵盖较全,创作不易,且行且珍惜!! 历时24小时,包含Jenkins环境构建部署过程中的99%问题,确定不来看一下吗? 由于Jenkins自2.357版本之后,上新的版本需要提供Java11及以上版本的支持,且之前的版本市场上推荐的绝大多数插件已经不再

    2024年02月06日
    浏览(43)
  • 基于Jenkins自动打包并部署docker、PHP环境,ansible部署-------从小白到大神之路之学习运维第86天

    第四阶段提升 时  间:2023年8月23日 参加人:全班人员 内  容: 基于Jenkins部署docker、PHP环境 目录 一、环境部署 (一)实验环境,服务器设置 (二)所有主机关闭防火墙和selinux,修改主机名 (三)配置git主机 (四)配置jenkins主机 (五)Jenkins配置 二、基于Jenkins自动打包

    2024年02月11日
    浏览(63)
  • 小白到运维工程师自学之路 第七十九集 (基于Jenkins自动打包并部署Tomcat环境)2

      拉到最后选择构建后操作 拉到最后点击保存   访问192.168.77.19:8080/probe 账户密码都是tomcat  

    2023年08月27日
    浏览(58)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包