当前位置: 首页 > article >正文

NSSM 实战手册:一键将你的脚本与程序转化为 Windows 后台服务

1. NSSMWindows后台服务的万能钥匙第一次在服务器上部署Node.js应用时我盯着那个黑漆漆的命令行窗口发愁——只要关掉窗口服务就断了。直到发现了NSSM这个神器才明白原来把普通程序变成系统服务可以这么简单。NSSM全称Non-Sucking Service Manager名字虽然戏谑但功能绝对专业它能将任何EXE、BAT或脚本程序转化为Windows服务就像给程序装上永不断电的电池。与Windows自带的sc命令相比NSSM有三大杀手锏一是自带图形配置界面参数设置点点鼠标就能完成二是具备进程守护功能程序崩溃会自动重启三是支持完整的日志记录所有输出都能保存到文件。我经手过的Java后端、Python爬虫、Redis数据库甚至一些冷门的工业控制软件都用NSSM实现了7x24小时稳定运行。最让我惊喜的是它的兼容性。去年给客户部署一套古董级的VB6程序用传统方法注册服务总是报错换成NSSM后居然一次成功。现在我的运维工具箱里NSSM永远是放在最显眼位置的必备工具。2. 为什么你的项目需要NSSM想象一下这样的场景凌晨三点服务器突然重启你的数据采集脚本没有自动恢复等早上发现时已经丢失了关键时段的数据。这就是没有服务化管理的典型后果。Windows系统原生的服务管理器只认特定格式的服务程序而像Python脚本、Node应用这些开发者日常使用的工具链99%都不具备原生服务能力。NSSM解决的正是这个痛点。它就像个万能适配器能让各种程序享受系统级服务待遇开机自启服务器重启后自动恢复业务后台运行不需要保持登录状态或打开终端崩溃重启程序异常退出时自动拉起统一管理通过标准服务控制台监控状态最近给电商客户部署价格监控系统时我们用NSSM托管了十几个Python爬虫。某天某个爬虫因为网站改版频繁崩溃全靠NSSM的自动重启功能撑过了紧急修复期。客户后来看到服务日志里密密麻麻的重启记录都惊了这要人工盯着早累死了3. 快速上手NSSM3.1 下载与安装NSSM的官网nssm.cc虽然停止更新了但2.24版本经过多年实战检验非常稳定。下载时注意选择对应系统位数的版本我习惯把解压后的文件夹放在C:\Tools\nssm这样的固定路径方便以后调用。这里有个小技巧在环境变量PATH里添加NSSM的路径以后在任何位置都能直接运行nssm命令。具体操作是右键此电脑选择属性进入高级系统设置点击环境变量在系统变量的Path中添加NSSM目录3.2 命令行基础操作NSSM的所有功能都能通过命令行完成最常用的几个命令我整理成了这个表格功能命令格式示例安装服务nssm install 服务名nssm install MyApp启动服务nssm start 服务名nssm start MyApp停止服务nssm stop 服务名nssm stop MyApp重启服务nssm restart 服务名nssm restart MyApp删除服务nssm remove 服务名 confirmnssm remove MyApp confirm编辑配置nssm edit 服务名nssm edit MyApp第一次使用时建议先用nssm install调出图形界面熟悉配置项。等熟练后可以尝试直接编辑注册表来批量配置效率更高。4. 实战案例不同类型程序的服务化4.1 Python脚本变身记上周刚用NSSM部署了一个Python数据清洗脚本这里分享详细步骤准备Python环境echo off C:\Python39\python.exe E:\scripts\data_cleaner.py把上面内容保存为run.bat这是为了避免路径问题以管理员身份运行CMD执行nssm install DataCleaner在图形界面配置Application Path: C:\Windows\System32\cmd.exeArguments: /c E:\scripts\run.batStartup Directory: E:\scripts在I/O标签页设置日志输出路径点击Install Service完成安装关键技巧在于用cmd.exe作为载体来运行Python脚本这样能确保所有环境变量正常加载。有个客户曾经直接指向python.exe导致导入第三方库失败就是这个原因。4.2 Java Spring Boot项目部署对于Spring Boot的jar包配置稍有不同安装服务时指定java.exe路径nssm install SpringService配置参数Path: C:\Program Files\Java\jdk-11\bin\java.exeArguments: -jar E:\apps\spring-app.jar --server.port8080设置JVM参数-Xms512m -Xmx1024m在Details标签设置服务描述Display Name: 订单中心服务Description: 处理电商订单业务逻辑特别注意当需要更新jar包时正确的流程是停止服务nssm stop SpringService替换jar文件启动服务nssm start SpringService直接覆盖正在运行的jar会导致文件锁定问题这是我踩过的坑。5. 高级配置与故障排查5.1 环境变量配置某些程序依赖特定环境变量可以在NSSM的Environment标签页添加。比如部署Go语言程序时需要设置GOPATH点击Edit service进入配置切换到Environment标签添加变量名GOPATH值设为你的工作目录勾选继承系统环境变量有个常见误区直接在系统环境变量里设置后就不管了。其实服务运行时加载的环境变量可能不同最好在NSSM里显式指定。5.2 服务依赖管理如果服务之间有启动顺序要求比如数据库服务要先于应用服务启动编辑应用服务的配置在Dependencies标签输入依赖的服务名多个服务用逗号分隔如MySQL,Redis曾经部署过一套微服务系统因为没设置依赖关系导致应用启动时报数据库连接失败。后来加上这个配置就再没出过问题。5.3 日志分析技巧NSSM的日志功能比很多人想象的强大在I/O标签可以同时配置stdout和stderr输出建议启用日志轮转防止单个文件过大用type 日志文件 | find ERROR快速检索错误去年排查一个内存泄漏问题时就是通过分析NSSM的日志发现服务每隔24小时就会增长200MB内存。最终定位到是某个定时任务没有释放资源。6. 服务管理的最佳实践经过几十次实战部署我总结出这些经验命名规范服务名加上业务前缀如ECOM_OrderService权限控制为服务配置专用系统账户不要用Administrator监控策略配合任务计划定期检查服务状态版本管理记录每个服务的NSSM配置版本最近帮一家医院部署检验仪器对接服务时我们为每台设备创建独立服务账户并设置不同的启动延时。这样即使同时开机也不会造成端口冲突客户直呼专业。对于需要批量管理的场景可以编写PowerShell脚本自动化操作。比如这个一键检查所有服务状态的脚本$services (Service1,Service2,Service3) foreach ($svc in $services) { $status nssm status $svc Write-Host $svc : $status }把这些技巧用好了你的Windows服务管理水平绝对能超过90%的运维人员。

