linux 以jar包的方式部署后端程序

打包,以及linux上的位置

然后执行下面两个命令,一个多服务启动,一个是单服务启动

多服务启动命令

复制代码
#!/bin/bash

# 设置JAR包的目录
JAR_DIR="/bpm/app_jar"

# 设置JAR包的名称,用空格分隔
# JAR_NAMES="platform-gateway.jar platform-authentication.jar platform-portal-svc.jar platform-flowengine-svc.jar platform-admin-svc.jar platform-runtime-svc.jar platform-designer-svc.jar platform-job-svc.jar platform-jobexecutor-svc.jar platform-cindare-svc.jar platform-logserver-svc.jar platform-springbootadmin.jar platform-msg-svc.jar platform-rules-svc.jar platform-registry.jar platform-file-svc.jar platform-mockserver.jar"

JAR_NAMES="platform-admin-svc.jar platform-portal-svc.jar platform-runtime-svc.jar platform-designer-svc.jar platform-rules-svc.jar"

start() {
    for JAR_NAME in $JAR_NAMES; do
        nohup java -server \
        -Xms2048m -Xmx3072m \
        -Xss1m \
        -XX:MetaspaceSize=300m -XX:MaxMetaspaceSize=300m \
        -XX:NewRatio=1 -XX:SurvivorRatio=8 \
        -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/bpm/hprod/"${JAR_NAME%.*}"_%p.hprof \
        -XX:ErrorFile=/bpm/logs/"${JAR_NAME%.*}"/java_error_%p.log \
        -XX:+PrintGCDetails -Xloggc:/bpm/logs/"${JAR_NAME%.*}"_gc.log -XX:+PrintGCDateStamps \
        -XX:-UseAdaptiveSizePolicy -XX:+UseG1GC -XX:MaxGCPauseMillis=500 -XX:+UnlockExperimentalVMOptions -XX:G1NewSizePercent=40 -XX:G1MaxNewSizePercent=60 -XX:InitiatingHeapOccupancyPercent=45 \
        -XX:G1HeapWastePercent=5 -XX:G1MixedGCCountTarget=8 -XX:G1OldCSetRegionThresholdPercent=10 -XX:G1ReservePercent=10 -XX:MaxTenuringThreshold=15 \
        -jar "$JAR_DIR/$JAR_NAME" >> /bpm/logs/"${JAR_NAME%.*}".log 2>&1 &
    done
}

stop() {
    for JAR_NAME in $JAR_NAMES; do
        # 根据进程名杀死对应的Java进程
        pkill -f "$JAR_NAME"
    done
}

restart() {
    stop
    sleep 5
    start
}

# 根据命令行参数执行相应的操作
case "$1" in
    "start")
        start
        ;;
    "stop")
        stop
        ;;
    "restart")
        restart
        ;;
    *)
        echo "Usage: $0 {start|stop|restart}"
        exit 1
        ;;
esac

exit 0

单个的

复制代码
nohup java -server \
	-Xms8192m -Xmx8192m \
	-Xss1m \
	-XX:MetaspaceSize=300m -XX:MaxMetaspaceSize=300m \
	-XX:NewRatio=1 -XX:SurvivorRatio=8 \
	-XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/bpm/hprod/platform-flowengine-svc_%p.hprof \
	-XX:ErrorFile=/bpm/logs/platform-flowengine-svc/java_error_%p.log \
	-XX:+PrintGCDetails -Xloggc:/bpm/logs/platform-flowengine-svc_gc.log -XX:+PrintGCDateStamps \
	-XX:-UseAdaptiveSizePolicy -XX:+UseG1GC -XX:MaxGCPauseMillis=500 -XX:+UnlockExperimentalVMOptions -XX:G1NewSizePercent=40 -XX:G1MaxNewSizePercent=60 -XX:InitiatingHeapOccupancyPercent=45 \
	-XX:G1HeapWastePercent=5 -XX:G1MixedGCCountTarget=8 -XX:G1OldCSetRegionThresholdPercent=10 -XX:G1ReservePercent=10 -XX:MaxTenuringThreshold=15 \
	-Dcom.sun.management.jmxremote \
	-Dcom.sun.management.jmxremote.port=9999   \
	-Dcom.sun.management.jmxremote.ssl=false   \
	-Dcom.sun.management.jmxremote.authenticate=false   \
	-Djava.rmi.server.hostname=100.224.32.118 \
	-Dcom.sun.management.jmxremote.rmi.port=9999  \
	-jar /bpm/app_jar/platform-flowengine-svc.jar >> /bpm/logs/platform-flowengine-svc.jar.log 2>&1 &

