【自用】通信内网部署rzgxxt项目_01,后端pipeDemo部署(使用nssm.exe仿照nohup)

server/2024/12/22 18:32:42/

做完这些工作之后,不要忘记打开 Windows Server 的防火墙端口,8181、8081、8080、22、443、1521
做完这些工作之后,不要忘记打开 Windows Server 的防火墙端口,8181、8081、8080、22、443、1521
做完这些工作之后,不要忘记打开 Windows Server 的防火墙端口,8181、8081、8080、22、443、1521

一、准备工作

1.准备 nssm 软件

下载地址:https://nssm.cc/download

2.进入 nssm.exe 目录,并测试能否调用 nssm 命令(也许能通过配置环境变量解决)

cd D:\HongYu\projects\rzgxxt\B_BackendNohupService\nssm-2.24\win64
d:nssm

在这里插入图片描述

3.(可选)如不想每次都进入 nssm 目录,运行 nssm 命令,可配置环境变量

配置系统环境变量 -> Path:
新增变量:

X:\XXX\nssm-2.24\win64

在这里插入图片描述

二、配置脚本、创建 NSSM 服务

1.创建批处理 bat 脚本

找个地方先创建 txt,写入脚本内容,然后改 .bat 文件

创建的脚本文件,它除了运行 jar 包之外,还包含以下内容:
· 每天生成 log 日志到指定目录
· 设置JVM初始堆大小 6g,最大堆大小 24g:-Xms6g -Xmx24g

在这里插入图片描述

在这里插入图片描述

脚本内容:

@echo off
:: 设置日志目录
set LOG_DIR=D:\HongYu\projects\rzgxxt\B_BackendLogFiles:: 检查日志目录是否存在,如果不存在则创建
if not exist "%LOG_DIR%" mkdir "%LOG_DIR%":: 生成当前日期的日志文件名 (格式:YYYY-MM-DD)
for /f "tokens=2 delims==" %%I in ('"wmic os get localdatetime /value"') do set DATETIME=%%I
set DATE=%DATETIME:~0,4%-%DATETIME:~4,2%-%DATETIME:~6,2%:: 定义日志文件路径
set LOG_FILE=%LOG_DIR%\PipeDemo_%DATE%.log:: 启动 Java 程序,将输出重定向到日志文件
echo Starting Java application with Xms=6g and Xmx=24g...
D:\java\jdk-1.8\bin\java.exe -Xms6g -Xmx24g -jar D:\HongYu\projects\rzgxxt\A_Backend\PipeDemo_tongXinNeiWangBan.jar >> "%LOG_FILE%" 2>&1

测试 .bat 文件功能性:
能够正常生成日志。

在这里插入图片描述

2.开启 nssm 配置窗口,准备创建服务 PipeDemoService

nssm install PipeDemoService

在这里插入图片描述

3.配置 nssm service installer - Application 栏目

Path:

D:\HongYu\projects\rzgxxt\B_BackendNohupService\PipeDemo_ServerStarter\start_pipe_with_logs.bat

Startup directory:
jar包所在的位置。

D:\HongYu\projects\rzgxxt\B_BackendNohupService\PipeDemo_ServerStarter

Arguments:
填写其他逻辑,但是,因为我们已经在 .bat 中写了,所以什么都不填写就好。

在这里插入图片描述

4.配置 nssm service installer - Exit action 栏目(看门狗)

配置如下:

在这里插入图片描述
这些参数和设置,让 GPT 解释一下:

在这里插入图片描述

5.配置 nssm service installer - Environment 栏目(配置JAVA项目运行环境)

配置如下:

在这里插入图片描述

内容:

JAVA_HOME=D:\java\jdk-1.8
PATH=%JAVA_HOME%\bin;%PATH%

勾选项说明(我们不勾选,只是说明一下这个的功能):
在这里插入图片描述

6.配置 nssm service installer - Shutdown 栏目(配置如何关闭程序的流程)

配置如图:

在这里插入图片描述

解释如下:

在这里插入图片描述

