Мы только что установили mrtg на наш Windows Server 2012, и мне не удается запустить его как службу. Я следую руководству здесь, но я все еще застрял.
Во-первых, если я запускаю mrtg вручную, указав файл конфигурации, он работает и генерирует графики.
Но для сервиса я файлы поместил srvany.exe
и instsrv.exe
в c:\mrtg\bin
(Я удалил номер версии из имени каталога, поэтому теперь он находится по адресу c:\mrtg
).
instsrv MRTG c:\mrtg\bin\srvany.exe
И я слил файл regedit в реестр, и я могу увидеть ключи там, если я пойду и посмотрю. Из пути к Perl видно, что я установил 64-битную версию Perl.
Windows Registry Editor Version 5.00
[HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\MRTG-PA500\Parameters]
"Application"="c:\\perl64\\bin\\wperl.exe"
"AppParameters"="c:\\mrtg\\bin\\mrtg --logging=eventlog c:\\mrtg\\bin\\mrtg-MyDevice.cfg"
"AppDirectory"="c:\\mrtg\\bin\\"
Теперь, после того как я все это сделаю, служба действительно создана, но когда я пытаюсь ее запустить, она запускается и останавливается.
Поэтому я создал учетную запись домена для службы и назначил ее службе и дал права чтения / записи / изменения каталогу mrtg и его веб-каталогу, но он все равно не запускается.
Что мне не хватает?
[Обновить]
Кроме того, если я использую командную строку, эквивалентную той, что задана в записи reg, я получаю некоторую странность.
c:\mrtg\bin>perl mrtg --logging=eventlog mrtg-mydevice.cfg
Use of uninitialized value in subroutine entry at C:/Perl64/lib/Win32/EventLog.pm line 73.
Argument "Started mrtg with config 'mrtg-mydevice.cfg'\n" isn't numeric in subroutine entry at C:/Perl64/lib/Win32/EventLog.pm line 46.
Use of uninitialized value in subroutine entry at C:/Perl64/lib/Win32/EventLog.pm line 199. Argument "WARN" isn't numeric in subroutine entry at C:/Perl64/lib/Win32/EventLog.pm line 199.
Daemonizing MRTG ...
Do Not close this window. Or MRTG will die
Use of uninitialized value in subroutine entry at C:/Perl64/lib/Win32/EventLog.pm line 73.
Use of uninitialized value in subroutine entry at C:/Perl64/lib/Win32/EventLog.pm line 199. Argument "WARN" isn't numeric in subroutine entry at C:/Perl64/lib/Win32/EventLog.pm line 199.
[Обновить]
я только что нашел это, в котором говорится, что svrany.exe не совсем подходит для Windows 7 (или Server 2012 после этого). Я знаю, что некоторые ссылки на сайте mrtg довольно старые. Может, я просто не могу использовать srvany
?
Но я думаю, у меня, вероятно, проблема с настройкой.
Ладно! Проблема заключалась в том, что srvany.exe не работал на новых моделях Windows. Но nssm.exe воля! nssm
означает не сосущий сервис-менеджер - классное имя!
Итак, я создал пакетный файл с этим.
::Monday, June 15, 2015
::http://nssm.cc/download
::Apparently, srvany.exe doesn't work right on newer Windows, so I got a 64bit nssm (non-sucking service manager) to put in its place.
::commandline directions: http://nssm.cc/commands
nssm install mrtg wperl "mrtg --logging=eventlog mrtg-mydevice.cfg"
nssm set mrtg AppDirectory c:\mrtg\bin
nssm set mrtg displayname mrtg
nssm set mrtg description "MRTG wPerl Service"
nssm set mrtg start service_auto_start
nssm start mrtg
Как только я это сделал, служба сразу заработала. Теперь я вижу nssm.exe
и wperl
(с соответствующей командной строкой) в списке процессов. И я могу изменить службу, изменив пакетный сценарий.
Итак, теперь вы можете остановить это с помощью nssm stop mrtg
и начни с nssm start mrtg
(или вы можете управлять другими службами Windows, если хотите)