国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開(kāi)發(fā) > Java > 正文

詳解SpringBoot注冊(cè)Windows服務(wù)和啟動(dòng)報(bào)錯(cuò)的原因

2024-07-14 08:43:44
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

Windows系統(tǒng)啟動(dòng)Java程序會(huì)彈出黑窗口。黑窗口有幾點(diǎn)不好。首先它不美觀;其次容易誤點(diǎn)導(dǎo)致程序關(guān)閉;但最讓我匪夷所思的是:將鼠標(biāo)光標(biāo)選中黑窗口日志信息,程序竟然不會(huì)繼續(xù)執(zhí)行,日志也不會(huì)繼續(xù)輸出。從而導(dǎo)致頁(yè)面一直處于請(qǐng)求狀態(tài)。回車(chē)后程序才能正常執(zhí)行。同時(shí)客戶希望我們能部署在Windows系統(tǒng)上并且做到開(kāi)機(jī)自動(dòng)啟動(dòng)。針對(duì)以上需求將系統(tǒng)程序注冊(cè)成Windows服務(wù)變得尤為重要。

針對(duì)于SpringBoot程序,目前主流的方法是采用winsw,簡(jiǎn)單方便。可是在開(kāi)發(fā)過(guò)程中,針對(duì)不同的系統(tǒng),啟動(dòng)服務(wù)可能會(huì)出現(xiàn)意想不到的結(jié)果。同樣的配置方法,在win10可以成功注冊(cè)并啟動(dòng)服務(wù)。而在windows server 2012 卻啟動(dòng)失敗。這里分享我的經(jīng)驗(yàn)。

注冊(cè)windows服務(wù)制作流程

winsw是?款可以將可執(zhí)?程序安裝成Windows Service的開(kāi)源??具,官地址, 下載地址

制作步驟:

第一步:將springboot項(xiàng)目打包成MyServer.jar

第二步:將下載的WinSW.NET2.exe 改名為MyServer.exe

第三步:將下載的sample-minimal.xml 改名為MyServer.xml

第四步:注冊(cè)和啟動(dòng)服務(wù)

這里重點(diǎn)介紹 sample-minimal.xml 文件

<service> <!-- Windows 服務(wù)唯一標(biāo)識(shí)ID--> <id>My Server</id> <!-- Windows 服務(wù)名稱-->  <name>My Server</name>  <!-- Windows 服務(wù)描述-->  <description>This service is a service cratead from a minimal configuration</description>  <!-- 啟動(dòng)的可執(zhí)行文件的路徑,如果已經(jīng)配置環(huán)境變量,則不必寫(xiě)全路徑(則其實(shí)是一個(gè)坑) --> <executable>java</executable>  <arguments> -jar MyServer.jar --spring.datasource.url=jdbc:mysql://localhost:3306/database </arguments>  <!-- 日志路徑,若目錄不存在,則默認(rèn)為配置文件所在的同一目錄-->  <logpath>ServerPath/log/dashboard/</logpath>  <!-- 日志模式,默認(rèn)為append追加模型,rotate為旋轉(zhuǎn)模式--> <logmode>rotate</logmode> </service>

executable:?jiǎn)?dòng)可執(zhí)行文件的全路徑,如果配置環(huán)境變量,則可以簡(jiǎn)寫(xiě),所有這里填寫(xiě)Java

arguments:命令執(zhí)行的參數(shù)

logpath:配置日志路徑

logmode:日志輸出模式,默認(rèn)為append,官方文檔

  • append (追加模式)其特點(diǎn)是將日志文件全部輸出在一個(gè)文件中,這個(gè)文件可能會(huì)越來(lái)越大。
  • rotate(旋轉(zhuǎn)模式,推薦)當(dāng)日志文件大小達(dá)到10兆(默認(rèn)值),winsw會(huì)將日志重新輸出到另外一份日志文件,最多保留8個(gè)(默認(rèn)值)。
  • reset(重置模式)每次重啟服務(wù)都會(huì)重置日志文件。
  • none(忽略模式)幾乎不會(huì)生成日志文件。

