jenkens自动打包 部署 配置 启动

使用ip为129的作为服务端 就是我们自己用得   用ip为130的作为jenkens部署到服务器的应用端

1.jenkens自动拉取git仓库的代码

     1)安装gitee插件到jenkens

 2)修改任务项

 

 3)因为gitee不允许内网触发  -----必须要配置内网穿透

使用natapp

 4)修改gitee远程仓库

测试:

修改idea中的代码并提交到gitee上,会自动触发jenkins---拉取--编译---打包

2.完成自动化部署

发人员提交完代码至版本控制器后,由Jenkins自动获取远程代码,自动打包,然后再自动发布的过程。

思考: jenkins打包好的项目jar在自己所在的服务器,而项目运行需要在其他服务器。需要把jenkins上打包好的jar复制到其他服务器。cp只能在本机进行复制。 scp 远程复制。

 

 scp demo1111-0.0.1-SNAPSHOT.jar root@192.168.26.130:/

scp:远程复制的命令
demo111: 被复制的文件
root@远程的ip:/远程的目录

我们再远程复制时需要输入另一台服务器167的密码. 由于后期需要jenkins软件帮你完成远程的复制功能。所以我们需要设置167这台服务免密操作  

 

2.2设置免密操作

在129 生成密钥

ssh-keygen -t rsa --一直回车

 

 

 2.2.2接下来需要将公钥导入到认证文件中

cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys

2.2.3 如果希望ssh公钥生效需满足至少下面两个条件:

  • .ssh目录的权限必须是700 r4 w2 x1

  • .ssh/authorized_keys文件权限必须是600

chmod 700 ~/.ssh
 chmod 600 ~/.ssh/authorized_keys

 将authorized_keys文件拷贝到另一台应用服务器的root用户.ssh目录下

# 在应用服务器(192.168.223.130)上用root用户创建/root/.ssh文件夹  mkdir -p /root/.ssh

# 在jenkins服务器(192.168.223.129)上将pub公钥文件拷贝到应用服务器的.ssh目录下

scp -p ~/.ssh/id_rsa.pub root@192.168.26.130:/root/.ssh/authorized_keys

测试: 第一次连接还是需要输入密码  之后就行了

发现不在需要密码

2.3 如何自动把jenkins服务器的jar复制到应用服务器上。

#!/bin/bash

echo "部署的目录和项目名称"
DIR="/data/app"
projectName="my-boot"

echo "待部署的应用服务器,可多台"
server_ips="192.168.223.167"
for server_ip in ${server_ips[@]}
do

echo "ssh连接进行备份操作"
ssh -Tq -oStrictHostKeyChecking=no root@${server_ip} <<EOF
mkdir -p $DIR/backup/${projectName}
mkdir -p $DIR/${projectName}
if [ -f "$DIR/${projectName}/${projectName}.jar" ];then
  mv $DIR/${projectName}/${projectName}.jar $DIR/backup/${projectName}/${projectName}-`date "+%Y%m%d_%H%M%S"`.jar 
fi
EOF

echo "拷贝jar包到目标服务器的tmp目录"
scp -q -oStrictHostKeyChecking=no ${WORKSPACE}/target/*.jar root@${server_ip}:/tmp/${projectName}.jar

echo "ssh远程连接进行发布操作"
ssh -q -oStrictHostKeyChecking=no root@${server_ip} <<EOF
mv /tmp/${projectName}.jar $DIR/${projectName}/${projectName}.jar

EOF

done

echo "success"

 

 然后用130 启动jar包

创建一个启动脚本

(1)编写项目的启动脚本

touch start.sh
vi start.sh
把下面的内容放入start.sh中

#!/bin/bash
set -e #任何命令出错就退出
set -o pipefail

APP_ID=my-boot
APP_DIR="/data/app"

nohup java -jar ${APP_DIR}/${APP_ID}/${APP_ID}.jar > release_out.log &
start_ok=false
if [[ $? = 0 ]];then
        sleep 3
        tail -n 10 release_out.log
        sleep 5
        tail -n 50 release_out.log
fi
aaa=`grep "Started" release_out.log | awk '{print $1}'`
if [[ -n "${aaa}" ]];then
    echo "Application started ok"
    exit 0
else
    echo "Application started error"
    exit 1
fi

 

 关闭脚本

touch stop.sh
vi stop.sh
把下面的内容放入stop.sh中

#!/bin/bash

APP_ID=my-boot
ps aux | grep ${APP_ID} | grep -v "grep" | awk '{print "kill -9 "$2}' | sh

然后修改权限

修改jenkins的权限

 然后修改代码上传gitee查看jenkens运行动态

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值