SOLR-9475: Add install script support for CentOS and better distro detection under Docker

(cherry picked from commit a1bbc99)
This commit is contained in:
Jan Høydahl 2016-09-20 11:22:53 +02:00
parent 09d399791a
commit 74bf88f8fe
2 changed files with 20 additions and 8 deletions

View File

@ -109,6 +109,9 @@ Bug Fixes
* SOLR-8080: bin/solr start script now exits with informative message if using wrong Java version (janhoy) * SOLR-8080: bin/solr start script now exits with informative message if using wrong Java version (janhoy)
* SOLR-9475: bin/install_solr_service.sh script got improved detection of Linux distro, especially within
virtualized/Docker environment through parsing of /etc/*-release files. Now also supports CentOS. (janhoy)
Optimizations Optimizations
---------------------- ----------------------

View File

@ -52,20 +52,29 @@ print_usage() {
echo "" echo ""
} # end print_usage } # end print_usage
if [ -f "/proc/version" ]; then proc_version=`cat /etc/*-release 2>/dev/null`
if [[ $? -gt 0 ]]; then
if [ -f "/proc/version" ]; then
proc_version=`cat /proc/version` proc_version=`cat /proc/version`
else else
proc_version=`uname -a` proc_version=`uname -a`
fi
fi fi
if [[ $proc_version == *"Debian"* ]]; then if [[ $proc_version == *"Debian"* ]]; then
distro=Debian distro=Debian
elif [[ $proc_version == *"Red Hat"* ]]; then elif [[ $proc_version == *"Red Hat"* ]]; then
distro=RedHat distro=RedHat
elif [[ $proc_version == *"CentOS"* ]]; then
distro=CentOS
elif [[ $proc_version == *"Ubuntu"* ]]; then elif [[ $proc_version == *"Ubuntu"* ]]; then
distro=Ubuntu distro=Ubuntu
elif [[ $proc_version == *"SUSE"* ]]; then elif [[ $proc_version == *"SUSE"* ]]; then
distro=SUSE distro=SUSE
elif [[ $proc_version == *"Darwin"* ]]; then
echo "Sorry, this script does not support macOS. You'll need to setup Solr as a service manually using the documentation provided in the Solr Reference Guide."
echo "You could also try installing via Homebrew (http://brew.sh/), e.g. brew install solr"
exit 1
else else
echo -e "\nERROR: Your Linux distribution ($proc_version) not supported by this script!\nYou'll need to setup Solr as a service manually using the documentation provided in the Solr Reference Guide.\n" 1>&2 echo -e "\nERROR: Your Linux distribution ($proc_version) not supported by this script!\nYou'll need to setup Solr as a service manually using the documentation provided in the Solr Reference Guide.\n" 1>&2
exit 1 exit 1
@ -214,7 +223,7 @@ fi
solr_uid="`id -u "$SOLR_USER"`" solr_uid="`id -u "$SOLR_USER"`"
if [ $? -ne 0 ]; then if [ $? -ne 0 ]; then
echo "Creating new user: $SOLR_USER" echo "Creating new user: $SOLR_USER"
if [ "$distro" == "RedHat" ]; then if [ "$distro" == "RedHat" ] || [ "$distro" == "CentOS" ] ; then
adduser "$SOLR_USER" adduser "$SOLR_USER"
elif [ "$distro" == "SUSE" ]; then elif [ "$distro" == "SUSE" ]; then
useradd -m "$SOLR_USER" useradd -m "$SOLR_USER"
@ -316,15 +325,15 @@ find "$SOLR_VAR_DIR" -type d -print0 | xargs -0 chmod 0750
find "$SOLR_VAR_DIR" -type f -print0 | xargs -0 chmod 0640 find "$SOLR_VAR_DIR" -type f -print0 | xargs -0 chmod 0640
# configure autostart of service # configure autostart of service
if [[ "$distro" == "RedHat" || "$distro" == "SUSE" ]]; then if [[ "$distro" == "RedHat" || "$distro" == "CentOS" || "$distro" == "SUSE" ]]; then
chkconfig "$SOLR_SERVICE" on chkconfig "$SOLR_SERVICE" on
else else
update-rc.d "$SOLR_SERVICE" defaults update-rc.d "$SOLR_SERVICE" defaults
fi fi
echo "Service $SOLR_SERVICE installed."
echo "Customize Solr startup configuration in /etc/default/$SOLR_SERVICE.in.sh"
# start service # start service
service "$SOLR_SERVICE" start service "$SOLR_SERVICE" start
sleep 5 sleep 5
service "$SOLR_SERVICE" status service "$SOLR_SERVICE" status
echo "Service $SOLR_SERVICE installed."