winsw常用命令

  • MyServer.exe install:安裝服務(wù)
  • MyServer.exe uninstall:刪除服務(wù)
  • MyServer.exe start:?jiǎn)?dòng)服務(wù)
  • MyServer.exe stop:停?服務(wù)
  • MyServer.exe restart:重啟服務(wù)
  • MyServer.exe status:輸出當(dāng)前服務(wù)的狀態(tài)

MyServer.exe 是WinSW.NET2.exe文件。在win10系統(tǒng)上一次成功,沒(méi)有多余的煩惱。可生活哪有這么容易,在windows server 2012 r2的系統(tǒng)上啟動(dòng)失敗。有錯(cuò)誤不可怕,可怕的是不會(huì)找錯(cuò)誤日志。

SpringBoot,注冊(cè),Windows服務(wù),啟動(dòng)報(bào)錯(cuò)

啟動(dòng)windows服務(wù)失敗

服務(wù)啟動(dòng)成功后自動(dòng)關(guān)閉,配置的日志文件也沒(méi)有生成。嘗試用cmd執(zhí)行java -jar的命令,服務(wù)可以正常啟動(dòng)。但可具體是什么錯(cuò)誤卻不得而知。其實(shí)Windows服務(wù)是有日志管理的。選擇:控制面板---管理工具---事件查看器---window日志---應(yīng)用程序---找出對(duì)應(yīng)服務(wù)的日志。如下:

Service cannot be started. System.ComponentModel.Win32Exception: The system cannot find the file specified at System.Diagnostics.Process.StartWithCreateProcess(ProcessStartInfo startInfo) at winsw.WrapperService.StartProcess(Process processToStart, String arguments, String executable) at winsw.WrapperService.OnStart(String[] _) at System.ServiceProcess.ServiceBase.ServiceQueuedMainCallback(Object state)

提示很清楚,系統(tǒng)沒(méi)有找到指定文件,而在winsw的xml文件中就已經(jīng)配置了executable,并且配置了環(huán)境變量。那為什么還提示文件沒(méi)有找到?抱著試一試的心態(tài),將java改為了全路徑。重新注冊(cè)服務(wù)并啟動(dòng),結(jié)果服務(wù)啟動(dòng)成功了。一肚子的火不知道往那撒。

為了避免這種事情再次發(fā)生,決定將executable的內(nèi)容設(shè)置成Java的全路徑,于是簡(jiǎn)單寫(xiě)了一個(gè)bat文件。

@echo off# 獲取java環(huán)境變量 set JAVA_HOME=%JAVA_HOME%echo %JAVA_HOME%# 替換java路徑setlocal enabledelayedexpansionset file=%cd%/MyServer.xmlset file_tmp=%cd%/MyServer_tmp.xmlset source=JAVAHOMEset replaced=%JAVA_HOME%/bin/javafor /f "delims=" %%i in (%file%) do (  set str=%%i    set "str=!str:%source%=%replaced%!"    echo !str!>>%file_tmp%)move "%file_tmp%" "%file%"# 注冊(cè)并啟動(dòng)服務(wù)MyServer.exe uninstallMyServer.exe installMyServer.exe startEXIT 

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持VeVb武林網(wǎng)。


注:相關(guān)教程知識(shí)閱讀請(qǐng)移步到JAVA教程頻道。
發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 濮阳市| 河南省| 湘阴县| 镇原县| 绥阳县| 阿瓦提县| 禄丰县| 玉山县| 丽江市| 平乡县| 商城县| 东台市| 杨浦区| 驻马店市| 台东县| 白河县| 五指山市| 红安县| 手游| 灵川县| 尤溪县| 九龙县| 周宁县| 板桥市| 中牟县| 德江县| 英吉沙县| 武川县| 平泉县| 汉阴县| 巴中市| 方城县| 南丹县| 清丰县| 阿荣旗| 永川市| 河北省| 若尔盖县| 琼中| 吕梁市| 陵川县|