@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 set "PASS_TO_RUN_EXAMPLE=" 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 Allow user to import vars from an include file REM vars set in the include file can be overridden with REM command line args IF "%SOLR_INCLUDE%"=="" set "SOLR_INCLUDE=%SOLR_TIP%\bin\solr.in.cmd" IF EXIST "%SOLR_INCLUDE%" CALL "%SOLR_INCLUDE%" REM Select HTTP OR HTTPS related configurations set SOLR_URL_SCHEME=http set "SOLR_JETTY_CONFIG=--module=http" set "SOLR_SSL_OPTS= " IF DEFINED SOLR_SSL_KEY_STORE ( set "SOLR_JETTY_CONFIG=--module=https" set SOLR_URL_SCHEME=https set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Dsolr.jetty.keystore=%SOLR_SSL_KEY_STORE%" IF DEFINED SOLR_SSL_KEY_STORE_PASSWORD ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Dsolr.jetty.keystore.password=%SOLR_SSL_KEY_STORE_PASSWORD%" ) IF DEFINED SOLR_SSL_KEY_STORE_TYPE ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Dsolr.jetty.keystore.type=%SOLR_SSL_KEY_STORE_TYPE%" ) IF DEFINED SOLR_SSL_TRUST_STORE ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Dsolr.jetty.truststore=%SOLR_SSL_TRUST_STORE%" ) IF DEFINED SOLR_SSL_TRUST_STORE_PASSWORD ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Dsolr.jetty.truststore.password=%SOLR_SSL_TRUST_STORE_PASSWORD%" ) IF DEFINED SOLR_SSL_TRUST_STORE_TYPE ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Dsolr.jetty.truststore.type=%SOLR_SSL_TRUST_STORE_TYPE%" ) IF DEFINED SOLR_SSL_NEED_CLIENT_AUTH ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Dsolr.jetty.ssl.needClientAuth=%SOLR_SSL_NEED_CLIENT_AUTH%" ) IF DEFINED SOLR_SSL_WANT_CLIENT_AUTH ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Dsolr.jetty.ssl.wantClientAuth=%SOLR_SSL_WANT_CLIENT_AUTH%" ) IF DEFINED SOLR_SSL_CLIENT_KEY_STORE ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Djavax.net.ssl.keyStore=%SOLR_SSL_CLIENT_KEY_STORE%" IF DEFINED SOLR_SSL_CLIENT_KEY_STORE_PASSWORD ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Djavax.net.ssl.keyStorePassword=%SOLR_SSL_CLIENT_KEY_STORE_PASSWORD%" ) IF DEFINED SOLR_SSL_CLIENT_KEY_STORE_TYPE ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Djavax.net.ssl.keyStoreType=%SOLR_SSL_CLIENT_KEY_STORE_TYPE%" ) ) ELSE ( IF DEFINED SOLR_SSL_KEY_STORE ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Djavax.net.ssl.keyStore=%SOLR_SSL_KEY_STORE%" ) IF DEFINED SOLR_SSL_KEY_STORE_PASSWORD ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Djavax.net.ssl.keyStorePassword=%SOLR_SSL_KEY_STORE_PASSWORD%" ) IF DEFINED SOLR_SSL_KEY_STORE_TYPE ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Djavax.net.ssl.keyStoreType=%SOLR_SSL_KEY_STORE_TYPE%" ) ) IF DEFINED SOLR_SSL_CLIENT_TRUST_STORE ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Djavax.net.ssl.trustStore=%SOLR_SSL_CLIENT_TRUST_STORE%" IF DEFINED SOLR_SSL_CLIENT_TRUST_STORE_PASSWORD ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Djavax.net.ssl.trustStorePassword=%SOLR_SSL_CLIENT_TRUST_STORE_PASSWORD%" ) IF DEFINED SOLR_SSL_CLIENT_TRUST_STORE_TYPE ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Djavax.net.ssl.trustStoreType=%SOLR_SSL_CLIENT_TRUST_STORE_TYPE%" ) ) ELSE ( IF DEFINED SOLR_SSL_TRUST_STORE ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Djavax.net.ssl.trustStore=%SOLR_SSL_TRUST_STORE%" ) IF DEFINED SOLR_SSL_TRUST_STORE_PASSWORD ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Djavax.net.ssl.trustStorePassword=%SOLR_SSL_TRUST_STORE_PASSWORD%" ) IF DEFINED SOLR_SSL_TRUST_STORE_TYPE ( set "SOLR_SSL_OPTS=%SOLR_SSL_OPTS% -Djavax.net.ssl.trustStoreType=%SOLR_SSL_TRUST_STORE_TYPE%" ) ) ) ELSE ( set SOLR_SSL_OPTS= ) REM Authentication options IF DEFINED SOLR_AUTHENTICATION_CLIENT_CONFIGURER ( echo WARNING: Found unsupported configuration variable SOLR_AUTHENTICATION_CLIENT_CONFIGURER echo Please start using SOLR_AUTHENTICATION_CLIENT_BUILDER instead ) IF DEFINED SOLR_AUTHENTICATION_CLIENT_BUILDER ( set AUTHC_CLIENT_BUILDER_ARG="-Dsolr.authentication.httpclient.builder=%SOLR_AUTHENTICATION_CLIENT_BUILDER%" ) set "AUTHC_OPTS=%AUTHC_CLIENT_BUILDER_ARG% %SOLR_AUTHENTICATION_OPTS%" REM Set the SOLR_TOOL_HOST variable for use when connecting to a running Solr instance IF NOT "%SOLR_HOST%"=="" ( set "SOLR_TOOL_HOST=%SOLR_HOST%" ) ELSE ( set "SOLR_TOOL_HOST=localhost" ) IF "%SOLR_JETTY_HOST%"=="" ( set SOLR_JETTY_HOST=0.0.0.0 ) REM Verify Java is available IF DEFINED SOLR_JAVA_HOME set "JAVA_HOME=%SOLR_JAVA_HOME%" REM Try to detect JAVA_HOME from the registry IF NOT DEFINED JAVA_HOME ( FOR /F "skip=2 tokens=2*" %%A IN ('REG QUERY "HKLM\Software\JavaSoft\Java Runtime Environment" /v CurrentVersion') DO set CurVer=%%B FOR /F "skip=2 tokens=2*" %%A IN ('REG QUERY "HKLM\Software\JavaSoft\Java Runtime Environment\!CurVer!" /v JavaHome') DO ( set "JAVA_HOME=%%B" ) ) IF NOT DEFINED JAVA_HOME goto need_java_home set JAVA_HOME=%JAVA_HOME:"=% IF %JAVA_HOME:~-1%==\ SET JAVA_HOME=%JAVA_HOME:~0,-1% IF NOT EXIST "%JAVA_HOME%\bin\java.exe" ( set "SCRIPT_ERROR=java.exe not found in %JAVA_HOME%\bin. Please set JAVA_HOME to a valid JRE / JDK directory." goto err ) set "JAVA=%JAVA_HOME%\bin\java" CALL :resolve_java_info IF !JAVA_MAJOR_VERSION! LSS 8 ( set "SCRIPT_ERROR=Java 1.8 or later is required to run Solr. Current Java version is: !JAVA_VERSION_INFO!" goto err ) set "DEFAULT_SERVER_DIR=%SOLR_TIP%\server" set FIRST_ARG=%1 IF [%1]==[] goto usage IF "%1"=="-help" goto usage IF "%1"=="-usage" goto usage IF "%1"=="-h" goto usage IF "%1"=="--help" goto usage IF "%1"=="/?" goto usage IF "%1"=="-i" goto get_info IF "%1"=="-info" goto get_info IF "%1"=="status" goto get_info IF "%1"=="version" goto get_version IF "%1"=="-v" goto get_version IF "%1"=="-version" goto get_version IF "%1"=="assert" goto run_assert 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 set SCRIPT_CMD=healthcheck SHIFT goto parse_healthcheck_args ) IF "%1"=="create" ( set SCRIPT_CMD=create SHIFT goto parse_create_args ) IF "%1"=="create_core" ( set SCRIPT_CMD=create_core SHIFT goto parse_create_args ) IF "%1"=="create_collection" ( set SCRIPT_CMD=create_collection SHIFT goto parse_create_args ) IF "%1"=="delete" ( set SCRIPT_CMD=delete SHIFT goto parse_delete_args ) IF "%1"=="zk" ( set SCRIPT_CMD=zk SHIFT set ZK_RECURSE=false goto parse_zk_args ) goto parse_args :usage IF NOT "%SCRIPT_ERROR%"=="" ECHO %SCRIPT_ERROR% IF [%FIRST_ARG%]==[] goto script_usage IF "%FIRST_ARG%"=="-help" goto script_usage IF "%FIRST_ARG%"=="-usage" goto script_usage IF "%FIRST_ARG%"=="-h" goto script_usage IF "%FIRST_ARG%"=="--help" 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 IF "%SCRIPT_CMD%"=="healthcheck" goto healthcheck_usage IF "%SCRIPT_CMD%"=="create" goto create_usage IF "%SCRIPT_CMD%"=="create_core" goto create_core_usage IF "%SCRIPT_CMD%"=="create_collection" goto create_collection_usage IF "%SCRIPT_CMD%"=="delete" goto delete_usage IF "%SCRIPT_CMD%"=="zk" goto zk_usage goto done :script_usage @echo. @echo Usage: solr COMMAND OPTIONS @echo where COMMAND is one of: start, stop, restart, healthcheck, create, create_core, create_collection, delete, version, zk @echo. @echo Standalone server example (start Solr running in the background on port 8984): @echo. @echo solr start -p 8984 @echo. @echo SolrCloud example (start Solr running in SolrCloud mode using localhost:2181 to connect to Zookeeper, with 1g max heap size and remote Java debug options enabled): @echo. @echo solr start -c -m 1g -z localhost:2181 -a "-Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=1044" @echo. @echo Pass -help after any COMMAND to see command-specific usage information, @echo such as: solr start -help or solr stop -help @echo. goto done :start_usage @echo. @echo Usage: solr %SCRIPT_CMD% [-f] [-c] [-h hostname] [-p port] [-d directory] [-z zkHost] [-m memory] [-e example] [-s solr.solr.home] [-a "additional-options"] [-V] @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 server @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 -s dir Sets the solr.solr.home system property; Solr will create core directories under @echo this directory. This allows you to run multiple Solr instances on the same host @echo while reusing the same server directory set using the -d parameter. If set, the @echo specified directory should contain a solr.xml file, unless solr.xml exists in Zookeeper. @echo This parameter is ignored when running examples (-e), as the solr.solr.home depends @echo on which example is run. The default value is server/solr. @echo. @echo -e example Name of the example to run; available examples: @echo cloud: SolrCloud example @echo techproducts: Comprehensive example illustrating many of Solr's core capabilities @echo dih: Data Import Handler @echo schemaless: Schema-less example @echo. @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. @echo -noprompt Don't prompt for input; accept all defaults when running examples that accept user input @echo. @echo -v and -q Verbose (-v) or quiet (-q) logging. Sets default log level to DEBUG or WARN instead of INFO @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 the Solr HTTP listener is bound to @echo. @echo -all Find and stop all running Solr servers on this host @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 :create_usage echo. echo Usage: solr create [-c name] [-d confdir] [-n confname] [-shards #] [-replicationFactor #] [-p port] echo. echo Create a core or collection depending on whether Solr is running in standalone (core) or SolrCloud echo mode (collection). In other words, this action detects which mode Solr is running in, and then takes echo the appropriate action (either create_core or create_collection). For detailed usage instructions, do: echo. echo bin\solr create_core -help echo. echo or echo. echo bin\solr create_collection -help echo. goto done :delete_usage echo. echo Usage: solr delete [-c name] [-deleteConfig boolean] [-p port] echo. echo Deletes a core or collection depending on whether Solr is running in standalone (core) or SolrCloud echo mode (collection). If you're deleting a collection in SolrCloud mode, the default behavior is to also echo delete the configuration directory from Zookeeper so long as it is not being used by another collection. echo You can override this behavior by passing -deleteConfig false when running this command. echo. echo -c name Name of core to create echo. echo -deleteConfig boolean Delete the configuration directory from Zookeeper; default is true echo. echo -p port Port of a local Solr instance where you want to create the new core echo If not specified, the script will search the local system for a running echo Solr instance and will use the port of the first server it finds. echo. goto done :create_core_usage echo. echo Usage: solr create_core [-c name] [-d confdir] [-p port] echo. echo -c name Name of core to create echo. echo -d confdir Configuration directory to copy when creating the new core, built-in options are: echo. echo basic_configs: Minimal Solr configuration echo data_driven_schema_configs: Managed schema with field-guessing support enabled echo sample_techproducts_configs: Example configuration with many optional features enabled to echo demonstrate the full power of Solr echo. echo If not specified, default is: data_driven_schema_configs echo. echo Alternatively, you can pass the path to your own configuration directory instead of using echo one of the built-in configurations, such as: bin\solr create_core -c mycore -d c:/tmp/myconfig echo. echo -p port Port of a local Solr instance where you want to create the new core echo If not specified, the script will search the local system for a running echo Solr instance and will use the port of the first server it finds. echo. goto done :create_collection_usage echo. echo Usage: solr create_collection [-c name] [-d confdir] [-n confname] [-shards #] [-replicationFactor #] [-p port] echo. echo -c name Name of collection to create echo. echo -d confdir Configuration directory to copy when creating the new collection, built-in options are: echo. echo basic_configs: Minimal Solr configuration echo data_driven_schema_configs: Managed schema with field-guessing support enabled echo sample_techproducts_configs: Example configuration with many optional features enabled to echo demonstrate the full power of Solr echo. echo If not specified, default is: data_driven_schema_configs echo. echo Alternatively, you can pass the path to your own configuration directory instead of using echo one of the built-in configurations, such as: bin\solr create_collection -c mycoll -d c:/tmp/myconfig echo. echo By default the script will upload the specified confdir directory into Zookeeper using the same echo name as the collection (-c) option. Alternatively, if you want to reuse an existing directory echo or create a confdir in Zookeeper that can be shared by multiple collections, use the -n option echo. echo -n configName Name the configuration directory in Zookeeper; by default, the configuration echo will be uploaded to Zookeeper using the collection name (-c), but if you want echo to use an existing directory or override the name of the configuration in echo Zookeeper, then use the -c option. echo. echo -shards # Number of shards to split the collection into echo. echo -replicationFactor # Number of copies of each document in the collection echo. echo -p port Port of a local Solr instance where you want to create the new collection echo If not specified, the script will search the local system for a running echo Solr instance and will use the port of the first server it finds. echo. goto done :zk_usage set ZK_FULL=true goto zk_short_usage :zk_full_usage echo Be sure to check the Solr logs in case of errors. echo. echo -z zkHost Optional Zookeeper connection string for all commands. If specified it echo overrides the 'ZK_HOST=...'' defined in solr.in.sh. echo. echo upconfig uploads a configset from the local machine to Zookeeper. (Backcompat: -upconfig) echo. echo downconfig downloads a configset from Zookeeper to the local machine. (Backcompat: -downconfig) echo. echo -n configName Name of the configset in Zookeeper that will be the destination of echo 'upconfig' and the source for 'downconfig'. echo. echo -d confdir The local directory the configuration will be uploaded from for echo 'upconfig' or downloaded to for 'downconfig'. If 'confdir' is a child of echo ...solr/server/solr/configsets' then the configs will be copied from/to echo that directory. Otherwise it is interpreted as a simple local path. echo. echo cp copies files or folders to/from Zookeeper or Zokeeper -^> Zookeeper echo -r Recursively copy ^ to ^. Command will fail if ^ has children and echo -r is not specified. Optional echo. echo. ^, ^ : [file:][/]path/to/local/file or zk:/path/to/zk/node echo NOTE: ^ and ^ may both be Zookeeper resources prefixed by 'zk:' echo When ^ is a zk resource, ^ may be '.' echo If ^ ends with '/', then ^ will be a local folder or parent znode and the last echo element of the ^ path will be appended. echo. echo The 'file:' prefix is stripped, thus 'file:/' specifies an absolute local path and echo 'file:somewhere' specifies a relative local path. All paths on Zookeeper are absolute echo so the slash is required. echo. echo Zookeeper nodes CAN have data, so moving a single file to a parent znode echo will overlay the data on the parent Znode so specifying the trailing slash echo is important. echo. echo Wildcards are not supported echo. echo rm deletes files or folders on Zookeeper echo -r Recursively delete if ^ is a directory. Command will fail if ^ echo has children and -r is not specified. Optional echo ^ : [zk:]/path/to/zk/node. ^ may not be the root ('/')" echo. echo mv moves (renames) znodes on Zookeeper echo ^, ^ : Zookeeper nodes, the 'zk:' prefix is optional. echo If ^ ends with '/', then ^ will be a parent znode echo and the last element of the ^ path will be appended. echo Zookeeper nodes CAN have data, so moving a single file to a parent znode echo will overlay the data on the parent Znode so specifying the trailing slash echo is important. echo. echo ls lists the znodes on Zookeeper echo -r recursively descends the path listing all znodes. Optional echo ^: The Zookeeper path to use as the root. echo. echo Only the node names are listed, not data echo. echo mkroot makes a znode in Zookeeper with no data. Can be used to make a path of arbitrary echo depth but primarily intended to create a 'chroot'." echo. echo ^: The Zookeeper path to create. Leading slash is assumed if not present. echo Intermediate nodes are created as needed if not present. echo. goto done :zk_short_usage IF NOT "!ERROR_MSG!"=="" ( echo ERROR: !ERROR_MSG! echo. ) echo Usage: solr zk upconfig^|downconfig -d ^ -n ^ [-z zkHost] echo solr zk cp [-r] ^ ^ [-z zkHost] echo solr zk rm [-r] ^ [-z zkHost] echo solr zk mv ^ ^ [-z zkHost] echo solr zk ls [-r] ^ [-z zkHost] echo solr zk mkroot ^ [-z zkHost] echo. IF "%ZK_FULL%"=="true" ( goto zk_full_usage ) ELSE ( echo Type bin/solr zk -help for full usage help ) goto done REM Really basic command-line arg parsing :parse_args set "arg=%~1" set "firstTwo=%arg:~0,2%" 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"=="-v" goto set_debug IF "%1"=="-q" goto set_warn 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"=="-s" goto set_solr_home_dir IF "%1"=="-solr.home" goto set_solr_home_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 IF "%1"=="-a" goto set_addl_opts IF "%1"=="-addlopts" goto set_addl_opts IF "%1"=="-noprompt" goto set_noprompt IF "%1"=="-k" goto set_stop_key IF "%1"=="-key" goto set_stop_key IF "%1"=="-all" goto set_stop_all IF "%firstTwo%"=="-D" goto set_passthru IF NOT "%1"=="" goto invalid_cmd_line goto invalid_cmd_line :set_script_cmd set SCRIPT_CMD=%1 SHIFT goto parse_args :set_foreground_mode set FG=1 SHIFT goto parse_args :set_verbose set verbose=1 set "PASS_TO_RUN_EXAMPLE=--verbose !PASS_TO_RUN_EXAMPLE!" SHIFT goto parse_args :set_debug set SOLR_LOG_LEVEL=DEBUG SHIFT goto parse_args :set_warn set SOLR_LOG_LEVEL=WARN SHIFT goto parse_args :set_cloud_mode set SOLR_MODE=solrcloud SHIFT goto parse_args :set_server_dir set "arg=%~2" IF "%arg%"=="" ( set SCRIPT_ERROR=Directory name is required! goto invalid_cmd_line ) set firstChar=%arg:~0,1% IF "%firstChar%"=="-" ( set SCRIPT_ERROR=Expected directory but found %2 instead! goto invalid_cmd_line ) REM See if they are using a short-hand name relative from the Solr tip directory IF EXIST "%SOLR_TIP%\%~2" ( set "SOLR_SERVER_DIR=%SOLR_TIP%\%~2" ) ELSE ( set "SOLR_SERVER_DIR=%~2" ) SHIFT SHIFT goto parse_args :set_solr_home_dir set "arg=%~2" IF "%arg%"=="" ( set SCRIPT_ERROR=Directory name is required! goto invalid_cmd_line ) set firstChar=%arg:~0,1% IF "%firstChar%"=="-" ( set SCRIPT_ERROR=Expected directory but found %2 instead! goto invalid_cmd_line ) set "SOLR_HOME=%~2" SHIFT SHIFT goto parse_args :set_example set "arg=%~2" IF "%arg%"=="" ( set SCRIPT_ERROR=Example name is required! goto invalid_cmd_line ) set firstChar=%arg:~0,1% IF "%firstChar%"=="-" ( set SCRIPT_ERROR=Expected example name but found %2 instead! goto invalid_cmd_line ) set EXAMPLE=%~2 SHIFT SHIFT goto parse_args :set_memory set "arg=%~2" IF "%arg%"=="" ( set SCRIPT_ERROR=Memory setting is required! goto invalid_cmd_line ) set firstChar=%arg:~0,1% IF "%firstChar%"=="-" ( set SCRIPT_ERROR=Expected memory setting but found %2 instead! goto invalid_cmd_line ) set SOLR_HEAP=%~2 set "PASS_TO_RUN_EXAMPLE=-m %~2 !PASS_TO_RUN_EXAMPLE!" SHIFT SHIFT goto parse_args :set_host set "arg=%~2" IF "%arg%"=="" ( set SCRIPT_ERROR=Hostname is required! goto invalid_cmd_line ) set firstChar=%arg:~0,1% IF "%firstChar%"=="-" ( set SCRIPT_ERROR=Expected hostname but found %2 instead! goto invalid_cmd_line ) set SOLR_HOST=%~2 set "PASS_TO_RUN_EXAMPLE=-h %~2 !PASS_TO_RUN_EXAMPLE!" SHIFT SHIFT goto parse_args :set_port set "arg=%~2" IF "%arg%"=="" ( set SCRIPT_ERROR=Port is required! goto invalid_cmd_line ) set firstChar=%arg:~0,1% IF "%firstChar%"=="-" ( set SCRIPT_ERROR=Expected port but found %2 instead! goto invalid_cmd_line ) set SOLR_PORT=%~2 set "PASS_TO_RUN_EXAMPLE=-p %~2 !PASS_TO_RUN_EXAMPLE!" SHIFT SHIFT goto parse_args :set_stop_key set "arg=%~2" IF "%arg%"=="" ( set SCRIPT_ERROR=Stop key is required! goto invalid_cmd_line ) set firstChar=%arg:~0,1% IF "%firstChar%"=="-" ( set SCRIPT_ERROR=Expected stop key but found %2 instead! goto invalid_cmd_line ) set STOP_KEY=%~2 SHIFT SHIFT goto parse_args :set_stop_all set STOP_ALL=1 SHIFT goto parse_args :set_zookeeper set "arg=%~2" IF "%arg%"=="" ( set SCRIPT_ERROR=Zookeeper connection string is required! goto invalid_cmd_line ) set firstChar=%arg:~0,1% IF "%firstChar%"=="-" ( set SCRIPT_ERROR=Expected Zookeeper connection string but found %2 instead! goto invalid_cmd_line ) set "ZK_HOST=%~2" set "PASS_TO_RUN_EXAMPLE=-z %~2 !PASS_TO_RUN_EXAMPLE!" SHIFT SHIFT goto parse_args :set_addl_opts set "arg=%~2" set "SOLR_ADDL_ARGS=%~2" SHIFT SHIFT goto parse_args :set_passthru set "PASSTHRU=%~1=%~2" IF NOT "%SOLR_OPTS%"=="" ( set "SOLR_OPTS=%SOLR_OPTS% %PASSTHRU%" ) ELSE ( set "SOLR_OPTS=%PASSTHRU%" ) set "PASS_TO_RUN_EXAMPLE=%PASSTHRU% !PASS_TO_RUN_EXAMPLE!" SHIFT SHIFT goto parse_args :set_noprompt set NO_USER_PROMPT=1 set "PASS_TO_RUN_EXAMPLE=-noprompt !PASS_TO_RUN_EXAMPLE!" SHIFT goto parse_args REM Perform the requested command after processing args :process_script_cmd IF "%verbose%"=="1" ( CALL :safe_echo "Using Solr root directory: %SOLR_TIP%" CALL :safe_echo "Using Java: %JAVA%" "%JAVA%" -version @echo. ) IF NOT "%SOLR_HOST%"=="" ( set SOLR_HOST_ARG=-Dhost=%SOLR_HOST% ) ELSE ( set SOLR_HOST_ARG= ) IF "%SOLR_SERVER_DIR%"=="" set "SOLR_SERVER_DIR=%DEFAULT_SERVER_DIR%" IF NOT EXIST "%SOLR_SERVER_DIR%" ( set "SCRIPT_ERROR=Solr server directory %SOLR_SERVER_DIR% not found!" goto err ) IF NOT "%EXAMPLE%"=="" goto run_example :start_solr IF "%SOLR_HOME%"=="" set "SOLR_HOME=%SOLR_SERVER_DIR%\solr" IF EXIST "%cd%\%SOLR_HOME%" set "SOLR_HOME=%cd%\%SOLR_HOME%" IF NOT EXIST "%SOLR_HOME%\" ( IF EXIST "%SOLR_SERVER_DIR%\%SOLR_HOME%" ( set "SOLR_HOME=%SOLR_SERVER_DIR%\%SOLR_HOME%" ) ELSE ( set "SCRIPT_ERROR=Solr home directory %SOLR_HOME% not found!" goto err ) ) IF "%STOP_KEY%"=="" set STOP_KEY=solrrocks @REM This is quite hacky, but examples rely on a different log4j.properties @REM so that we can write logs for examples to %SOLR_HOME%\..\logs IF [%SOLR_LOGS_DIR%] == [] ( set "SOLR_LOGS_DIR=%SOLR_SERVER_DIR%\logs" ) ELSE ( set SOLR_LOGS_DIR=%SOLR_LOGS_DIR:"=% ) set SOLR_LOGS_DIR_QUOTED="%SOLR_LOGS_DIR%" set "EXAMPLE_DIR=%SOLR_TIP%\example" set TMP=!SOLR_HOME:%EXAMPLE_DIR%=! IF NOT "%TMP%"=="%SOLR_HOME%" ( set "SOLR_LOGS_DIR=%SOLR_HOME%\..\logs" set "LOG4J_CONFIG=file:%EXAMPLE_DIR%\resources\log4j.properties" ) set IS_RESTART=0 IF "%SCRIPT_CMD%"=="restart" ( IF "%SOLR_PORT%"=="" ( set "SCRIPT_ERROR=Must specify the port when trying to restart Solr." goto err ) set SCRIPT_CMD=stop set IS_RESTART=1 ) @REM stop logic here IF "%SCRIPT_CMD%"=="stop" ( IF "%SOLR_PORT%"=="" ( IF "%STOP_ALL%"=="1" ( set found_it=0 for /f "usebackq" %%i in (`dir /b "%SOLR_TIP%\bin" ^| findstr /i "^solr-.*\.port$"`) do ( set SOME_SOLR_PORT= For /F "delims=" %%J In ('type "%SOLR_TIP%\bin\%%i"') do set SOME_SOLR_PORT=%%~J if NOT "!SOME_SOLR_PORT!"=="" ( for /f "tokens=2,5" %%j in ('netstat -aon ^| find "TCP " ^| find ":0 " ^| find ":!SOME_SOLR_PORT! "') do ( @REM j is the ip:port and k is the pid IF NOT "%%k"=="0" ( IF "%%j"=="%SOLR_JETTY_HOST%:!SOME_SOLR_PORT!" ( set found_it=1 @echo Stopping Solr process %%k running on port !SOME_SOLR_PORT! set /A STOP_PORT=!SOME_SOLR_PORT! - 1000 "%JAVA%" %SOLR_SSL_OPTS% -Djetty.home="%SOLR_SERVER_DIR%" -jar "%SOLR_SERVER_DIR%\start.jar" STOP.PORT=!STOP_PORT! STOP.KEY=%STOP_KEY% --stop del "%SOLR_TIP%"\bin\solr-!SOME_SOLR_PORT!.port timeout /T 5 REM Kill it if it is still running after the graceful shutdown For /f "tokens=2,5" %%M in ('netstat -nao ^| find "TCP " ^| find ":0 " ^| find ":!SOME_SOLR_PORT! "') do ( IF "%%N"=="%%k" ( IF "%%M"=="%SOLR_JETTY_HOST%:!SOME_SOLR_PORT!" ( @echo Forcefully killing process %%N taskkill /f /PID %%N ) ) ) ) ) ) ) ) if "!found_it!"=="0" echo No Solr nodes found to stop. ) ELSE ( set "SCRIPT_ERROR=Must specify the port when trying to stop Solr, or use -all to stop all running nodes on this host." goto err ) ) ELSE ( set found_it=0 For /f "tokens=2,5" %%M in ('netstat -nao ^| find "TCP " ^| find ":0 " ^| find ":%SOLR_PORT% "') do ( IF NOT "%%N"=="0" ( IF "%%M"=="%SOLR_JETTY_HOST%:%SOLR_PORT%" ( set found_it=1 @echo Stopping Solr process %%N running on port %SOLR_PORT% set /A STOP_PORT=%SOLR_PORT% - 1000 "%JAVA%" %SOLR_SSL_OPTS% -Djetty.home="%SOLR_SERVER_DIR%" -jar "%SOLR_SERVER_DIR%\start.jar" "%SOLR_JETTY_CONFIG%" STOP.PORT=!STOP_PORT! STOP.KEY=%STOP_KEY% --stop del "%SOLR_TIP%"\bin\solr-%SOLR_PORT%.port timeout /T 5 REM Kill it if it is still running after the graceful shutdown For /f "tokens=2,5" %%j in ('netstat -nao ^| find "TCP " ^| find ":0 " ^| find ":%SOLR_PORT% "') do ( IF "%%N"=="%%k" ( IF "%%j"=="%SOLR_JETTY_HOST%:%SOLR_PORT%" ( @echo Forcefully killing process %%N taskkill /f /PID %%N ) ) ) ) ) ) if "!found_it!"=="0" echo No Solr found running on port %SOLR_PORT% ) IF "!IS_RESTART!"=="0" goto done ) IF "!IS_RESTART!"=="1" set SCRIPT_CMD=start IF "%SOLR_PORT%"=="" set SOLR_PORT=8983 IF "%STOP_PORT%"=="" set /A STOP_PORT=%SOLR_PORT% - 1000 IF "%SCRIPT_CMD%"=="start" ( REM see if Solr is already running using netstat For /f "tokens=2,5" %%j in ('netstat -aon ^| find "TCP " ^| find ":0 " ^| find ":%SOLR_PORT% "') do ( IF NOT "%%k"=="0" ( IF "%%j"=="%SOLR_JETTY_HOST%:%SOLR_PORT%" ( set "SCRIPT_ERROR=Process %%k 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 ) ) ) ) @REM determine if -server flag is supported by current JVM "%JAVA%" -server -version > nul 2>&1 IF ERRORLEVEL 1 ( set IS_JDK=false set "SERVEROPT=" @echo WARNING: You are using a JRE without support for -server option. Please upgrade to latest JDK for best performance @echo. ) ELSE ( set IS_JDK=true set "SERVEROPT=-server" ) "%JAVA%" -d64 -version > nul 2>&1 IF ERRORLEVEL 1 ( set "IS_64BIT=false" @echo WARNING: 32-bit Java detected. Not recommended for production. Point your JAVA_HOME to a 64-bit JDK @echo. ) ELSE ( set IS_64bit=true ) REM Clean up and rotate logs call :run_utils "-remove_old_solr_logs 7" || echo "Failed removing old solr logs" call :run_utils "-archive_gc_logs" || echo "Failed archiving old GC logs" call :run_utils "-archive_console_logs" || echo "Failed archiving old console logs" call :run_utils "-rotate_solr_logs 9" || echo "Failed rotating old solr logs" IF NOT "%ZK_HOST%"=="" set SOLR_MODE=solrcloud IF "%SOLR_MODE%"=="solrcloud" ( IF "%ZK_CLIENT_TIMEOUT%"=="" set "ZK_CLIENT_TIMEOUT=15000" set "CLOUD_MODE_OPTS=-DzkClientTimeout=!ZK_CLIENT_TIMEOUT!" IF NOT "%ZK_HOST%"=="" ( set "CLOUD_MODE_OPTS=!CLOUD_MODE_OPTS! -DzkHost=%ZK_HOST%" ) ELSE ( IF "%verbose%"=="1" echo Configuring SolrCloud to launch an embedded Zookeeper using -DzkRun set "CLOUD_MODE_OPTS=!CLOUD_MODE_OPTS! -DzkRun" ) IF EXIST "%SOLR_HOME%\collection1\core.properties" set "CLOUD_MODE_OPTS=!CLOUD_MODE_OPTS! -Dbootstrap_confdir=./solr/collection1/conf -Dcollection.configName=myconf -DnumShards=1" ) ELSE ( set CLOUD_MODE_OPTS= IF NOT EXIST "%SOLR_HOME%\solr.xml" ( set "SCRIPT_ERROR=Solr home directory %SOLR_HOME% must contain solr.xml!" goto err ) ) REM These are useful for attaching remove profilers like VisualVM/JConsole IF "%ENABLE_REMOTE_JMX_OPTS%"=="true" ( IF "!RMI_PORT!"=="" set RMI_PORT=1%SOLR_PORT% 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=!RMI_PORT! ^ -Dcom.sun.management.jmxremote.rmi.port=!RMI_PORT! 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 IF "%SOLR_JAVA_STACK_SIZE%"=="" set SOLR_JAVA_STACK_SIZE=-Xss256k set SOLR_OPTS=%SOLR_JAVA_STACK_SIZE% %SOLR_OPTS% IF "%SOLR_TIMEZONE%"=="" set SOLR_TIMEZONE=UTC IF "%GC_TUNE%"=="" ( set GC_TUNE=-XX:NewRatio=3 ^ -XX:SurvivorRatio=4 ^ -XX:TargetSurvivorRatio=90 ^ -XX:MaxTenuringThreshold=8 ^ -XX:+UseConcMarkSweepGC ^ -XX:+UseParNewGC ^ -XX:ConcGCThreads=4 -XX:ParallelGCThreads=4 ^ -XX:+CMSScavengeBeforeRemark ^ -XX:PretenureSizeThreshold=64m ^ -XX:+UseCMSInitiatingOccupancyOnly ^ -XX:CMSInitiatingOccupancyFraction=50 ^ -XX:CMSMaxAbortablePrecleanTime=6000 ^ -XX:+CMSParallelRemarkEnabled ^ -XX:+ParallelRefProcEnabled ^ -XX:-OmitStackTraceInFastThrow ) IF "%GC_LOG_OPTS%"=="" ( set GC_LOG_OPTS=-verbose:gc ^ -XX:+PrintHeapAtGC ^ -XX:+PrintGCDetails ^ -XX:+PrintGCDateStamps ^ -XX:+PrintGCTimeStamps ^ -XX:+PrintTenuringDistribution ^ -XX:+PrintGCApplicationStoppedTime ) IF "%verbose%"=="1" ( @echo Starting Solr using the following settings: CALL :safe_echo " JAVA = %JAVA%" CALL :safe_echo " SOLR_SERVER_DIR = %SOLR_SERVER_DIR%" CALL :safe_echo " SOLR_HOME = %SOLR_HOME%" @echo SOLR_HOST = %SOLR_HOST% @echo SOLR_PORT = %SOLR_PORT% @echo STOP_PORT = %STOP_PORT% @echo SOLR_JAVA_MEM = %SOLR_JAVA_MEM% @echo GC_TUNE = !GC_TUNE! @echo GC_LOG_OPTS = %GC_LOG_OPTS% @echo SOLR_TIMEZONE = %SOLR_TIMEZONE% IF "%SOLR_MODE%"=="solrcloud" ( @echo CLOUD_MODE_OPTS = %CLOUD_MODE_OPTS% ) IF NOT "%SOLR_OPTS%"=="" ( @echo SOLR_OPTS = %SOLR_OPTS% ) IF NOT "%SOLR_ADDL_ARGS%"=="" ( CALL :safe_echo " SOLR_ADDL_ARGS = %SOLR_ADDL_ARGS%" ) IF "%ENABLE_REMOTE_JMX_OPTS%"=="true" ( @echo RMI_PORT = !RMI_PORT! @echo REMOTE_JMX_OPTS = %REMOTE_JMX_OPTS% ) IF NOT "%SOLR_LOG_LEVEL%"=="" ( @echo SOLR_LOG_LEVEL = !SOLR_LOG_LEVEL! ) @echo. ) set START_OPTS=-Duser.timezone=%SOLR_TIMEZONE% set START_OPTS=%START_OPTS% !GC_TUNE! %GC_LOG_OPTS% IF NOT "!CLOUD_MODE_OPTS!"=="" set "START_OPTS=%START_OPTS% !CLOUD_MODE_OPTS!" 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%" IF NOT "%SOLR_OPTS%"=="" set "START_OPTS=%START_OPTS% %SOLR_OPTS%" IF NOT "%SOLR_SSL_OPTS%"=="" ( set "SSL_PORT_PROP=-Dsolr.jetty.https.port=%SOLR_PORT%" set "START_OPTS=%START_OPTS% %SOLR_SSL_OPTS% !SSL_PORT_PROP!" ) IF NOT "%SOLR_LOG_LEVEL%"=="" set "START_OPTS=%START_OPTS% -Dsolr.log.level=%SOLR_LOG_LEVEL%" set "START_OPTS=%START_OPTS% -Dsolr.log.dir=%SOLR_LOGS_DIR_QUOTED%" IF NOT DEFINED LOG4J_CONFIG set "LOG4J_CONFIG=file:%SOLR_SERVER_DIR%\resources\log4j.properties" cd /d "%SOLR_SERVER_DIR%" IF NOT EXIST "%SOLR_LOGS_DIR%" ( mkdir "%SOLR_LOGS_DIR%" ) copy /Y NUL "%SOLR_LOGS_DIR%\.writable" > NUL 2>&1 && set WRITEOK=1 IF DEFINED WRITEOK ( del "%SOLR_LOGS_DIR%\.writable" ) else ( echo "ERROR: Logs directory %SOLR_LOGS_DIR% is not writable or could not be created. Exiting" GOTO :eof ) echo " contexts etc lib modules resources scripts solr solr-webapp " > "%TEMP%\solr-pattern.txt" findstr /i /C:" %SOLR_LOGS_DIR% " "%TEMP%\solr-pattern.txt" 1>nul if %ERRORLEVEL% == 0 ( echo "ERROR: Logs directory %SOLR_LOGS_DIR% is invalid. Reserved for the system. Exiting" GOTO :eof ) IF NOT EXIST "%SOLR_SERVER_DIR%\tmp" ( mkdir "%SOLR_SERVER_DIR%\tmp" ) IF "%JAVA_VENDOR%" == "IBM J9" ( set GCLOG_OPT="-Xverbosegclog:!SOLR_LOGS_DIR!\solr_gc.log" -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=9 -XX:GCLogFileSize=20M ) else ( set GCLOG_OPT="-Xloggc:!SOLR_LOGS_DIR!\solr_gc.log" -XX:+UseGCLogFileRotation -XX:NumberOfGCLogFiles=9 -XX:GCLogFileSize=20M ) IF "%FG%"=="1" ( REM run solr in the foreground title "Solr-%SOLR_PORT%" echo %SOLR_PORT%>"%SOLR_TIP%"\bin\solr-%SOLR_PORT%.port "%JAVA%" %SERVEROPT% %SOLR_JAVA_MEM% %START_OPTS% %GCLOG_OPT% ^ -Dlog4j.configuration="%LOG4J_CONFIG%" -DSTOP.PORT=!STOP_PORT! -DSTOP.KEY=%STOP_KEY% ^ -Dsolr.solr.home="%SOLR_HOME%" -Dsolr.install.dir="%SOLR_TIP%" ^ -Djetty.host=%SOLR_JETTY_HOST% -Djetty.port=%SOLR_PORT% -Djetty.home="%SOLR_SERVER_DIR%" ^ -Djava.io.tmpdir="%SOLR_SERVER_DIR%\tmp" -jar start.jar "%SOLR_JETTY_CONFIG%" ) ELSE ( START /B "Solr-%SOLR_PORT%" /D "%SOLR_SERVER_DIR%" ^ "%JAVA%" %SERVEROPT% %SOLR_JAVA_MEM% %START_OPTS% %GCLOG_OPT% ^ -Dlog4j.configuration="%LOG4J_CONFIG%" -DSTOP.PORT=!STOP_PORT! -DSTOP.KEY=%STOP_KEY% ^ -Dsolr.log.muteconsole ^ -Dsolr.solr.home="%SOLR_HOME%" -Dsolr.install.dir="%SOLR_TIP%" ^ -Djetty.host=%SOLR_JETTY_HOST% -Djetty.port=%SOLR_PORT% -Djetty.home="%SOLR_SERVER_DIR%" ^ -Djava.io.tmpdir="%SOLR_SERVER_DIR%\tmp" -jar start.jar "%SOLR_JETTY_CONFIG%" > "!SOLR_LOGS_DIR!\solr-%SOLR_PORT%-console.log" echo %SOLR_PORT%>"%SOLR_TIP%"\bin\solr-%SOLR_PORT%.port REM now wait to see Solr come online ... "%JAVA%" %SOLR_SSL_OPTS% %AUTHC_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 -maxWaitSecs 30 -solr !SOLR_URL_SCHEME!://%SOLR_TOOL_HOST%:%SOLR_PORT%/solr ) goto done :run_example REM Run the requested example "%JAVA%" %SOLR_SSL_OPTS% %AUTHC_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 run_example -script "%SDIR%\solr.cmd" -e %EXAMPLE% -d "%SOLR_SERVER_DIR%" ^ -urlScheme !SOLR_URL_SCHEME! !PASS_TO_RUN_EXAMPLE! REM End of run_example goto done :get_info REM Find all Java processes, correlate with those listening on a port REM and then try to contact via that port using the status tool for /f "usebackq" %%i in (`dir /b "%SOLR_TIP%\bin" ^| findstr /i "^solr-.*\.port$"`) do ( set SOME_SOLR_PORT= For /F "Delims=" %%J In ('type "%SOLR_TIP%\bin\%%i"') do set SOME_SOLR_PORT=%%~J if NOT "!SOME_SOLR_PORT!"=="" ( for /f "tokens=2,5" %%j in ('netstat -aon ^| find "TCP " ^| find ":0 " ^| find ":!SOME_SOLR_PORT! "') do ( IF NOT "%%k"=="0" ( if "%%j"=="%SOLR_JETTY_HOST%:!SOME_SOLR_PORT!" ( @echo. set has_info=1 echo Found Solr process %%k running on port !SOME_SOLR_PORT! "%JAVA%" %SOLR_SSL_OPTS% %AUTHC_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 !SOLR_URL_SCHEME!://%SOLR_TOOL_HOST%:!SOME_SOLR_PORT!/solr @echo. ) ) ) ) ) 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 set HEALTHCHECK_COLLECTION=%~2 SHIFT SHIFT goto parse_healthcheck_args :set_healthcheck_zk set HEALTHCHECK_ZK_HOST=%~2 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%" %SOLR_SSL_OPTS% %AUTHC_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 :run_assert "%JAVA%" %SOLR_SSL_OPTS% %AUTHC_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 %* if errorlevel 1 ( exit /b 1 ) goto done :get_version "%JAVA%" %SOLR_SSL_OPTS% %AUTHC_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 version goto done :run_utils set "TOOL_CMD=%~1" "%JAVA%" %SOLR_SSL_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 utils -s "%DEFAULT_SERVER_DIR%" -l "%SOLR_LOGS_DIR%" %TOOL_CMD% if errorlevel 1 ( exit /b 1 ) goto done :parse_create_args IF [%1]==[] goto run_create IF "%1"=="-c" goto set_create_name IF "%1"=="-core" goto set_create_name IF "%1"=="-collection" goto set_create_name IF "%1"=="-d" goto set_create_confdir IF "%1"=="-confdir" goto set_create_confdir IF "%1"=="-n" goto set_create_confname IF "%1"=="-confname" goto set_create_confname IF "%1"=="-s" goto set_create_shards IF "%1"=="-shards" goto set_create_shards IF "%1"=="-rf" goto set_create_rf IF "%1"=="-replicationFactor" goto set_create_rf IF "%1"=="-p" goto set_create_port IF "%1"=="-port" goto set_create_port IF "%1"=="-help" goto usage IF "%1"=="-usage" goto usage IF "%1"=="/?" goto usage goto run_create :set_create_name set CREATE_NAME=%~2 SHIFT SHIFT goto parse_create_args :set_create_confdir set CREATE_CONFDIR=%~2 SHIFT SHIFT goto parse_create_args :set_create_confname set CREATE_CONFNAME=%~2 SHIFT SHIFT goto parse_create_args :set_create_port set CREATE_PORT=%~2 SHIFT SHIFT goto parse_create_args :set_create_shards set CREATE_NUM_SHARDS=%~2 SHIFT SHIFT goto parse_create_args :set_create_rf set CREATE_REPFACT=%~2 SHIFT SHIFT goto parse_create_args :run_create IF "!CREATE_NAME!"=="" ( set "SCRIPT_ERROR=Name (-c) is a required parameter for %SCRIPT_CMD%" goto invalid_cmd_line ) IF "!CREATE_CONFDIR!"=="" set CREATE_CONFDIR=data_driven_schema_configs IF "!CREATE_NUM_SHARDS!"=="" set CREATE_NUM_SHARDS=1 IF "!CREATE_REPFACT!"=="" set CREATE_REPFACT=1 IF "!CREATE_CONFNAME!"=="" set CREATE_CONFNAME=!CREATE_NAME! REM Find a port that Solr is running on if "!CREATE_PORT!"=="" ( for /f "usebackq" %%i in (`dir /b "%SOLR_TIP%\bin" ^| findstr /i "^solr-.*\.port$"`) do ( set SOME_SOLR_PORT= For /F "Delims=" %%J In ('type "%SOLR_TIP%\bin\%%i"') do set SOME_SOLR_PORT=%%~J if NOT "!SOME_SOLR_PORT!"=="" ( for /f "tokens=2,5" %%j in ('netstat -aon ^| find "TCP " ^| find ":0 " ^| find ":!SOME_SOLR_PORT! "') do ( IF NOT "%%k"=="0" set CREATE_PORT=!SOME_SOLR_PORT! ) ) ) ) if "!CREATE_PORT!"=="" ( set "SCRIPT_ERROR=Could not find a running Solr instance on this host! Please use the -p option to specify the port." goto err ) if "%SCRIPT_CMD%"=="create_core" ( "%JAVA%" %SOLR_SSL_OPTS% %AUTHC_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 create_core -name !CREATE_NAME! -solrUrl !SOLR_URL_SCHEME!://%SOLR_TOOL_HOST%:!CREATE_PORT!/solr ^ -confdir !CREATE_CONFDIR! -configsetsDir "%SOLR_TIP%\server\solr\configsets" ) else ( "%JAVA%" %SOLR_SSL_OPTS% %AUTHC_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 create -name !CREATE_NAME! -shards !CREATE_NUM_SHARDS! -replicationFactor !CREATE_REPFACT! ^ -confname !CREATE_CONFNAME! -confdir !CREATE_CONFDIR! -configsetsDir "%SOLR_TIP%\server\solr\configsets" ^ -solrUrl !SOLR_URL_SCHEME!://%SOLR_TOOL_HOST%:!CREATE_PORT!/solr ) goto done :parse_delete_args IF [%1]==[] goto run_delete IF "%1"=="-c" goto set_delete_name IF "%1"=="-core" goto set_delete_name IF "%1"=="-collection" goto set_delete_name IF "%1"=="-p" goto set_delete_port IF "%1"=="-port" goto set_delete_port IF "%1"=="-deleteConfig" goto set_delete_config IF "%1"=="-help" goto usage IF "%1"=="-usage" goto usage IF "%1"=="/?" goto usage goto run_delete :set_delete_name set DELETE_NAME=%~2 SHIFT SHIFT goto parse_delete_args :set_delete_port set DELETE_PORT=%~2 SHIFT SHIFT goto parse_delete_args :set_delete_config set DELETE_CONFIG=%~2 SHIFT SHIFT goto parse_delete_args :run_delete IF "!DELETE_NAME!"=="" ( set "SCRIPT_ERROR=Name (-c) is a required parameter for %SCRIPT_CMD%" goto invalid_cmd_line ) REM Find a port that Solr is running on if "!DELETE_PORT!"=="" ( for /f "usebackq" %%i in (`dir /b "%SOLR_TIP%\bin" ^| findstr /i "^solr-.*\.port$"`) do ( set SOME_SOLR_PORT= For /F "Delims=" %%J In ('type "%SOLR_TIP%\bin\%%i"') do set SOME_SOLR_PORT=%%~J if NOT "!SOME_SOLR_PORT!"=="" ( for /f "tokens=2,5" %%j in ('netstat -aon ^| find "TCP " ^| find ":0 " ^| find ":!SOME_SOLR_PORT! "') do ( IF NOT "%%k"=="0" set DELETE_PORT=!SOME_SOLR_PORT! ) ) ) ) if "!DELETE_PORT!"=="" ( set "SCRIPT_ERROR=Could not find a running Solr instance on this host! Please use the -p option to specify the port." goto err ) if "!DELETE_CONFIG!"=="" ( set DELETE_CONFIG=true ) "%JAVA%" %SOLR_SSL_OPTS% %AUTHC_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 delete -name !DELETE_NAME! -deleteConfig !DELETE_CONFIG! ^ -solrUrl !SOLR_URL_SCHEME!://%SOLR_TOOL_HOST%:!DELETE_PORT!/solr goto done REM Clumsy to do the state machine thing for -d and -n, but that's required for back-compat :parse_zk_args IF "%1"=="-upconfig" ( goto set_zk_op ) ELSE IF "%1"=="upconfig" ( goto set_zk_op ) ELSE IF "%1"=="-downconfig" ( goto set_zk_op ) ELSE IF "%1"=="downconfig" ( goto set_zk_op ) ELSE IF "%1"=="cp" ( goto set_zk_op ) ELSE IF "%1"=="mv" ( goto set_zk_op ) ELSE IF "%1"=="rm" ( goto set_zk_op ) ELSE IF "%1"=="ls" ( goto set_zk_op ) ELSE IF "%1"=="mkroot" ( goto set_zk_op ) ELSE IF "%1"=="-n" ( goto set_config_name ) ELSE IF "%1"=="-r" ( goto set_zk_recurse ) ELSE IF "%1"=="-configname" ( goto set_config_name ) ELSE IF "%1"=="-d" ( goto set_configdir ) ELSE IF "%1"=="-confdir" ( goto set_configdir ) ELSE IF "%1"=="-z" ( goto set_config_zk ) ELSE IF "%1"=="/?" ( goto zk_usage ) ELSE IF "%1"=="-h" ( goto zk_usage ) ELSE IF "%1"=="-help" ( goto zk_usage ) ELSE IF "!ZK_SRC!"=="" ( if not "%~1"=="" ( goto set_zk_src ) ) ELSE IF "!ZK_DST!"=="" ( IF "%ZK_OP%"=="cp" ( goto set_zk_dst ) IF "%ZK_OP%"=="mv" ( goto set_zk_dst ) set ZK_DST="_" ) ELSE IF NOT "%1"=="" ( set ERROR_MSG="Unrecognized or misplaced zk argument %1%" goto zk_short_usage ) goto run_zk :set_zk_op set ZK_OP=%~1 SHIFT goto parse_zk_args :set_config_name set CONFIGSET_NAME=%~2 SHIFT SHIFT goto parse_zk_args :set_configdir set CONFIGSET_DIR=%~2 SHIFT SHIFT goto parse_zk_args :set_config_zk set ZK_HOST=%~2 SHIFT SHIFT goto parse_zk_args :set_zk_src set ZK_SRC=%~1 SHIFT goto parse_zk_args :set_zk_dst set ZK_DST=%~1 SHIFT goto parse_zk_args :set_zk_recurse set ZK_RECURSE="true" SHIFT goto parse_zk_args :run_zk IF "!ZK_OP!"=="" ( set "ERROR_MSG=Invalid command specified for zk sub-command" goto zk_short_usage ) IF "!ZK_HOST!"=="" ( set "ERROR_MSG=Must specify -z zkHost" goto zk_short_usage ) IF "!ZK_OP!"=="-upconfig" ( set ZK_OP="upconfig" ) IF "!ZK_OP!"=="-downconfig" ( set ZK_OP="downconfig" ) IF "!ZK_OP!"=="upconfig" ( IF "!CONFIGSET_NAME!"=="" ( set ERROR_MSG="-n option must be set for upconfig" goto zk_short_usage ) IF "!CONFIGSET_DIR!"=="" ( set ERROR_MSG="The -d option must be set for upconfig." goto zk_short_usage ) "%JAVA%" %SOLR_SSL_OPTS% %AUTHC_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 !ZK_OP! -confname !CONFIGSET_NAME! -confdir !CONFIGSET_DIR! -zkHost !ZK_HOST! ^ -configsetsDir "%SOLR_TIP%/server/solr/configsets" ) ELSE IF "!ZK_OP!"=="downconfig" ( IF "!CONFIGSET_NAME!"=="" ( set ERROR_MSG="-n option must be set for downconfig" goto zk_short_usage ) IF "!CONFIGSET_DIR!"=="" ( set ERROR_MSG="The -d option must be set for downconfig." goto zk_short_usage ) "%JAVA%" %SOLR_SSL_OPTS% %AUTHC_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 !ZK_OP! -confname !CONFIGSET_NAME! -confdir !CONFIGSET_DIR! -zkHost !ZK_HOST! ) ELSE IF "!ZK_OP!"=="cp" ( IF "%ZK_SRC%"=="" ( set ERROR_MSG=" must be specified for 'cp' command" goto zk_short_usage ) IF "%ZK_DST%"=="" ( set ERROR_MSG= must be specified for 'cp' command" goto zk_short_usage ) IF NOT "!ZK_SRC:~0,3!"=="zk:" ( IF NOT "!%ZK_DST:~0,3!"=="zk:" ( set ERROR_MSG="At least one of src or dst must be prefixed by 'zk:'" goto zk_short_usage ) ) "%JAVA%" %SOLR_SSL_OPTS% %AUTHC_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 !ZK_OP! -zkHost !ZK_HOST! -src !ZK_SRC! -dst !ZK_DST! -recurse !ZK_RECURSE! ) ELSE IF "!ZK_OP!"=="mv" ( IF "%ZK_SRC%"=="" ( set ERROR_MSG=" must be specified for 'mv' command" goto zk_short_usage ) IF "%ZK_DST%"=="" ( set ERROR_MSG=" must be specified for 'mv' command" goto zk_short_usage ) "%JAVA%" %SOLR_SSL_OPTS% %AUTHC_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 !ZK_OP! -zkHost !ZK_HOST! -src !ZK_SRC! -dst !ZK_DST! ) ELSE IF "!ZK_OP!"=="rm" ( IF "%ZK_SRC"=="" ( set ERROR_MSG="Zookeeper path to remove must be specified when using the 'rm' command" goto zk_short_usage ) "%JAVA%" %SOLR_SSL_OPTS% %AUTHC_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 !ZK_OP! -zkHost !ZK_HOST! -path !ZK_SRC! -recurse !ZK_RECURSE! ) ELSE IF "!ZK_OP!"=="ls" ( IF "%ZK_SRC"=="" ( set ERROR_MSG="Zookeeper path to remove must be specified when using the 'ls' command" goto zk_short_usage ) "%JAVA%" %SOLR_SSL_OPTS% %AUTHC_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 !ZK_OP! -zkHost !ZK_HOST! -path !ZK_SRC! -recurse !ZK_RECURSE! ) ELSE IF "!ZK_OP!"=="mkroot" ( IF "%ZK_SRC"=="" ( set ERROR_MSG="Zookeeper path to create must be specified when using the 'mkroot' command" goto zk_short_usage ) "%JAVA%" %SOLR_SSL_OPTS% %AUTHC_OPTS% %SOLR_ZK_CREDS_AND_ACLS% -Dsolr.install.dir="%SOLR_TIP%" ^ -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 !ZK_OP! -zkHost !ZK_HOST! -path !ZK_SRC! ) ELSE ( set ERROR_MSG="Unknown zk option !ZK_OP!" goto zk_short_usage ) goto done :invalid_cmd_line @echo. IF "!SCRIPT_ERROR!"=="" ( @echo Invalid command-line option: %1 ) ELSE ( @echo ERROR: !SCRIPT_ERROR! ) @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 IF "%FIRST_ARG%"=="create" ( goto create_usage ) ELSE IF "%FIRST_ARG%"=="create_core" ( goto create_core_usage ) ELSE IF "%FIRST_ARG%"=="create_collection" ( goto create_collection_usage ) ELSE IF "%FIRST_ARG%"=="zk" ( goto zk_short_usage ) ELSE ( goto script_usage ) :need_java_home @echo Please set the JAVA_HOME environment variable to the path where you installed Java 1.8+ goto done :need_java_vers @echo Java 1.8 or later is required to run Solr. goto done :err @echo. @echo ERROR: !SCRIPT_ERROR! @echo. exit /b 1 :done ENDLOCAL exit /b 0 REM Tests what Java we have and sets some global variables :resolve_java_info CALL :resolve_java_vendor set JAVA_MAJOR_VERSION=0 set JAVA_VERSION_INFO= set JAVA_BUILD=0 FOR /f "usebackq tokens=3" %%a IN (`^""%JAVA%" -version 2^>^&1 ^| findstr "version"^"`) do ( set JAVA_VERSION_INFO=%%a REM Remove surrounding quotes set JAVA_VERSION_INFO=!JAVA_VERSION_INFO:"=! REM Extract the major Java version, e.g. 7, 8, 9, 10 ... for /f "tokens=2 delims=." %%a in ("!JAVA_VERSION_INFO!") do ( set JAVA_MAJOR_VERSION=%%a ) REM Don't look for "_{build}" if we're on IBM J9. if NOT "%JAVA_VENDOR%" == "IBM J9" ( for /f "delims=_ tokens=2" %%a in ("!JAVA_VERSION_INFO!") do ( set /a JAVA_BUILD=%%a ) ) ) GOTO :eof REM Set which JVM vendor we have :resolve_java_vendor "%JAVA%" -version 2>&1 | findstr /i "IBM J9" > nul if %ERRORLEVEL% == 1 ( set "JAVA_VENDOR=Oracle" ) else ( set "JAVA_VENDOR=IBM J9" ) set JAVA_VENDOR_OUT= GOTO :eof REM Safe echo which does not mess with () in strings :safe_echo set "eout=%1" set eout=%eout:"=% echo !eout! GOTO :eof