2014-08-06 12:30:01 -04:00
@ REM
@ REM Licensed to the Apache Software Foundation (ASF) under one or more
@ REM contributor license agreements. See the NOTICE file distributed with
@ REM this work for additional information regarding copyright ownership.
@ REM The ASF licenses this file to You under the Apache License, Version 2.0
@ REM (the "License"); you may not use this file except in compliance with
@ REM 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, software
@ REM distributed under the License is distributed on an "AS IS" BASIS,
@ REM WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
@ REM See the License for the specific language governing permissions and
@ REM limitations under the License.
@ echo off
IF " %OS% " == " Windows_NT " setlocal enabledelayedexpansion enableextensions
REM Determine top-level Solr directory
set SDIR = %~dp0
IF " %SDIR:~-1% " == " \ " set SDIR = %SDIR:~0,-1%
set SOLR_TIP = %SDIR% \..
pushd %SOLR_TIP%
set SOLR_TIP = %CD%
popd
REM Used to report errors before exiting the script
set SCRIPT_ERROR =
set NO_USER_PROMPT = 0
REM Verify Java is available
if NOT DEFINED JAVA_HOME goto need_java_home
" %JAVA_HOME% " \bin\java -version:1.8 -version > nul 2 >& 1
IF ERRORLEVEL 1 " %JAVA_HOME% " \bin\java -version:1.7 -version > nul 2 >& 1
IF ERRORLEVEL 1 goto need_java_vers
set " JAVA= %JAVA_HOME% \bin\java "
REM See SOLR-3619
IF EXIST " %SOLR_TIP% \server\start.jar " (
set " DEFAULT_SERVER_DIR= %SOLR_TIP% \server "
) ELSE (
set " DEFAULT_SERVER_DIR= %SOLR_TIP% \example "
)
set FIRST_ARG = %1
IF [%1 ]== [] goto usage
IF " %1 " == " -help " goto usage
IF " %1 " == " -usage " goto usage
IF " %1 " == " /? " goto usage
IF " %1 " == " -i " goto get_info
IF " %1 " == " -info " goto get_info
REM Only allow the command to be the first argument, assume start if not supplied
IF " %1 " == " start " goto set_script_cmd
IF " %1 " == " stop " goto set_script_cmd
IF " %1 " == " restart " goto set_script_cmd
IF " %1 " == " healthcheck " (
REM healthcheck uses different arg parsing strategy
SHIFT
goto parse_healthcheck_args
)
goto include_vars
: usage
2014-09-22 12:48:32 -04:00
IF NOT " %SCRIPT_ERROR% " == " " ECHO %SCRIPT_ERROR%
2014-08-06 12:30:01 -04:00
IF [%FIRST_ARG% ]== [] goto script_usage
IF " %FIRST_ARG% " == " -help " goto script_usage
IF " %FIRST_ARG% " == " -usage " goto script_usage
IF " %FIRST_ARG% " == " /? " goto script_usage
IF " %SCRIPT_CMD% " == " start " goto start_usage
IF " %SCRIPT_CMD% " == " restart " goto start_usage
IF " %SCRIPT_CMD% " == " stop " goto stop_usage
goto done
: script_usage
@ echo .
@ echo Usage: solr COMMAND OPTIONS
@ echo where COMMAND is one of: start, stop, restart, healthcheck
@ echo .
2014-09-22 12:48:32 -04:00
@ echo Example: Start Solr running in the background on port 8984:
2014-08-06 12:30:01 -04:00
@ echo .
@ echo ./solr start -p 8984
@ echo .
@ echo Pass -help after any COMMAND to see command-specific usage information,
@ echo such as: ./solr start -help
@ echo .
goto done
: start_usage
@ echo .
2014-09-22 12:48:32 -04:00
@ echo Usage: solr %SCRIPT_CMD% [-f] [-c] [-h hostname] [-p port] [-d directory] [-z zkHost] [-m memory] [-e example] [-a " additional-options " ] [-V]
2014-08-06 12:30:01 -04:00
@ echo .
@ echo -f Start Solr in foreground; default starts Solr in the background
@ echo and sends stdout / stderr to solr-PORT-console.log
@ echo .
@ echo -c or -cloud Start Solr in SolrCloud mode; if -z not supplied, an embedded ZooKeeper
@ echo instance is started on Solr port+1000, such as 9983 if Solr is bound to 8983
@ echo .
@ echo -h host Specify the hostname for this Solr instance
@ echo .
@ echo -p port Specify the port to start the Solr HTTP listener on; default is 8983
@ echo .
@ echo -d dir Specify the Solr server directory; defaults to example
@ echo .
@ echo -z zkHost ZooKeeper connection string; only used when running in SolrCloud mode using -c
@ echo To launch an embedded ZooKeeper instance, don't pass this parameter.
@ echo .
@ echo -m memory Sets the min (-Xms) and max (-Xmx) heap size for the JVM, such as: -m 4g
@ echo results in: -Xms4g -Xmx4g; by default, this script sets the heap size to 512m
@ echo .
@ echo -e example Name of the example to run; available examples:
@ echo cloud: SolrCloud example
@ echo default: Solr default example
@ echo dih: Data Import Handler
@ echo schemaless: Schema-less example
@ echo multicore: Multicore
@ echo .
2014-09-22 12:48:32 -04:00
@ echo -a opts Additional parameters to pass to the JVM when starting Solr, such as to setup
@ echo Java debug options. For example, to enable a Java debugger to attach to the Solr JVM
@ echo you could pass: -a " -agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=18983 "
@ echo In most cases, you should wrap the additional parameters in double quotes.
@ echo .
2014-08-06 12:30:01 -04:00
@ echo -noprompt Don't prompt for input; accept all defaults when running examples that accept user input
@ echo .
@ echo -V Verbose messages from this script
@ echo .
goto done
: stop_usage
@ echo .
@ echo Usage: solr stop [-k key] [-p port]
@ echo .
@ echo -k key Stop key; default is solrrocks
@ echo .
@ echo -p port Specify the port to start the Solr HTTP listener on; default is 8983
@ echo .
@ echo -V Verbose messages from this script
@ echo .
@ echo NOTE: If port is not specified, then all running Solr servers are stopped.
@ echo .
goto done
: healthcheck_usage
@ echo .
@ echo Usage: solr healthcheck [-c collection] [-z zkHost]
@ echo .
@ echo -c collection Collection to run healthcheck against.
@ echo .
@ echo -z zkHost ZooKeeper connection string; default is localhost:9983
@ echo .
goto done
REM Allow user to import vars from an include file
REM vars set in the include file can be overridden with
REM command line args
: include_vars
IF " %SOLR_INCLUDE% " == " " set SOLR_INCLUDE = solr.in.cmd
IF EXIST " %SOLR_INCLUDE% " CALL " %SOLR_INCLUDE% "
goto parse_args
REM Really basic command-line arg parsing
: parse_args
IF " %SCRIPT_CMD% " == " " set SCRIPT_CMD = start
IF [%1 ]== [] goto process_script_cmd
IF " %1 " == " -help " goto usage
IF " %1 " == " -usage " goto usage
IF " %1 " == " /? " goto usage
IF " %1 " == " -f " goto set_foreground_mode
IF " %1 " == " -foreground " goto set_foreground_mode
IF " %1 " == " -V " goto set_verbose
IF " %1 " == " -verbose " goto set_verbose
IF " %1 " == " -c " goto set_cloud_mode
IF " %1 " == " -cloud " goto set_cloud_mode
IF " %1 " == " -d " goto set_server_dir
IF " %1 " == " -dir " goto set_server_dir
IF " %1 " == " -e " goto set_example
IF " %1 " == " -example " goto set_example
IF " %1 " == " -h " goto set_host
IF " %1 " == " -host " goto set_host
IF " %1 " == " -m " goto set_memory
IF " %1 " == " -memory " goto set_memory
IF " %1 " == " -p " goto set_port
IF " %1 " == " -port " goto set_port
IF " %1 " == " -z " goto set_zookeeper
IF " %1 " == " -zkhost " goto set_zookeeper
2014-09-22 12:48:32 -04:00
IF " %1 " == " -a " goto set_addl_opts
IF " %1 " == " -addlopts " goto set_addl_opts
2014-08-06 12:30:01 -04:00
IF " %1 " == " -noprompt " goto set_noprompt
IF NOT " %1 " == " " goto invalid_cmd_line
process_script_cmd
: set_script_cmd
set SCRIPT_CMD = %1
SHIFT
goto include_vars
: set_foreground_mode
set FG = 1
SHIFT
goto parse_args
: set_verbose
set verbose = 1
SHIFT
goto parse_args
: set_cloud_mode
set SOLR_MODE = solrcloud
SHIFT
goto parse_args
: set_server_dir
2014-08-19 22:56:18 -04:00
2014-09-22 12:48:32 -04:00
set " arg= %~2 "
2014-08-19 22:56:18 -04:00
set firstChar = %arg:~0,1%
IF " %firstChar% " == " - " (
2014-08-21 11:57:33 -04:00
set SCRIPT_ERROR = Expected directory but found %2 instead!
2014-08-19 22:56:18 -04:00
goto invalid_cmd_line
)
2014-08-06 12:30:01 -04:00
REM See if they are using a short-hand name relative from the Solr tip directory
2014-09-22 12:48:32 -04:00
IF EXIST " %SOLR_TIP% \ %~2 " (
set " SOLR_SERVER_DIR= %SOLR_TIP% \ %~2 "
2014-08-06 12:30:01 -04:00
) ELSE (
2014-09-22 12:48:32 -04:00
set " SOLR_SERVER_DIR= %~2 "
2014-08-06 12:30:01 -04:00
)
SHIFT
SHIFT
goto parse_args
: set_example
2014-08-19 22:56:18 -04:00
2014-09-22 12:48:32 -04:00
set " arg= %~2 "
2014-08-19 22:56:18 -04:00
set firstChar = %arg:~0,1%
IF " %firstChar% " == " - " (
2014-08-21 11:57:33 -04:00
set SCRIPT_ERROR = Expected example name but found %2 instead!
2014-08-19 22:56:18 -04:00
goto invalid_cmd_line
)
2014-09-22 12:48:32 -04:00
set EXAMPLE = %~2
2014-08-06 12:30:01 -04:00
SHIFT
SHIFT
goto parse_args
: set_memory
2014-08-19 22:56:18 -04:00
2014-09-22 12:48:32 -04:00
set " arg= %~2 "
2014-08-19 22:56:18 -04:00
set firstChar = %arg:~0,1%
IF " %firstChar% " == " - " (
2014-08-21 11:57:33 -04:00
set SCRIPT_ERROR = Expected memory setting but found %2 instead!
2014-08-19 22:56:18 -04:00
goto invalid_cmd_line
)
2014-09-22 12:48:32 -04:00
set SOLR_HEAP = %~2
2014-08-06 12:30:01 -04:00
@ echo SOLR_HEAP=%SOLR_HEAP%
SHIFT
SHIFT
goto parse_args
: set_host
2014-09-22 12:48:32 -04:00
set " arg= %~2 "
2014-08-19 22:56:18 -04:00
set firstChar = %arg:~0,1%
IF " %firstChar% " == " - " (
2014-08-21 11:57:33 -04:00
set SCRIPT_ERROR = Expected hostname but found %2 instead!
2014-08-19 22:56:18 -04:00
goto invalid_cmd_line
)
2014-09-22 12:48:32 -04:00
set SOLR_HOST = %~2
2014-08-06 12:30:01 -04:00
SHIFT
SHIFT
goto parse_args
: set_port
2014-09-22 12:48:32 -04:00
set " arg= %~2 "
2014-08-19 22:56:18 -04:00
set firstChar = %arg:~0,1%
IF " %firstChar% " == " - " (
2014-08-21 11:57:33 -04:00
set SCRIPT_ERROR = Expected port but found %2 instead!
2014-08-19 22:56:18 -04:00
goto invalid_cmd_line
)
2014-09-22 12:48:32 -04:00
set SOLR_PORT = %~2
2014-08-06 12:30:01 -04:00
SHIFT
SHIFT
goto parse_args
: set_zookeeper
2014-08-19 22:56:18 -04:00
2014-09-22 12:48:32 -04:00
set " arg= %~2 "
2014-08-19 22:56:18 -04:00
set firstChar = %arg:~0,1%
IF " %firstChar% " == " - " (
2014-08-21 11:57:33 -04:00
set SCRIPT_ERROR = Expected ZooKeeper connection string but found %2 instead!
2014-08-19 22:56:18 -04:00
goto invalid_cmd_line
)
2014-09-22 12:48:32 -04:00
set " ZK_HOST= %~2 "
SHIFT
SHIFT
goto parse_args
: set_addl_opts
set " arg= %~2 "
set " SOLR_ADDL_ARGS= %~2 "
2014-08-06 12:30:01 -04:00
SHIFT
SHIFT
goto parse_args
: set_noprompt
set NO_USER_PROMPT = 1
SHIFT
goto parse_args
REM Perform the requested command after processing args
: process_script_cmd
IF " %verbose% " == " 1 " (
@ echo Using Solr root directory: %SOLR_TIP%
@ echo Using Java: %JAVA%
%JAVA% -version
)
IF NOT " %SOLR_HOST% " == " " (
set SOLR_HOST_ARG = -Dhost=%SOLR_HOST%
) ELSE (
set SOLR_HOST_ARG =
)
REM TODO: Change this to "server" when we resolve SOLR-3619
IF " %SOLR_SERVER_DIR% " == " " set SOLR_SERVER_DIR = %DEFAULT_SERVER_DIR%
IF NOT EXIST " %SOLR_SERVER_DIR% " (
2014-08-19 22:56:18 -04:00
set SCRIPT_ERROR = Solr server directory %SOLR_SERVER_DIR% not found!
2014-08-06 12:30:01 -04:00
goto err
)
IF " %EXAMPLE% " == " " (
REM SOLR_HOME just becomes serverDir/solr
) ELSE IF "%EXAMPLE%"=="default" (
set " SOLR_HOME= %SOLR_TIP% \example\solr "
) ELSE IF "%EXAMPLE%"=="cloud" (
set SOLR_MODE = solrcloud
goto cloud_example_start
) ELSE IF "%EXAMPLE%"=="dih" (
set " SOLR_HOME= %SOLR_TIP% \example\example-DIH\solr "
) ELSE IF "%EXAMPLE%"=="schemaless" (
set " SOLR_HOME= %SOLR_TIP% \example\example-schemaless\solr "
) ELSE IF "%EXAMPLE%"=="multicore" (
set " SOLR_HOME= %SOLR_TIP% \example\multicore "
) ELSE (
@ echo .
@ echo 'Unrecognized example %EXAMPLE% !'
@ echo .
goto start_usage
)
: start_solr
IF " %SOLR_HOME% " == " " set " SOLR_HOME= %SOLR_SERVER_DIR% \solr "
IF " %STOP_KEY% " == " " set STOP_KEY = solrrocks
REM TODO stop all if no port specified as Windows doesn't seem to have a
REM tool that does: ps waux | grep start.jar
IF " %SCRIPT_CMD% " == " stop " (
IF " %SOLR_PORT% " == " " (
set SCRIPT_ERROR = Must specify the port when trying to stop Solr!
goto err
)
)
IF " %SOLR_PORT% " == " " set SOLR_PORT = 8983
IF " %STOP_PORT% " == " " set STOP_PORT = 79%SOLR_PORT:~-2,2%
IF " %SCRIPT_CMD% " == " start " (
2014-09-22 12:48:32 -04:00
REM see if Solr is already running using netstat
2014-08-06 12:30:01 -04:00
For /f " tokens=5 " %% j in ( 'netstat -aon ^| find /i "listening" ^| find ": %SOLR_PORT% "' ) do (
set " SCRIPT_ERROR=Process %% j is already listening on port %SOLR_PORT% . If this is Solr, please stop it first before starting (or use restart). If this is not Solr, then please choose a different port using -p PORT "
goto err
)
) ELSE (
@ echo Stopping Solr running on port %SOLR_PORT%
" %JAVA% " -jar " %SOLR_SERVER_DIR% \start.jar " STOP.PORT=%STOP_PORT% STOP.KEY=%STOP_KEY% --stop
timeout /T 5
)
REM Kill it if it is still running after the graceful shutdown
For /f " tokens=5 " %% j in ( 'netstat -nao ^| find /i "listening" ^| find ": %SOLR_PORT% "' ) do ( taskkill /f /PID %% j)
REM backup log files (use current timestamp for backup name)
For /f " tokens=2-4 delims=/ " %% a in ( 'date /t' ) do ( set mydate = %% c-%% a-%% b)
For /f " tokens=1-2 delims=/: " %% a in ( " %TIME% " ) do ( set mytime = %% a%% b)
set now_ts = %mydate% _%mytime%
IF EXIST " %SOLR_SERVER_DIR% \logs\solr.log " (
echo Backing up %SOLR_SERVER_DIR% \logs\solr.log
move /Y " %SOLR_SERVER_DIR% \logs\solr.log " " %SOLR_SERVER_DIR% \logs\solr_log_!now_ts! "
)
IF EXIST " %SOLR_SERVER_DIR% \logs\solr_gc.log " (
echo Backing up %SOLR_SERVER_DIR% \logs\solr_gc.log
move /Y " %SOLR_SERVER_DIR% \logs\solr_gc.log " " %SOLR_SERVER_DIR% \logs\solr_gc_log_!now_ts! "
)
IF " %SCRIPT_CMD% " == " stop " goto done
REM if verbose gc logging enabled, setup the location of the log file
IF NOT " %GC_LOG_OPTS% " == " " set GC_LOG_OPTS = %GC_LOG_OPTS% -Xloggc:" %SOLR_SERVER_DIR% /logs/solr_gc.log "
IF " %SOLR_MODE% " == " solrcloud " (
2014-08-19 22:56:18 -04:00
IF " %ZK_CLIENT_TIMEOUT% " == " " set " ZK_CLIENT_TIMEOUT=15000 "
2014-08-06 12:30:01 -04:00
2014-08-19 22:56:18 -04:00
set " CLOUD_MODE_OPTS=-DzkClientTimeout=!ZK_CLIENT_TIMEOUT! "
2014-08-06 12:30:01 -04:00
IF NOT " %ZK_HOST% " == " " (
2014-08-19 22:56:18 -04:00
set " CLOUD_MODE_OPTS=!CLOUD_MODE_OPTS! -DzkHost= %ZK_HOST% "
2014-08-06 12:30:01 -04:00
) ELSE (
2014-08-19 22:56:18 -04:00
IF " %verbose% " == " 1 " echo Configuring SolrCloud to launch an embedded ZooKeeper using -DzkRun
set " CLOUD_MODE_OPTS=!CLOUD_MODE_OPTS! -DzkRun "
2014-09-22 12:48:32 -04:00
)
2014-09-22 13:23:14 -04:00
IF EXIST " %SOLR_HOME% \collection1\core.properties " set " CLOUD_MODE_OPTS=!CLOUD_MODE_OPTS! -Dbootstrap_confdir=./solr/collection1/conf -Dcollection.configName=myconf -DnumShards=1 "
2014-08-06 12:30:01 -04:00
) ELSE (
set CLOUD_MODE_OPTS =
)
REM These are useful for attaching remove profilers like VisualVM/JConsole
IF " %ENABLE_REMOTE_JMX_OPTS% " == " true " (
set REMOTE_JMX_OPTS = -Dcom.sun.management.jmxremote ^
-Dcom.sun.management.jmxremote.local.only=false ^
-Dcom.sun.management.jmxremote.ssl=false ^
-Dcom.sun.management.jmxremote.authenticate=false ^
-Dcom.sun.management.jmxremote.port=10%SOLR_PORT:~-2,2% ^
-Dcom.sun.management.jmxremote.rmi.port=10%SOLR_PORT:~-2,2%
IF NOT " %SOLR_HOST% " == " " set REMOTE_JMX_OPTS = %REMOTE_JMX_OPTS% -Djava.rmi.server.hostname=%SOLR_HOST%
) ELSE (
set REMOTE_JMX_OPTS =
)
IF NOT " %SOLR_HEAP% " == " " set SOLR_JAVA_MEM = -Xms%SOLR_HEAP% -Xmx%SOLR_HEAP%
IF " %SOLR_JAVA_MEM% " == " " set SOLR_JAVA_MEM = -Xms512m -Xmx512m
2014-09-22 12:48:32 -04:00
IF " %SOLR_TIMEZONE% " == " " set SOLR_TIMEZONE = UTC
2014-08-06 12:30:01 -04:00
IF " %verbose% " == " 1 " (
@ echo Starting Solr using the following settings:
@ echo JAVA = %JAVA%
@ echo SOLR_SERVER_DIR = %SOLR_SERVER_DIR%
@ echo SOLR_HOME = %SOLR_HOME%
@ echo SOLR_HOST = %SOLR_HOST%
@ echo SOLR_PORT = %SOLR_PORT%
@ echo GC_TUNE = %GC_TUNE%
@ echo GC_LOG_OPTS = %GC_LOG_OPTS%
@ echo SOLR_JAVA_MEM = %SOLR_JAVA_MEM%
@ echo REMOTE_JMX_OPTS = %REMOTE_JMX_OPTS%
@ echo CLOUD_MODE_OPTS = %CLOUD_MODE_OPTS%
@ echo SOLR_TIMEZONE = %SOLR_TIMEZONE%
)
set START_OPTS = -Duser.timezone=%SOLR_TIMEZONE% -Djava.net.preferIPv4Stack=true -Dsolr.autoSoftCommit.maxTime=3000
set START_OPTS = %START_OPTS% %GC_TUNE% %GC_LOG_OPTS%
2014-08-19 22:56:18 -04:00
IF NOT " !CLOUD_MODE_OPTS! " == " " set START_OPTS = %START_OPTS% !CLOUD_MODE_OPTS!
2014-08-06 12:30:01 -04:00
IF NOT " %REMOTE_JMX_OPTS% " == " " set START_OPTS = %START_OPTS% %REMOTE_JMX_OPTS%
IF NOT " %SOLR_ADDL_ARGS% " == " " set START_OPTS = %START_OPTS% %SOLR_ADDL_ARGS%
IF NOT " %SOLR_HOST_ARG% " == " " set START_OPTS = %START_OPTS% %SOLR_HOST_ARG%
2014-08-19 22:56:18 -04:00
cd " %SOLR_SERVER_DIR% "
2014-08-06 12:30:01 -04:00
@ echo .
@ echo Starting Solr on port %SOLR_PORT% from %SOLR_SERVER_DIR%
2014-09-22 12:48:32 -04:00
@ echo .
2014-08-06 12:30:01 -04:00
IF " %FG% " == " 1 " (
REM run solr in the foreground
" %JAVA% " -server -Xss256k %SOLR_JAVA_MEM% %START_OPTS% -DSTOP.PORT=%STOP_PORT% -DSTOP.KEY=%STOP_KEY% ^
-Djetty.port=%SOLR_PORT% -Dsolr.solr.home=" %SOLR_HOME% " -jar start.jar
) ELSE (
2014-08-19 22:56:18 -04:00
START " " " %JAVA% " -server -Xss256k %SOLR_JAVA_MEM% %START_OPTS% -DSTOP.PORT=%STOP_PORT% -DSTOP.KEY=%STOP_KEY% ^
2014-09-05 12:35:52 -04:00
-Djetty.port=%SOLR_PORT% -Dsolr.solr.home=" %SOLR_HOME% " -jar start.jar > " %SOLR_SERVER_DIR% \logs\solr- %SOLR_PORT% -console.log "
2014-08-06 12:30:01 -04:00
)
goto done
: cloud_example_start
REM Launch interactive session to guide the user through the SolrCloud example
CLS
@ echo .
@ echo Welcome to the SolrCloud example
@ echo .
@ echo .
IF " %NO_USER_PROMPT% " == " 1 " (
set CLOUD_NUM_NODES = 2
@ echo Starting up %CLOUD_NUM_NODES% Solr nodes for your example SolrCloud cluster.
goto start_cloud_nodes
) ELSE (
@ echo This interactive session will help you launch a SolrCloud cluster on your local workstation.
@ echo .
SET /P " USER_INPUT=To begin, how many Solr nodes would you like to run in your local cluster (specify 1-4 nodes) [2]: "
goto while_num_nodes_not_valid
)
2014-09-22 12:48:32 -04:00
: while_num_nodes_not_valid
2014-08-06 12:30:01 -04:00
IF " %USER_INPUT% " == " " set USER_INPUT = 2
SET /A INPUT_AS_NUM =! USER_INPUT !* 1
IF %INPUT_AS_NUM% GEQ 1 IF %INPUT_AS_NUM% LEQ 4 set CLOUD_NUM_NODES = %INPUT_AS_NUM%
IF NOT DEFINED CLOUD_NUM_NODES (
SET USER_INPUT =
SET /P " USER_INPUT=Please enter a number between 1 and 4 [2]: "
2014-09-22 12:48:32 -04:00
goto while_num_nodes_not_valid
2014-08-06 12:30:01 -04:00
)
@ echo Ok, let's start up %CLOUD_NUM_NODES% Solr nodes for your example SolrCloud cluster.
: start_cloud_nodes
for /l %% x in ( 1 , 1 , !CLOUD_NUM_NODES! ) do (
set USER_INPUT =
set /A idx =%% x - 1
set DEF_PORT = 8983
IF %% x EQU 2 (
set DEF_PORT = 7574
) ELSE (
IF %% x EQU 3 (
set DEF_PORT = 8984
) ELSE (
IF %% x EQU 4 (
set DEF_PORT = 7575
)
)
)
2014-09-22 12:48:32 -04:00
2014-08-06 12:30:01 -04:00
IF " %NO_USER_PROMPT% " == " 1 " (
set NODE_PORT = !DEF_PORT!
) ELSE (
set /P " USER_INPUT=Please enter the port for node %% x [!DEF_PORT!]: "
IF " !USER_INPUT! " == " " set USER_INPUT = !DEF_PORT!
set NODE_PORT = !USER_INPUT!
echo node%% x port: !NODE_PORT!
@ echo .
)
2014-09-22 12:48:32 -04:00
2014-08-06 12:30:01 -04:00
IF NOT EXIST " %SOLR_TIP% \node %% x " (
@ echo Cloning %DEFAULT_SERVER_DIR% into %SOLR_TIP% \node%% x
xcopy /Q /E /I " %DEFAULT_SERVER_DIR% " " %SOLR_TIP% \node %% x "
)
2014-09-22 13:23:14 -04:00
2014-09-22 12:48:32 -04:00
IF %% x EQU 1 (
2014-08-06 12:30:01 -04:00
set EXAMPLE =
2014-09-22 13:23:14 -04:00
IF NOT " !ZK_HOST! " == " " (
set " DASHZ=-z !ZK_HOST! "
) ELSE (
set " DASHZ= "
)
@ echo Starting node1 on port !NODE_PORT! using command:
@ echo solr -cloud -p !NODE_PORT! -d node1 !DASHZ!
START " " " %SDIR% \solr " -f -cloud -p !NODE_PORT! -d node1 !DASHZ!
2014-08-06 12:30:01 -04:00
set NODE1_PORT = !NODE_PORT!
) ELSE (
2014-09-22 13:23:14 -04:00
IF " !ZK_HOST! " == " " (
set /A ZK_PORT =! NODE1_PORT !+ 1000
set " ZK_HOST=localhost:!ZK_PORT! "
)
@ echo Starting node%% x on port !NODE_PORT! using command:
@ echo solr -cloud -p !NODE_PORT! -d node%% x -z !ZK_HOST!
START " " " %SDIR% \solr " -f -cloud -p !NODE_PORT! -d node%% x -z !ZK_HOST!
2014-08-06 12:30:01 -04:00
)
timeout /T 10
)
set USER_INPUT =
echo .
echo Now let's create a new collection for indexing documents in your %CLOUD_NUM_NODES% -node cluster.
IF " %NO_USER_PROMPT% " == " 1 " (
set CLOUD_COLLECTION = gettingstarted
set CLOUD_NUM_SHARDS = 2
set CLOUD_REPFACT = 2
2014-08-19 22:56:18 -04:00
set CLOUD_CONFIG = default
set " CLOUD_CONFIG_DIR= %SOLR_TIP% \example\solr\collection1\conf "
2014-08-06 12:30:01 -04:00
goto create_collection
) ELSE (
goto get_create_collection_params
)
: get_create_collection_params
set /P " USER_INPUT=Please provide a name for your new collection: [gettingstarted] "
IF " !USER_INPUT! " == " " set USER_INPUT = gettingstarted
set CLOUD_COLLECTION = !USER_INPUT!
echo !CLOUD_COLLECTION!
set USER_INPUT =
echo .
set /P " USER_INPUT=How many shards would you like to split !CLOUD_COLLECTION! into? [2] "
IF " !USER_INPUT! " == " " set USER_INPUT = 2
set CLOUD_NUM_SHARDS = !USER_INPUT!
echo !CLOUD_NUM_SHARDS!
set USER_INPUT =
echo .
set /P " USER_INPUT=How many replicas per shard would you like to create? [2] "
IF " !USER_INPUT! " == " " set USER_INPUT = 2
set CLOUD_REPFACT = !USER_INPUT!
echo !CLOUD_REPFACT!
2014-08-19 22:56:18 -04:00
set USER_INPUT =
echo .
set /P " USER_INPUT=Please choose a configuration for the !CLOUD_COLLECTION! collection, available options are: default or schemaless [default] "
IF " !USER_INPUT! " == " " set USER_INPUT = default
set CLOUD_CONFIG = !USER_INPUT!
echo !CLOUD_CONFIG!
IF " !CLOUD_CONFIG! " == " schemaless " (
IF EXIST " %SOLR_TIP% \server\solr\configsets\schemaless " set " CLOUD_CONFIG_DIR= %SOLR_TIP% \server\solr\configsets\schemaless "
IF NOT EXIST " %SOLR_TIP% \server\solr\configsets\schemaless " set " CLOUD_CONFIG_DIR= %SOLR_TIP% \example\example-schemaless\solr\collection1\conf "
) ELSE (
set " CLOUD_CONFIG_DIR= %SOLR_TIP% \example\solr\collection1\conf "
)
2014-08-06 12:30:01 -04:00
goto create_collection
: create_collection
set /A MAX_SHARDS_PER_NODE = (( ! CLOUD_NUM_SHARDS!*!CLOUD_REPFACT!)/!CLOUD_NUM_NODES ! ) + 1
echo .
echo Deploying default Solr configuration files to embedded ZooKeeper
echo .
" %JAVA% " -Dlog4j.configuration=" file: %DEFAULT_SERVER_DIR% \scripts\cloud-scripts\log4j.properties " ^
-classpath " %DEFAULT_SERVER_DIR% \solr-webapp\webapp\WEB-INF\lib\*; %DEFAULT_SERVER_DIR% \lib\ext\* " ^
2014-08-19 22:56:18 -04:00
org.apache.solr.cloud.ZkCLI -zkhost %zk_host% -cmd upconfig -confdir " !CLOUD_CONFIG_DIR! " -confname !CLOUD_CONFIG!
2014-08-06 12:30:01 -04:00
set COLLECTIONS_API = http://localhost:!NODE1_PORT!/solr/admin/collections
2014-08-19 22:56:18 -04:00
set " CLOUD_CREATE_COLLECTION_CMD= %COLLECTIONS_API% ?action=CREATE&name= %CLOUD_COLLECTION% &replicationFactor= %CLOUD_REPFACT% &numShards= %CLOUD_NUM_SHARDS% &collection.configName=!CLOUD_CONFIG!&maxShardsPerNode= %MAX_SHARDS_PER_NODE% &wt=json&indent=2 "
2014-09-22 12:48:32 -04:00
echo Creating new collection %CLOUD_COLLECTION% with %CLOUD_NUM_SHARDS% shards and replication factor %CLOUD_REPFACT% using Collections API command:
2014-08-06 12:30:01 -04:00
echo .
@ echo " %CLOUD_CREATE_COLLECTION_CMD% "
echo .
echo For more information about the Collections API, please see: https://cwiki.apache.org/confluence/display/solr/Collections+API
echo .
" %JAVA% " -Dlog4j.configuration=" file: %DEFAULT_SERVER_DIR% \scripts\cloud-scripts\log4j.properties " ^
-classpath " %DEFAULT_SERVER_DIR% \solr-webapp\webapp\WEB-INF\lib\*; %DEFAULT_SERVER_DIR% \lib\ext\* " ^
org.apache.solr.util.SolrCLI api -get " %CLOUD_CREATE_COLLECTION_CMD% "
echo .
echo SolrCloud example is running, please visit http://localhost:%NODE1_PORT% /solr"
echo .
REM End of interactive cloud example
goto done
: get_info
2014-09-22 12:48:32 -04:00
REM Find all Java processes, correlate with those listening on a port
2014-08-06 12:30:01 -04:00
REM and then try to contact via that port using the status tool
for /f " tokens=2 " %% a in ( 'tasklist ^| find "java.exe"' ) do (
for /f " tokens=2,5 " %% j in ( 'netstat -aon ^| find /i "listening"' ) do (
if " %% k " EQU " %% a " (
for /f " delims=: tokens=1,2 " %% x IN ( " %% j " ) do (
if " 0.0.0.0 " EQU " %% x " (
@ echo .
set has_info = 1
echo Found Solr process %% k running on port %% y
" %JAVA% " -Dlog4j.configuration=" file: %DEFAULT_SERVER_DIR% \scripts\cloud-scripts\log4j.properties " ^
-classpath " %DEFAULT_SERVER_DIR% \solr-webapp\webapp\WEB-INF\lib\*; %DEFAULT_SERVER_DIR% \lib\ext\* " ^
org.apache.solr.util.SolrCLI status -solr http://localhost:%% y/solr
2014-09-22 12:48:32 -04:00
2014-08-06 12:30:01 -04:00
@ echo .
)
)
2014-09-22 12:48:32 -04:00
)
2014-08-06 12:30:01 -04:00
)
)
if NOT " !has_info! " == " 1 " echo No running Solr nodes found.
set has_info =
goto done
: parse_healthcheck_args
IF [%1 ]== [] goto run_healthcheck
IF " %1 " == " -c " goto set_healthcheck_collection
IF " %1 " == " -collection " goto set_healthcheck_collection
IF " %1 " == " -z " goto set_healthcheck_zk
IF " %1 " == " -zkhost " goto set_healthcheck_zk
IF " %1 " == " -help " goto usage
IF " %1 " == " -usage " goto usage
IF " %1 " == " /? " goto usage
goto run_healthcheck
: set_healthcheck_collection
2014-09-22 12:48:32 -04:00
set HEALTHCHECK_COLLECTION = %~2
2014-08-06 12:30:01 -04:00
SHIFT
SHIFT
goto parse_healthcheck_args
: set_healthcheck_zk
2014-09-22 12:48:32 -04:00
set HEALTHCHECK_ZK_HOST = %~2
2014-08-06 12:30:01 -04:00
SHIFT
SHIFT
goto parse_healthcheck_args
: run_healthcheck
IF NOT DEFINED HEALTHCHECK_COLLECTION goto healthcheck_usage
IF NOT DEFINED HEALTHCHECK_ZK_HOST set " HEALTHCHECK_ZK_HOST=localhost:9983 "
" %JAVA% " -Dlog4j.configuration=" file: %DEFAULT_SERVER_DIR% \scripts\cloud-scripts\log4j.properties " ^
-classpath " %DEFAULT_SERVER_DIR% \solr-webapp\webapp\WEB-INF\lib\*; %DEFAULT_SERVER_DIR% \lib\ext\* " ^
org.apache.solr.util.SolrCLI healthcheck -collection !HEALTHCHECK_COLLECTION! -zkHost !HEALTHCHECK_ZK_HOST!
goto done
: invalid_cmd_line
@ echo .
2014-08-19 22:56:18 -04:00
IF " !SCRIPT_ERROR! " == " " (
@ echo Invalid command-line option: %1
) ELSE (
@ echo ERROR: !SCRIPT_ERROR!
)
2014-08-06 12:30:01 -04:00
@ echo .
IF " %FIRST_ARG% " == " start " (
goto start_usage
) ELSE IF "%FIRST_ARG:~0,1%" == "-" (
goto start_usage
) ELSE IF "%FIRST_ARG%"=="restart" (
goto start_usage
) ELSE IF "%FIRST_ARG%"=="stop" (
goto stop_usage
) ELSE IF "%FIRST_ARG%"=="healthcheck" (
goto healthcheck_usage
) ELSE (
goto script_usage
)
: need_java_home
@ echo Please set the JAVA_HOME environment variable to the path where you installed Java 1.7+
goto done
: need_java_vers
@ echo Java 1.7 or later is required to run Solr.
goto done
: err
@ echo .
2014-08-19 22:56:18 -04:00
@ echo ERROR: !SCRIPT_ERROR!
2014-08-06 12:30:01 -04:00
@ echo .
exit /b 1
: done
ENDLOCAL