| #!/usr/bin/env bash |
| if [ ! -z "${IGNITE_SCRIPT_STRICT_MODE:-}" ] |
| then |
| set -o nounset |
| set -o errexit |
| set -o pipefail |
| set -o errtrace |
| set -o functrace |
| fi |
| |
| # |
| # Licensed to the Apache Software Foundation (ASF) under one or more |
| # contributor license agreements. See the NOTICE file distributed with |
| # this work for additional information regarding copyright ownership. |
| # The ASF licenses this file to You under the Apache License, Version 2.0 |
| # (the "License"); you may not use this file except in compliance with |
| # the License. You may obtain a copy of the License at |
| # |
| # http://www.apache.org/licenses/LICENSE-2.0 |
| # |
| # Unless required by applicable law or agreed to in writing, software |
| # distributed under the License is distributed on an "AS IS" BASIS, |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| # See the License for the specific language governing permissions and |
| # limitations under the License. |
| # |
| |
| # |
| # Grid cluster control. |
| # |
| |
| # |
| # Import common functions. |
| # |
| if [ "${IGNITE_HOME:-}" = "" ]; |
| then IGNITE_HOME_TMP="$(dirname "$(cd "$(dirname "$0")"; "pwd")")"; |
| else IGNITE_HOME_TMP=${IGNITE_HOME}; |
| fi |
| |
| # |
| # Set SCRIPTS_HOME - base path to scripts. |
| # |
| SCRIPTS_HOME="${IGNITE_HOME_TMP}/bin" |
| |
| source "${SCRIPTS_HOME}"/include/functions.sh |
| |
| # |
| # Discover path to Java executable and check it's version. |
| # |
| checkJava |
| |
| # |
| # Discover IGNITE_HOME environment variable. |
| # |
| setIgniteHome |
| |
| if [ "${DEFAULT_CONFIG:-}" == "" ]; then |
| DEFAULT_CONFIG=config/default-config.xml |
| fi |
| |
| # |
| # Set IGNITE_LIBS. |
| # |
| . "${SCRIPTS_HOME}"/include/setenv.sh |
| . "${SCRIPTS_HOME}"/include/build-classpath.sh # Will be removed in the binary release. |
| CP="${IGNITE_LIBS}:${IGNITE_HOME}/libs/optional/ignite-zookeeper/*" |
| |
| RANDOM_NUMBER=$("$JAVA" -cp "${CP}" org.apache.ignite.startup.cmdline.CommandLineRandomNumberGenerator) |
| |
| # |
| # Find available port for JMX |
| # |
| # You can specify IGNITE_JMX_PORT environment variable for overriding automatically found JMX port |
| # |
| # This is executed when -nojmx is not specified |
| # |
| if [ "${NOJMXI:-}" == "0" ] ; then |
| findAvailableJmxPort |
| fi |
| |
| # Mac OS specific support to display correct name in the dock. |
| osname=`uname` |
| |
| if [ "${DOCK_OPTS:-}" == "" ]; then |
| DOCK_OPTS="-Xdock:name=Ignite Node" |
| fi |
| |
| # |
| # JVM options. See http://java.sun.com/javase/technologies/hotspot/vmoptions.jsp for more details. |
| # |
| # ADD YOUR/CHANGE ADDITIONAL OPTIONS HERE |
| # |
| if [ -z "${JVM_OPTS:-}" ] ; then |
| if [[ `"$JAVA" -version 2>&1 | egrep "1\.[7]\."` ]]; then |
| JVM_OPTS="-Xms256m -Xmx1g" |
| else |
| JVM_OPTS="-Xms256m -Xmx1g" |
| fi |
| fi |
| |
| # |
| # Uncomment to enable experimental commands [--wal] |
| # |
| # JVM_OPTS="${JVM_OPTS} -DIGNITE_ENABLE_EXPERIMENTAL_COMMAND=true" |
| |
| # |
| # Uncomment the following GC settings if you see spikes in your throughput due to Garbage Collection. |
| # |
| # JVM_OPTS="$JVM_OPTS -XX:+UseG1GC" |
| |
| # |
| # Uncomment if you get StackOverflowError. |
| # On 64 bit systems this value can be larger, e.g. -Xss16m |
| # |
| # JVM_OPTS="${JVM_OPTS} -Xss4m" |
| |
| # |
| # Uncomment to set preference for IPv4 stack. |
| # |
| # JVM_OPTS="${JVM_OPTS} -Djava.net.preferIPv4Stack=true" |
| |
| # |
| # Assertions are disabled by default since version 3.5. |
| # If you want to enable them - set 'ENABLE_ASSERTIONS' flag to '1'. |
| # |
| ENABLE_ASSERTIONS="1" |
| |
| # |
| # Set '-ea' options if assertions are enabled. |
| # |
| if [ "${ENABLE_ASSERTIONS:-}" = "1" ]; then |
| JVM_OPTS="${JVM_OPTS} -ea" |
| fi |
| |
| # |
| # Set main class to start service (grid node by default). |
| # |
| if [ "${MAIN_CLASS:-}" = "" ]; then |
| MAIN_CLASS=org.apache.ignite.internal.commandline.CommandHandler |
| fi |
| |
| # |
| # Remote debugging (JPDA). |
| # Uncomment and change if remote debugging is required. |
| # |
| # JVM_OPTS="-agentlib:jdwp=transport=dt_socket,server=y,suspend=n,address=8787 ${JVM_OPTS}" |
| |
| # |
| # Final JVM_OPTS for Java 9+ compatibility |
| # |
| if [ $version -eq 8 ] ; then |
| JVM_OPTS="\ |
| -XX:+AggressiveOpts \ |
| ${JVM_OPTS}" |
| |
| elif [ $version -gt 8 ] && [ $version -lt 11 ]; then |
| JVM_OPTS="\ |
| -XX:+AggressiveOpts \ |
| --add-exports=java.base/jdk.internal.misc=ALL-UNNAMED \ |
| --add-exports=java.base/sun.nio.ch=ALL-UNNAMED \ |
| --add-exports=java.management/com.sun.jmx.mbeanserver=ALL-UNNAMED \ |
| --add-exports=jdk.internal.jvmstat/sun.jvmstat.monitor=ALL-UNNAMED \ |
| --add-exports=java.base/sun.reflect.generics.reflectiveObjects=ALL-UNNAMED \ |
| --illegal-access=permit \ |
| --add-modules=java.xml.bind \ |
| ${JVM_OPTS}" |
| |
| elif [ $version -ge 11 ] ; then |
| JVM_OPTS="\ |
| --add-exports=java.base/jdk.internal.misc=ALL-UNNAMED \ |
| --add-exports=java.base/sun.nio.ch=ALL-UNNAMED \ |
| --add-exports=java.management/com.sun.jmx.mbeanserver=ALL-UNNAMED \ |
| --add-exports=jdk.internal.jvmstat/sun.jvmstat.monitor=ALL-UNNAMED \ |
| --add-exports=java.base/sun.reflect.generics.reflectiveObjects=ALL-UNNAMED \ |
| --add-opens=jdk.management/com.sun.management.internal=ALL-UNNAMED \ |
| --illegal-access=permit \ |
| ${JVM_OPTS}" |
| fi |
| |
| case $osname in |
| Darwin*) |
| "$JAVA" ${JVM_OPTS} ${QUIET:-} "${DOCK_OPTS}" ${JMX_MON:-} \ |
| -DIGNITE_UPDATE_NOTIFIER=false -DIGNITE_HOME="${IGNITE_HOME}" \ |
| -DIGNITE_PROG_NAME="$0" ${JVM_XOPTS:-} -cp "${CP}" ${MAIN_CLASS} $@ |
| ;; |
| *) |
| "$JAVA" ${JVM_OPTS} ${QUIET:-} ${JMX_MON:-} \ |
| -DIGNITE_UPDATE_NOTIFIER=false -DIGNITE_HOME="${IGNITE_HOME}" \ |
| -DIGNITE_PROG_NAME="$0" ${JVM_XOPTS:-} -cp "${CP}" ${MAIN_CLASS} $@ |
| ;; |
| esac |