相关文章:

NSSM 实战手册:一键将你的脚本与程序转化为 Windows 后台服务

1. NSSM:Windows后台服务的万能钥匙 第一次在服务器上部署Node.js应用时,我盯着那个黑漆漆的命令行窗口发愁——只要关掉窗口,服务就断了。直到发现了NSSM这个神器,才明白原来把普通程序变成系统服务可以这么简单。NSSM全称Non-Su…...

从游戏到网页:5大3D引擎实战应用场景全解析(UE/Unity/Three.js等)

从游戏到网页:5大3D引擎实战应用场景全解析(UE/Unity/Three.js等) 在数字内容创作领域,3D引擎的选择往往决定了项目的成败。就像木匠需要根据家具类型选择不同工具一样,开发者也需要根据项目需求匹配合适的3D引擎。本文…...

【虚拟样机技术】Adams-Solidworks-Matlab联合仿真进阶实践——基于命令流的自动化建模与参数优化

1. 虚拟样机技术概述 虚拟样机技术是现代工程设计中不可或缺的工具,它通过计算机仿真来模拟物理系统的行为,帮助工程师在产品实际制造前预测其性能。这项技术广泛应用于机械、汽车、航空航天等领域,能够显著缩短开发周期、降低研发成本。 在虚…...

别再纠结选哪个了!手把手教你用Kilo Code一键整合Cline和Roo Code的核心功能

告别选择困难:Kilo Code一站式整合Cline与Roo Code实战指南 每次启动新项目时,你是否也经历过这样的纠结时刻?面对Cline精准的Plan/Act模式心动不已,却又舍不得Roo Code的多角色协作能力。现在,一个更聪明的选择摆在面…...

Halcon实战:5分钟搞定离散点拟合圆(附完整代码与参数详解)

Halcon实战:5分钟掌握离散点拟合圆的精髓与参数调优 第一次接触Halcon的圆拟合功能时,我被它强大的算法和复杂的参数列表弄得晕头转向。直到在工业视觉检测项目中,需要快速定位数百个圆形零件的位置,才真正体会到fit_circle_conto…...

别再只盯着参数了!聊聊数据中心交换机选型时,CLOS、Crossbar这些硬件架构到底该怎么看?

数据中心交换机硬件架构实战指南:从CLOS到Crossbar的智能选型策略 在数据中心网络规划中,工程师们常陷入参数对比的泥潭——背板带宽、端口密度、转发速率这些冰冷数字背后,真正决定设备长期价值的却是鲜少被深入讨论的硬件架构设计。当某金融…...

(aaa-) snap 不走系统代理,也不走终端的代理?:ubuntu官方:snap-store-proxy 的使用方法 (***)