命令执行

复制代码
./xxx.sh  --单个
./xxxx.sh start --多个

单个传命令的方式

复制代码
#!/bin/bash

# 设置JAR包的目录
JAR_DIR="/bpm/app_jar"

# 功能函数定义
start() {
    JAR_NAME=$1
    echo "Starting $JAR_NAME..."
    nohup java -server \
        -Xms1024m -Xmx2048m \
        -Xss1m \
        -XX:MetaspaceSize=300m -XX:MaxMetaspaceSize=300m \
        -XX:NewRatio=1 -XX:SurvivorRatio=8 \
        -XX:+HeapDumpOnOutOfMemoryError -XX:HeapDumpPath=/bpm/hprod/${JAR_NAME%.*}_%p.hprof \
        -XX:ErrorFile=/bpm/logs/${JAR_NAME%.*}/java_error_%p.log \
        -XX:+PrintGCDetails -Xloggc:/bpm/logs/${JAR_NAME%.*}_gc.log -XX:+PrintGCDateStamps \
        -XX:-UseAdaptiveSizePolicy -XX:+UseG1GC -XX:MaxGCPauseMillis=500 -XX:+UnlockExperimentalVMOptions -XX:G1NewSizePercent=40 -XX:G1MaxNewSizePercent=60 -XX:InitiatingHeapOccupancyPercent=45 \
        -XX:G1HeapWastePercent=5 -XX:G1MixedGCCountTarget=8 -XX:G1OldCSetRegionThresholdPercent=10 -XX:G1ReservePercent=10 -XX:MaxTenuringThreshold=15 \
        -jar $JAR_DIR/$JAR_NAME >> /bpm/logs/${JAR_NAME%.*}.log 2>&1 &
    echo "$JAR_NAME started."
}

stop() {
    JAR_NAME=$1
    echo "Stopping $JAR_NAME..."
    pkill -f $JAR_DIR/$JAR_NAME
    echo "$JAR_NAME stopped."
}

restart() {
    JAR_NAME=$1
    echo "Restarting $JAR_NAME..."
    stop $JAR_NAME
    sleep 5
    start $JAR_NAME
    echo "$JAR_NAME restarted."
}

# 主逻辑
if [ "$#" -ne 2 ]; then
    echo "Usage: $0 {start|stop|restart} <jar-file-name>"
    exit 1
fi

ACTION=$1
JAR_NAME=$2

case $ACTION in
    start)
        start $JAR_NAME
        ;;
    stop)
        stop $JAR_NAME
        ;;
    restart)
        restart $JAR_NAME
        ;;
    *)
        echo "Invalid command. Usage: $0 {start|stop|restart} <jar-file-name>"
        exit 1
        ;;
esac

exit 0

使用

复制代码
./start-new.sh restart platform-portal-svc.jar

jsp命令查看jar包的部署情况,更多详细的命令可以自行百度

查看日志

复制代码
tail -300f platform-portal-svc.log
相关推荐
taxunjishu2 分钟前
DeviceNet 转 Modbus TCP 协议转换在 S7-1200 PLC化工反应釜中的应用
运维·人工智能·物联网·自动化·区块链
迎風吹頭髮1 小时前
UNIX下C语言编程与实践53-UNIX 共享内存控制:shmctl 函数与共享内存管理
服务器·c语言·unix
迎風吹頭髮1 小时前
Linux内核架构浅谈8-Linux内核与UNIX的传承:设计思想与特性差异
linux·运维·架构
黑马金牌编程2 小时前
Linux 服务器常见的性能调优
linux·运维·服务器·性能优化
jieyu11192 小时前
网络、主机安全扫描工具
linux·安全·系统安全
tianyuanwo2 小时前
Linux进程管理中的T状态问题分析与解决体系
linux·运维·进程管理·t状态
liuyao_xianhui3 小时前
Linux_基本指令1
linux·运维·服务器
守望时空333 小时前
Linux挂载NTFS分区指南
linux
shan~~4 小时前
linux达梦数据库操作
linux·数据库·chrome
liliangcsdn4 小时前
LLM时代基于unstructured解析非结构化pdf
linux·服务器·数据分析