DevOps之六 shell以及pipeline 命令部署
一 使用shell命启动spring boot 项目
1. 使用shell停止当前项目
#!/bin/sh
main() {
clear
pid=`ps -ef|grep xx.jar|grep -v grep|grep -v kill|awk '{print $2}'`
if [ -n ${pid} ]; then
echo 'start Kill Process --->'
kill -9 $pid
until [ -n $tempPid ]
do
echo 'Killing Process ... ...'
sleep 2
tempPid=`ps -ef|grep xx.jar|grep -v grep|grep -v kill|awk '{print $2}'`
done
echo 'killed device.jar <---'
fi
}
main $1
2. 使用shell拷贝替换要启动的Java包
#!/bin/sh target=/home/robot/device/jar/xx.jar
if [ -f $target ]; then
rm -rf $target
fi cp -rf /var/lib/jenkins/workspace/robot-device/target/xx.jar $target
3. 使用shell启动Java包
#!/bin/sh
echo "赋权限"
chmod -R /home/robot/device/jar/xx.jar
java -Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address= -jar /home/robot/device/jar/xx.jar
#!/bin/sh
nohup sh startup-api.sh>starup-api.log >& &
二 使用shell以及docker命令 生成镜像
docker build -t haier-robot-alarm:1.0. .
docker login -u hollysys -p hollysys-xian
docker push haier-robot-alarm:1.0.
三 使用pipeline命令发布程序
node{
def mvnHome
stage('Preparation') {
// Get some code from a GitHub repository
git branch: 'stage', credentialsId: '4ea34875-7eb6-4c8b-b9b2-f437a0aa5fb2', url: 'http://172.21.46.15/HairRobot/micro-services/zuul.git'
}
stage("build-web"){
dir('/var/lib/jenkins/workspace/robot-zuul-cd/webroot') {
//sh "rm -rf /var/lib/jenkins/workspace/robot-zuul-cd/src/main/resources/static/*"
git branch: 'stage', credentialsId: '4ea34875-7eb6-4c8b-b9b2-f437a0aa5fb2', url: 'http://172.21.46.11/HairRobot/robot-management-platform-web.git'
//replace to the target hiacloud API_URL
sh returnStdout: true, script: '''sed -i "s/const baseUrl = \'http\\:\\/\\/172.21.12.25\\:9000\';/\\/\\/const baseUrl = \'http\\:\\/\\/172.21.12.25\\:9000\';/g" src/api/Ajax.js
sed -i "s/\\/\\/const baseUrl = process.API_URL;/const baseUrl = process.API_URL;/g" src/api/Ajax.js'''
sh "npm install"
sh "npm run production"
}
}
stage('Build') {
mvnHome = tool 'M3'
echo "maven home is ${mvnHome}"
echo "${env.PATH}"
def JAVA_HOME
JAVA_HOME= tool 'JDK1.8'
echo "${JAVA_HOME}"
env.JAVA_HOME=JAVA_HOME
sh "pwd"
sh "'${mvnHome}/bin/mvn' clean package -DskipTests -X"
}
stage('push docker'){
sh "docker build -t haier-robot-zuul:1.0.0 ."
sh "docker login -u hollysys -p 1234 hollysys-xian"
sh "docker push haier-robot-zuul:1.0.0"
}
}
DevOps之六 shell以及pipeline 命令部署的更多相关文章
- Linux初学:(二)Shell环境与命令基础
博客园(FOREVER_ENJOY):http://www.cnblogs.com/zyx1314/ 本文版权归作者所有:欢迎转载!请注明文章作者和原文连接 Shell是什么? 1. Shell作为应 ...
- Shell编程-项目部署(一)
由于实际工作中经常用到需要部署项目,比较麻烦,今天记录下如何利用shell脚本完成自动部署的工作,毕竟不是专业的运维出身,写的不好,还请勿喷_^o^_ 今天以部署Django项目为演示,进行部署项目, ...
- PowerShell命令部署WSP
转载:http://www.cnblogs.com/ChunLiangZhang/archive/2012/07/18/2597335.html(作者:ChunLiang) 现在可以用SharePoi ...
- Dubbo入门到精通学习笔记(二):Dubbo管理控制台、使用Maven构建Dubbo的jar包、在Linux上部署Dubbo privider服务(shell脚本)、部署consumer服务
文章目录 Dubbo管理控制台 1.Dubbo管理控制台的主要作用: 2.管理控制台主要包含: 3.管理控制台版本: 安装 Dubbo 管理控制台 使用Maven构建Dubbo服务的可执行jar包 D ...
- Azure DevOps Server 入门实践与安装部署
一,引言 最近一段时间,公司希望在自己的服务器上安装本地版的 Azure DevOps Service(Azure DevOps Server),用于项目内的测试,学习.本着学习的目的,我也就开始学习 ...
- Bash Shell内建命令和保留字
Bash Shell内建命令和保留字命令含义!保留字,逻辑非:不做任何事,只做参数展开.读取文件并在shell中执行它alias设置命令或命令行别名bg将作业置于后台运行bind将关键字序列与read ...
- 单行bash、shell、perl命令
主题:单行经典bash.shell.perl命令 作者:luomg 摘要: 会陆陆续的写自己工作中的常用有意思的命令,争取你能看完后就能搞定常见操作, 且尽量自少提供基本shell.perl的实现方式 ...
- Shell 的source命令
source命令用法: source FileName 作用:在当前bash环境下读取并执行FileName中的命令. 注:该命令通常用命令“.”来替代. 如:source .bash_rc 与 . ...
- shell 后台执行命令
shell 后台执行命令方法: 1. nohup cmd & 后台会生成 nohup.out 文件 2.cmd >/路径/xx.log & 后台生成 xx. ...
随机推荐
- Docker 常用命令——容器
1.新建并启动容器 docker run [option] images [command][arg] #根据镜像新建容器并运行.如果本地没有镜像则从docker hub上拉取. --name ...
- eclipse的git插件安装、配置与使用
Git是一个分布式的版本控制工具,本篇文章从介绍Git开始,重点在于介绍Git的基本命令和使用技巧,让你尝试使用Git的同时,体验到原来一个版 本控制工具可以对开发产生如此之多的影响,文章分为两部分, ...
- mysql的索引和执行计划
一.mysql的索引 索引是帮助mysql高效获取数据的数据结构.本质:索引是数据结构 1:索引分类 普通索引:一个索引只包含单个列,一个表可以有多个单列索引. 唯一索引:索引列的值必须唯一 ,但允许 ...
- python新建一个表格xls并写入数据
# -*- coding:utf-8 -*- import xlwt workbook = xlwt.Workbook() # 新建一个工作簿 sheet = workbook.add_sheet(& ...
- Linux启动流程(CentOS6)
内核级别: (POST)BIOS加电自检-->(Boot Sequence)从BIOS中读取启动顺序-->读取MBR中的bootloader-->加载内核-->读取伪根--&g ...
- echarts使用方法
1.引入完整版echarts.min.js. 2.为ECharts准备一个具备大小(宽高)的Dom . <div id="main" style="width: 6 ...
- 四、spring成长之路——springIOC容器(下)
目录 5.spring注解开发(Spring扩展知识) 5.1定义配置类:@Configuration 声明一个类为IOC容器 @Bean定义一个Bean 5.2.按照条件进行注入 5.3.@Impo ...
- Hadoop分布式集群搭建_1
Hadoop是一个开源的分布式系统框架 一.集群准备 1. 三台虚拟机,操作系统Centos7,三台主机名分别为k1,k2,k3,NAT模式 2.节点分布 k1: NameNode DataNode ...
- Spark RDD理解
目录 ----RDD简介 ----RDD操作类别 ----RDD分区 ----宽依赖和窄依赖作用 ----RDD分区划分器 ----RDD到调度 返回顶部 RDD简介 RDD是弹性分布式数据集(Res ...
- 从网上下载小说_keywords:python、multiprocess
# -*- coding: utf-8 -*- __author__ = "YuDian" from multiprocessing import Pool # Pool用来创建进 ...