7.配置 nssm service installer - 完成配置,Install Service!

如图:

在这里插入图片描述

8.运行刚刚配置的服务,并查看是否成功

启动服务:

nssm start PipeDemoService

在这里插入图片描述

cmd查看服务运行情况:

nssm status PipeDemoService

在这里插入图片描述

TIPS:如何删除已经创建的服务?

nssm remove 服务名 confirm

在这里插入图片描述

9.看看我们的服务,是否作为一个真正的服务运行

win + R,运行。
运行:services.msc
查找服务名:PipeDemoService
找到了!

在这里插入图片描述

10.服务意外终止,是否可自行恢复?

这个暂时无法测试,因为 NSSM 的逻辑是:
只在非正常程序崩溃时进行重启,如果我们只是在windows服务中停止服务,或者在命令行中通过ctrl c进行停止,NSSM都会将此类行为视为“人为停止”,并不会触发重启。


http://www.ppmy.cn/server/152294.html

相关文章

cenos如何升级git到2以上版本

1:先卸载旧的版本: # 卸载源默认安装的git $ git --version git version 1.8.3.1 $ sudo yum remove git2: 安装新的git版本 编译 配置环境变量 下载相关依赖 并安装 [rootlocalhost /]# yum install curl-devel expat-devel openssl-devel zlib-devel gcc […

使用html2canvas库对可滚动的dom节点导出全量的图片

页面的dom节点样式 想要导出的图片样式 做法 1,使用html2canvas库 先在项目中安装:npm install html2canvas在vue文件中引用: import html2canvas from "html2canvas";2, 对于dom节点,不能有overflow&…

【从零开始入门unity游戏开发之——C#篇20】C#面向对象的封装——静态成员(`static`)(静态字段、静态方法、静态属性、静态构造函数、静态类)

文章目录 静态成员(static)1、静态成员的特点:2、为什么可以直接点出来使用?3、不同的静态成员介绍3.1. 静态字段3.2. 静态方法3.3. 静态属性3.4. 静态构造函数3.5. 静态类 4、静态成员的优缺点优点:缺点: …

CTFshow-文件上传(Web151-170)

CTFshow-文件上传(Web151-170) 参考了CTF show 文件上传篇(web151-170,看这一篇就够啦)-CSDN博客 Web151 要求png,然后上传带有一句话木马的a.png,burp抓包后改后缀为a.php,然后蚁剑连接,找fl…

C++面向对象三大特性之——继承

C面向对象三大特性之——继承 一.继承的概念及定义1.1概念1.2 继承的定义1.3继承基类成员访问方式的变化 二.基类和派生类对象赋值转换三.继承中的作用域四. 派生类的默认成员函数4.1.派生类构造函数4.2派生类拷贝构造函数4.3派生类的赋值重载函数(operator&#xf…

使用ElasticSearch实现全文检索

文章目录 全文检索任务描述技术难点任务目标实现过程1. java读取Json文件,并导入MySQL数据库中2. 利用Logstah完成MySQL到ES的数据同步3. 开始编写功能接口3.1 全文检索接口3.2 查询详情 4. 前端调用 全文检索 任务描述 在获取到数据之后如何在ES中进行数据建模&a…

音视频入门基础:MPEG2-TS专题(19)——FFmpeg源码中,解析TS流中的PES流的实现

一、引言 FFmpeg源码在解析完PMT表后,会得到该节目包含的视频和音频信息,从而找到音视频流。TS流的音视频流包含在PES流中。FFmpeg源码通过调用函数指针tss->u.pes_filter.pes_cb指向的回调函数解析PES流的PES packet: /* handle one TS…

Kafka部署

部署命令 wget https://archive.apache.org/dist/kafka/2.6.0/kafka_2.13-2.6.0.tgz tar -xzvf kafka_2.13-2.6.0.tgz mv kafka_2.13-2.6.0 kafka useradd kafka yum install java mkdir /home/kafka/logs vi /home/kafka/kafka/config/server.properties /home/kafka/kafka…