diff --git a/fluent-package/msi/assets/fluentd.bat b/fluent-package/msi/assets/fluentd.bat index 117b38011..cc02049c4 100644 --- a/fluent-package/msi/assets/fluentd.bat +++ b/fluent-package/msi/assets/fluentd.bat @@ -15,13 +15,40 @@ set PATH=%FLUENT_PACKAGE_TOPDIR%;%PATH% set "FLUENT_CONF=%FLUENT_PACKAGE_TOPDIR%etc/fluent/fluentd.conf" set "FLUENT_PLUGIN=%FLUENT_PACKAGE_TOPDIR%etc/fluent/plugin" -setlocal +setlocal enabledelayedexpansion set "FLUENT_PACKAGE_VERSION=%FLUENT_PACKAGE_TOPDIR%bin/fluent-package-version.rb" +set PREVENT_DUPLICATE_LAUNCH=1 +set HAS_SHORT_VERBOSE_OPTION=0 + for %%p in (%*) do ( if "%%p"=="--version" ( ruby "%FLUENT_PACKAGE_VERSION%" goto last ) + if "%%p"=="-c" set PREVENT_DUPLICATE_LAUNCH=0 + if "%%p"=="--config" set PREVENT_DUPLICATE_LAUNCH=0 + if "%%p"=="--dry-run" set PREVENT_DUPLICATE_LAUNCH=0 + if "%%p"=="--reg-winsvc" set PREVENT_DUPLICATE_LAUNCH=0 + if "%%p"=="--reg-winsvc-fluentdopt" set PREVENT_DUPLICATE_LAUNCH=0 + if "%%p"=="-v" set HAS_SHORT_VERBOSE_OPTION=1 +) + +@rem Abort if the fluentdwinsvc service is running and the config path is not specified. +if %PREVENT_DUPLICATE_LAUNCH% equ 1 ( + sc query fluentdwinsvc | findstr RUNNING > nul 2>&1 + if !ERRORLEVEL! equ 0 ( + echo Error: Can't start duplicate Fluentd instance with the default config. + if %HAS_SHORT_VERBOSE_OPTION% equ 1 ( + echo. + echo To take the version, please use '--version', not '-v' ^('--verbose'^). + ) + echo. + echo To start Fluentd, please do one of the following: + echo ^(Caution: Please be careful not to start multiple instances with the same config.^) + echo - Stop the Fluentd Windows service 'fluentdwinsvc'. + echo - Specify the config path explicitly by '-c' ^('--config'^). + exit /b 2 + ) ) endlocal diff --git a/fluent-package/msi/install-test.ps1 b/fluent-package/msi/install-test.ps1 index e5cb99a78..250edf133 100644 --- a/fluent-package/msi/install-test.ps1 +++ b/fluent-package/msi/install-test.ps1 @@ -41,6 +41,41 @@ Get-ChildItem "C:\\opt\\fluent\\*.log" | %{ } } +# Test: fluentd.bat +Start-Service fluentdwinsvc + +$proc = Start-Process "C:\\opt\\fluent\\fluentd.bat" -Wait -NoNewWindow -PassThru +if ($proc.ExitCode -ne 2) { + Write-Host "Failed to abort when already fluentdwinsvc service is running" + [Environment]::Exit(1) +} +Write-Host "Succeeded to abort when already fluentdwinsvc service is running" + +$proc = Start-Process "C:\\opt\\fluent\\fluentd.bat" -ArgumentList "--version" -Wait -NoNewWindow -PassThru +if ($proc.ExitCode -ne 0) { + Write-Host "Failed to take the version" + [Environment]::Exit(1) +} +Write-Host "Succeeded to take the version" + +$proc = Start-Process "C:\\opt\\fluent\\fluentd.bat" -ArgumentList "--dry-run" -Wait -NoNewWindow -PassThru +if ($proc.ExitCode -ne 0) { + Write-Host "Failed to dry-run" + [Environment]::Exit(1) +} +Write-Host "Succeeded to dry-run" + +$fluentdopt = "-c 'C:\opt\fluent\etc\fluent\fluentd.conf' -o 'C:\opt\fluent\fluentd.log' -v" +$proc = Start-Process "C:\\opt\\fluent\\fluentd.bat" -ArgumentList "--reg-winsvc-fluentdopt ""$fluentdopt""" -Wait -NoNewWindow -PassThru +$fluentdoptResult = Get-ItemPropertyValue -Path HKLM:\SYSTEM\CurrentControlSet\Services\fluentdwinsvc -Name fluentdopt +if ($proc.ExitCode -ne 0 -or $fluentdopt -ne $fluentdoptResult) { + Write-Host "Failed to register fluentdopt" + [Environment]::Exit(1) +} +Write-Host "Succeeded to register fluentdopt" + +# Test: Uninstall +Stop-Service fluentdwinsvc $msi -Match "fluent-package-([0-9\.]+)-.+\.msi" $name = "Fluent Package v" + $matches[1] Write-Host "Uninstalling ...${name}"