blob: 569374a89d26d2680ac1f4a767803705faaaceec [file] [log] [blame]
@REM
@REM Licensed to the Apache Software Foundation (ASF) under one
@REM or more contributor license agreements. See the NOTICE file
@REM distributed with this work for additional information
@REM regarding copyright ownership. The ASF licenses this file
@REM to you under the Apache License, Version 2.0 (the
@REM "License"); you may not use this file except in compliance
@REM with the License. You may obtain a copy of the License at
@REM
@REM http://www.apache.org/licenses/LICENSE-2.0
@REM
@REM Unless required by applicable law or agreed to in writing,
@REM software distributed under the License is distributed on an
@REM "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
@REM KIND, either express or implied. See the License for the
@REM specific language governing permissions and limitations
@REM under the License.
@REM
@echo off
@REM set cmd format
chcp 65001
title IoTDB DataNode
echo ````````````````````````
echo Starting IoTDB DataNode
echo ````````````````````````
@REM -----------------------------------------------------------------------------
@REM SET JAVA
PATH %PATH%;%JAVA_HOME%\bin\
set "FULL_VERSION="
set "MAJOR_VERSION="
set "MINOR_VERSION="
for /f tokens^=2-5^ delims^=.-_+^" %%j in ('java -fullversion 2^>^&1') do (
set "FULL_VERSION=%%j-%%k-%%l-%%m"
IF "%%j" == "1" (
set "MAJOR_VERSION=%%k"
set "MINOR_VERSION=%%l"
) else (
set "MAJOR_VERSION=%%j"
set "MINOR_VERSION=%%k"
)
)
set JAVA_VERSION=%MAJOR_VERSION%
@REM we do not check jdk that version less than 1.8 because they are too stale...
IF "%JAVA_VERSION%" == "6" (
echo IoTDB only supports jdk >= 8, please check your java version.
goto finally
)
IF "%JAVA_VERSION%" == "7" (
echo IoTDB only supports jdk >= 8, please check your java version.
goto finally
)
@REM -----------------------------------------------------------------------------
@REM SET DIR
if "%OS%" == "Windows_NT" setlocal
pushd %~dp0..
if NOT DEFINED IOTDB_HOME set IOTDB_HOME=%cd%
popd
SET enable_printgc=false
IF "%1" == "printgc" (
SET enable_printgc=true
SHIFT
)
SET IOTDB_CONF=%IOTDB_HOME%\conf
SET IOTDB_LOGS=%IOTDB_HOME%\logs
@setlocal ENABLEDELAYEDEXPANSION ENABLEEXTENSIONS
set is_conf_path=false
for %%i in (%*) do (
IF "%%i" == "-c" (
set is_conf_path=true
) ELSE IF "!is_conf_path!" == "true" (
set is_conf_path=false
set IOTDB_CONF=%%i
)
)
IF EXIST "%IOTDB_CONF%\datanode-env.bat" (
IF "%enable_printgc%" == "true" (
CALL "%IOTDB_CONF%\datanode-env.bat" printgc
) ELSE (
CALL "%IOTDB_CONF%\datanode-env.bat"
)
) ELSE IF EXIST "%IOTDB_HOME%/conf/datanode-env.bat" (
IF "%enable_printgc%" == "true" (
CALL "%IOTDB_HOME%/conf/datanode-env.bat" printgc
) ELSE (
CALL "%IOTDB_HOME%/conf/datanode-env.bat"
)
) ELSE (
echo "Can't find datanode-env.bat"
)
@REM CHECK THE PORT USAGES
IF EXIST "%IOTDB_CONF%\iotdb-datanode.properties" (
for /f "eol=# tokens=2 delims==" %%i in ('findstr /i "^dn_rpc_port"
"%IOTDB_CONF%\iotdb-datanode.properties"') do (
set dn_rpc_port=%%i
)
for /f "eol=# tokens=2 delims==" %%i in ('findstr /i "^dn_internal_port"
"%IOTDB_CONF%\iotdb-datanode.properties"') do (
set dn_internal_port=%%i
)
for /f "eol=# tokens=2 delims==" %%i in ('findstr /i "^dn_mpp_data_exchange_port"
"%IOTDB_CONF%\iotdb-datanode.properties"') do (
set dn_mpp_data_exchange_port=%%i
)
for /f "eol=# tokens=2 delims==" %%i in ('findstr /i "^dn_schema_region_consensus_port"
"%IOTDB_CONF%\iotdb-datanode.properties"') do (
set dn_schema_region_consensus_port=%%i
)
for /f "eol=# tokens=2 delims==" %%i in ('findstr /i "^dn_data_region_consensus_port"
"%IOTDB_CONF%\iotdb-datanode.properties"') do (
set dn_data_region_consensus_port=%%i
)
) ELSE IF EXIST "%IOTDB_HOME%\conf\iotdb-datanode.properties" (
for /f "eol=# tokens=2 delims==" %%i in ('findstr /i "^dn_rpc_port"
"%IOTDB_HOME%\conf\iotdb-datanode.properties"') do (
set dn_rpc_port=%%i
)
for /f "eol=# tokens=2 delims==" %%i in ('findstr /i "^dn_internal_port"
"%IOTDB_HOME%\conf\iotdb-datanode.properties"') do (
set dn_internal_port=%%i
)
for /f "eol=# tokens=2 delims==" %%i in ('findstr /i "^dn_mpp_data_exchange_port"
"%IOTDB_HOME%\conf\iotdb-datanode.properties"') do (
set dn_mpp_data_exchange_port=%%i
)
for /f "eol=# tokens=2 delims==" %%i in ('findstr /i "^dn_schema_region_consensus_port"
"%IOTDB_HOME%\conf\iotdb-datanode.properties"') do (
set dn_schema_region_consensus_port=%%i
)
for /f "eol=# tokens=2 delims==" %%i in ('findstr /i "^dn_data_region_consensus_port"
"%IOTDB_HOME%\conf\iotdb-datanode.properties"') do (
set dn_data_region_consensus_port=%%i
)
) ELSE (
echo "Can't find iotdb-datanode.properties, check the default ports"
set dn_rpc_port=6667
set dn_internal_port=10730
set dn_mpp_data_exchange_port=10740
set dn_schema_region_consensus_port=10750
set dn_data_region_consensus_port=10760
)
echo Check whether the ports are occupied....
set occupied=0
set dn_rpc_port_occupied=0
set dn_internal_port_occupied=0
set dn_mpp_data_exchange_port_occupied=0
set dn_schema_region_consensus_port_occupied=0
set dn_data_region_consensus_port_occupied=0
for /f "tokens=1,3,7 delims=: " %%i in ('netstat /ano') do (
if %%i==TCP (
if %%j==%dn_rpc_port% (
if !dn_rpc_port_occupied!==0 (
echo The dn_rpc_port %dn_rpc_port% is already occupied, pid:%%k
set occupied=1
set dn_rpc_port_occupied=1
)
) else if %%j==%dn_internal_port% (
if !dn_internal_port_occupied!==0 (
echo The dn_internal_port %dn_internal_port% is already occupied, pid:%%k
set occupied=1
set dn_internal_port_occupied=1
)
) else if %%j==%dn_mpp_data_exchange_port% (
if !dn_mpp_data_exchange_port_occupied!==0 (
echo The dn_mpp_data_exchange_port %dn_mpp_data_exchange_port% is already occupied, pid:%%k
set occupied=1
set dn_mpp_data_exchange_port_occupied=1
)
) else if %%j==%dn_schema_region_consensus_port% (
if !dn_schema_region_consensus_port_occupied!==0 (
echo The dn_schema_region_consensus_port %dn_schema_region_consensus_port% is already occupied, pid:%%k
set occupied=1
set dn_schema_region_consensus_port_occupied=1
)
) else if %%j==%dn_data_region_consensus_port% (
if !dn_data_region_consensus_port_occupied!==0 (
echo The dn_data_region_consensus_port %dn_data_region_consensus_port% is already occupied, pid:%%k
set occupied=1
)
)
)
)
if %occupied%==1 (
echo There exists occupied port, please change the configuration.
TIMEOUT /T 10 /NOBREAK
exit 0
)
@setlocal ENABLEDELAYEDEXPANSION ENABLEEXTENSIONS
set CONF_PARAMS=-s
if NOT DEFINED MAIN_CLASS set MAIN_CLASS=org.apache.iotdb.db.service.DataNode
if NOT DEFINED JAVA_HOME goto :err
@REM -----------------------------------------------------------------------------
@REM JVM Opts we'll use in legacy run or installation
set JAVA_OPTS=-ea^
-Dlogback.configurationFile="%IOTDB_CONF%\logback-datanode.xml"^
-DIOTDB_HOME="%IOTDB_HOME%"^
-DTSFILE_HOME="%IOTDB_HOME%"^
-DTSFILE_CONF="%IOTDB_CONF%"^
-DIOTDB_CONF="%IOTDB_CONF%"^
-DOFF_HEAP_MEMORY="%OFF_HEAP_MEMORY%"^
-Dsun.jnu.encoding=UTF-8^
-Dfile.encoding=UTF-8
@REM ----------------------------------------------------------------------------
@REM ***** CLASSPATH library setting *****
@REM Ensure that any user defined CLASSPATH variables are not used on startup
if EXIST "%IOTDB_HOME%\lib" (set CLASSPATH="%IOTDB_HOME%\lib\*") else set CLASSPATH="%IOTDB_HOME%\..\lib\*"
@REM this special suffix 'iotdb.DataNode' is mandatory as stop-node.bat uses it to filter the process id.
set CLASSPATH=%CLASSPATH%;iotdb.DataNode
goto okClasspath
:append
set CLASSPATH=%CLASSPATH%;%1
goto :eof
@REM -----------------------------------------------------------------------------
:okClasspath
rem echo CLASSPATH: %CLASSPATH%
@REM ----------------------------------------------------------------------------
@REM SET PARA
@REM iotdb-server runs in foreground by default
@REM set foreground=0
set foreground=yes
:checkPara
set COMMANSLINE=%*
@REM setlocal ENABLEDELAYEDEXPANSION
:STR_VISTOR
for /f "tokens=1* delims= " %%a in ("%COMMANSLINE%") do (
@REM -----more para-----
for /f "tokens=1* delims==" %%1 in ("%%a") do (
@REM echo 1=%%1 "|||" 2=%%2
if "%%1"=="-v" ( java %JAVA_OPTS% -Dlogback.configurationFile="%IOTDB_CONF%/logback-tool.xml" -cp %CLASSPATH% org.apache.iotdb.db.service.GetVersion & goto finally )
if "%%1"=="-f" ( set foreground=yes)
if "%%1"=="-d" ( set foreground=0)
)
set COMMANSLINE=%%b
goto STR_VISTOR
)
@REM ----------------------------------------------------------------------------
@REM START
:start
if %foreground%==yes (
java %ILLEGAL_ACCESS_PARAMS% %JAVA_OPTS% %IOTDB_HEAP_OPTS% -cp %CLASSPATH% %IOTDB_JMX_OPTS% %MAIN_CLASS% %CONF_PARAMS%
) ELSE (
start javaw %ILLEGAL_ACCESS_PARAMS% %JAVA_OPTS% %IOTDB_HEAP_OPTS% -cp %CLASSPATH% %IOTDB_JMX_OPTS% %MAIN_CLASS% %CONF_PARAMS%
)
goto finally
:err
echo JAVA_HOME environment variable must be set!
pause
@REM -----------------------------------------------------------------------------
:finally
@ENDLOCAL
pause