⚠️ 注意:Snap 应用运行在沙箱中,默认不使用系统或终端环境变量(如 http_proxy),因此必须通过 snap set system proxy.* 显式配置 。 ## 官方方法,个人用途时,据说麻烦。 snap-store-proxy sna…...

MATLAB里给二自由度机械臂装上‘智能大脑’:手把手实现模糊PID轨迹跟踪仿真

为二自由度机械臂注入智能:模糊PID控制的MATLAB实战解析 在机器人控制领域,让机械臂精准跟踪预定轨迹一直是个令人着迷的挑战。传统PID控制器虽然结构简单,但在面对复杂非线性系统时往往力不从心。想象一下,如果给机械臂装上能够&…...

DCCRN-E: Enhancing Real-Time Speech Clarity with Phase-Aware Complex Masking

1. 实时语音增强的挑战与DCCRN-E的突破 想象一下你在嘈杂的咖啡厅视频会议时,对方总是要求你重复说话内容;或是智能音箱在厨房油烟机轰鸣时完全听不懂指令——这些正是实时语音增强技术要解决的核心痛点。传统方法往往面临两难选择:要么牺牲处…...

Cadence Allegro 17.4实战指南:高效导出PCB设计中的IPC网表与生产文件

1. 从设计到生产:为什么IPC网表如此重要? 在PCB设计流程中,很多工程师容易忽视生产文件的导出环节,直到工厂反馈"文件不完整"才手忙脚乱。我经历过一次惨痛教训:设计好的六层板因为坐标文件格式错误&#x…...

高通QUPv3安全配置与多协议访问控制解析

1. 高通QUPv3架构与安全隔离基础 在嵌入式系统开发中,硬件资源的安全隔离是确保系统稳定性的关键。高通QUPv3(Qualcomm Universal Peripheral v3)作为第三代通用外设接口控制器,其核心价值在于通过TrustZone技术实现物理硬件资源的…...

【WebRTC】Webrtc-streamer实战:从RTSP到WebRTC的低延迟流媒体转发

1. WebRTC-streamer 是什么? WebRTC-streamer 是一个开源工具,专门用于将传统流媒体协议(如 RTSP、RTMP)转换为 WebRTC 流。它的核心功能是充当一个桥梁,把摄像头、屏幕录制、本地文件等媒体源,通过 WebRTC…...

单相并网逆变器MATLAB仿真:离网仿真与PLL锁相环下的电感电流谐波含量THD分析

单相并网逆变器matlab仿真。 包括离网仿真,PLL锁相环等。 电感电流的谐波含量THD较小,仿真效果较好。搞过单相并网逆变器的都知道,仿真这玩意儿就像炒菜,火候差一点味道就变了。今天咱们直接上干货,在Matlab里搭个能随…...

JavaWeb —— 过滤器 (Filter) 与监听器 (Listener) 全解析(附代码)

过滤器(Filter)和监听器(Listener)是 JavaWeb 三大组件(Servlet、Filter、Listener)中的重要成员,与 Servlet 协同构成 JavaWeb 的基础骨架。过滤器负责拦截请求与响应,实现统一预处…...

JavaWeb ——HttpServletRequest 请求对象(附代码)

HttpServletRequest 是 JavaWeb 三大对象之一,封装了客户端向服务器发送的所有请求数据,是处理前端请求、获取参数、实现请求转发的工具。一、HttpServletRequest 1. 作用当客户端发送 HTTP 请求到 Tomcat 服务器时,Tomcat 会为每一次请求创建…...

COMSOL锂枝晶应力模型:到手即用

comsol锂枝晶应力模型,到手就能用。打开COMSOL看到锂枝晶模型就手痒?先别急着点"计算",咱们得把应力场和电化学揉明白了。模型库里的枝晶生长模块虽然自带基础设置,但想要真实模拟SEI膜破裂和机械变形,得自己加亿点点细…...

深入理解 synchronized:到底锁的是谁?

在 Java 多线程并发编程里,synchronized 是保证线程安全的核心关键字,但很多开发者只知道它能加锁,却不清楚它到底锁的是什么、不同写法锁的范围有何区别。这篇文章就把 synchronized 的锁对象、作用范围、经典测试用例一次性讲透&#xff0c…...

避坑指南:Containerd镜像加速新旧版本配置差异详解

Containerd镜像加速配置全解析:从版本差异到最佳实践 在云原生技术栈中,容器运行时作为基础组件的重要性不言而喻。作为Docker的轻量级替代方案,Containerd凭借其稳定性和高性能逐渐成为Kubernetes生态中的主流选择。然而,在实际生…...

2026-03-22 全国各地响应最快的 BT Tracker 服务器(联通版)

数据来源:https://bt.me88.top 序号Tracker 服务器地域网络响应(毫秒)1http://211.75.205.187:80/announce上海联通192http://211.75.210.221:6969/announce江苏镇江联通223http://93.158.213.92:1337/announce北京联通1284udp://176.99.7.59:6969/announce天津联通…...

2026年03月21日最热门的开源项目(Github)

根据本期榜单的数据分析,可以提取出以下几个关键点: 1. 项目种类与趋势 语言分布: 此榜单中的项目主要采用 JavaScript、TypeScript 和 Python 等语言,显示了这些编程语言在人工智能及相关技术领域的广泛应用。项目类型: 许多项目都集中在人…...

Comsol 模拟电击穿与电树枝现象

comsol 电击穿,电树枝,通过消耗复合材料静电能,形成随机电击穿通道,可根据SEM 照片制定不同的击穿路径,同时考虑晶粒与晶界不同的击穿场强,由于晶界的阻挡作用,击穿强度增加。 晶界面设置不同的…...

基于MATLAB的单相双极性SPWM逆变电路系统设计:探索SVPWM的独特魅力

基于MATLAB的单相双极性SPWM逆变电路系统设计 本设计包括设计报告,仿真程序。 系统优势 通过对比方波逆变器和正弦波逆变器,阐述了SVPWM逆变器在改善输出波形质量方面的优势如下: (1)谐波抑制: 方波逆变器的…...

【手把手教程】阿里云OpenClaw一键部署指南,两步解锁龙虾AI助理!

2026年,开源AI智能体OpenClaw(昵称“龙虾AI”)凭借其“能动手做事”的颠覆性能力,迅速成为技术圈与普通用户热议的焦点。这款以红色龙虾为图标的AI工具,不仅支持文件管理、浏览器自动化、代码编写等本地化操作&#xf…...

3DSlicer实战:从零开始完成冠脉精准分割

1. 为什么选择3DSlicer进行冠脉分割 第一次接触医学影像分析的朋友可能会问:市面上这么多专业软件,为什么偏偏推荐3DSlicer?我刚开始做心脏CT分析时也纠结过这个问题,实测对比过多个工具后,发现3DSlicer有三大不可替代…...

别再只用pretrained=True了!timm库加载模型权重的5种实战姿势(附避坑清单)

解锁timm库模型权重加载的5种高阶玩法:从精准控制到性能优化 在深度学习项目实践中,模型权重的加载远不止pretrainedTrue这么简单。当你需要处理自定义权重、进行模型微调或优化加载性能时,timm库提供了丰富的底层控制接口。本文将深入剖析五…...

OpenCloudOS 8实战:从零构建高性能WordPress企业官网

1. 企业官网与个人博客的技术差异 很多刚接触WordPress的朋友可能觉得,搭建企业官网和个人博客没什么区别。但实际在企业级应用中,流量压力、安全要求和功能复杂度都完全不同。我去年帮一家50人规模的科技公司迁移官网时就深有体会——他们原先用共享主机…...

鸿蒙HarmonyOS开发踩坑记:POST请求参数到底该放哪儿?别再用拼接URL的老办法了!

鸿蒙HarmonyOS开发实战:POST请求参数传递的正确姿势与深度解析 作为一名从Android转向HarmonyOS开发的程序员,我最初也陷入了POST请求传参的困惑。在Android世界里,Retrofit或OKHttp早已帮我们封装好了POST请求的参数处理,但在Har…...

别再死记硬背了!用Keil5和STM32F103C8T6搞懂GPIO八种模式,看这篇就够了

从电路原理到实战应用:深度解析STM32 GPIO八种工作模式 理解GPIO的本质 当我们第一次接触STM32的GPIO时,常常会被各种模式搞得晕头转向。与其死记硬背,不如从电路设计的角度来理解GPIO的本质。GPIO(General Purpose Input/Output&…...

Uniapp实战:5分钟搞定谷歌地图选点定位(附完整代码与避坑指南)

Uniapp集成谷歌地图选点功能的完整实现方案 1. 谷歌地图在Uniapp中的应用场景 对于面向海外市场的Uniapp应用开发,谷歌地图集成是一个常见需求。无论是电商应用的收货地址选择、社交应用的打卡功能,还是出行服务的定位服务,都需要可靠的地图选…...

重复文件处理的三种方案对比:删除、压缩还是硬链接?EternalBlaze实测报告

随着数字资产的不断累积,重复文件已成为困扰众多计算机用户的普遍问题。 面对这一挑战,业界形成了三种主流处理方案:直接删除、压缩归档以及硬链接合并。 每种方案各有优劣,适用于不同的应用场景。 本文将通过实测对比&#xf…...