You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@trafodion.apache.org by db...@apache.org on 2018/01/18 19:19:31 UTC

[2/3] trafodion git commit: [TRAFODION-2802]Modified according to the review comments

[TRAFODION-2802]Modified according to the review comments


Project: http://git-wip-us.apache.org/repos/asf/trafodion/repo
Commit: http://git-wip-us.apache.org/repos/asf/trafodion/commit/9048853b
Tree: http://git-wip-us.apache.org/repos/asf/trafodion/tree/9048853b
Diff: http://git-wip-us.apache.org/repos/asf/trafodion/diff/9048853b

Branch: refs/heads/master
Commit: 9048853bdce13a2da0052d73403379a4d0039f7d
Parents: d1f1db6
Author: sumory.wu <su...@gmail.com>
Authored: Mon Dec 25 19:26:54 2017 +0800
Committer: sumory.wu <su...@gmail.com>
Committed: Mon Dec 25 19:26:54 2017 +0800

----------------------------------------------------------------------
 install/traf_checkset_env.sh | 138 ++++++++++++++++++++++++++++----------
 1 file changed, 103 insertions(+), 35 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/trafodion/blob/9048853b/install/traf_checkset_env.sh
----------------------------------------------------------------------
diff --git a/install/traf_checkset_env.sh b/install/traf_checkset_env.sh
index f2016b8..58ae454 100755
--- a/install/traf_checkset_env.sh
+++ b/install/traf_checkset_env.sh
@@ -25,16 +25,72 @@
 # must configure the yum repo right before execute this script.
 # run this script with normal user, while must has sudo permission.
 
+function usage {
+
+cat <<EOF
+
+Syntax: $0 [ -y ] [ -h | -help | --help | -v | -version | --version ]
+Usage:
+
+    1. You can create building environment with this script 
+    2. You must have sudo privileges before running this script.
+    3. This script will change the following environment:
+        a) Checking and installing basic commands(like as yum lsb_release awk cut uname).
+        b) Checking the os version.
+        c) Installing all libraries which is depended by Trafodion.
+        d) Removing pdsh and qt-dev if had installed.
+        e) Checking and setting the java environment.
+        f) Checking and setting locale(modify the LANG and LC_LANG to en_US.UTF-8)
+        g) Changing $HOME/.bashrc(Add JAVA_HOME, LANG, LC_LANG and TOOLSDIR, modify PATH)
+        h) Calling the script traf_tools_setup.sh to install the depended tools.
+    4. Getting more information from the link:
+        https://cwiki.apache.org/confluence/display/TRAFODION/Create+Build+Environment
+    5. It's best to download all the necessary softwares and set the environment variable "MY_SW_HOME" before running this script.
+    6. You can set optional environment variables as following:
+        a) MY_JVM_PATH: set the specific JVM path
+        b) MY_JAVA_VER: set the specific JDK version name
+        c) MY_SUDO: set the specific sudo command
+        d) MY_YUM: set the command for installing packages 
+        e) MY_LOCAL_SW_DIST:
+    7. This script maybe create the directory "${MY_DOWNLOAD_SW_DIST}" if not exits.
+
+EOF
+}
+
 #default path
 MY_JVM_PATH=${MY_JVM_PATH-"/usr/lib/jvm"}
 MY_JAVA_VER=${MY_JAVA_VER-"java-1.7.0-openjdk"}
 MY_SUDO=${MY_SUDO-"sudo"}
 MY_YUM=${MY_YUM-"${MY_SUDO} yum -y"}
 
-# for setup tools
-MY_LOCAL_SW_DIST=${MY_LOCAL_SW_DIST-${HOME}/local_software_tools}
-MY_INSTALL_SW_DIST=${MY_INSTALL_SW_DIST-${HOME}/installed_software_tools}
-MY_DOWNLOAD_SW_DIST=${MY_DOWNLOAD_SW_DIST-${HOME}/download_software_tools}
+# for setup tools, 
+MY_SW_HOME=${MY_SW_HOME-"/add_your_local_shared_folder_here"}
+MY_LOCAL_SW_DIST=${MY_LOCAL_SW_DIST-${MY_SW_HOME}/local_software_tools}
+MY_INSTALL_SW_DIST=${MY_INSTALL_SW_DIST-${MY_SW_HOME}/installed_software_tools}
+MY_DOWNLOAD_SW_DIST=${MY_DOWNLOAD_SW_DIST-${MY_SW_HOME}/download_software_tools}
+
+MY_IMPLICIT_Y="n"
+while [ $# -gt 0 ];
+do
+  case $1 in
+      -y) MY_IMPLICIT_Y="y"
+	  ;;
+      -h|-help|--help)
+	  usage
+	  exit 0
+	  ;;
+      -v|-version|--version)
+	  echo "version 0.0.0.1"
+	  exit 0
+	  ;;
+      *)  echo "ERROR: Unexpected argument $1"
+	  usage
+	  exit 1
+	  ;;
+  esac
+  shift
+done
+
 
 CHECKLOG=${LOGFILE-$(pwd)/$0.log}
 local_sws=(udis llvm mpich bison icu zookeeper thrift apache-maven protobuf apache-log4cxx hadoop)
@@ -55,19 +111,21 @@ http://archive.apache.org/dist/hadoop/common/hadoop-2.6.0/hadoop-2.6.0.tar.gz
 # check the local software directory
 if [ ! -d ${MY_LOCAL_SW_DIST} ]; then
     echo "WARNING: Local software tools aren't present. Will download all tools from the internet. This will be very slow. If you do have the local software tools present, set the environment variable MY_LOCAL_SW_DIST to point to them and run this script again. The default local software directory is [${MY_LOCAL_SW_DIST}]. Do you want to continue? Enter y/n (default: n):"
-    read YN
-    case ${YN} in
-	Y|y|Yes|YES)
-	    ;;
-	*)
-	    echo "Downloading the following build tools from the internet:"
-	    for i in `seq ${#local_sws[@]}`
-	    do
-		printf "%2d.%15s: %s\n" ${i} ${local_sws[${i}-1]} ${http_sws[${i}-1]}
-	    done
-	    exit 1
-	    ;;
-    esac
+    if [ "x$MY_IMPLICIT_Y" = "xn" ]; then
+	read YN
+	case ${YN} in
+	    Y|y|Yes|YES)
+		;;
+	    *)
+		echo "Downloading the following build tools from the internet:"
+		for i in `seq ${#local_sws[@]}`
+		do
+		    printf "%2d.%15s: %s\n" ${i} ${local_sws[${i}-1]} ${http_sws[${i}-1]}
+		done
+		exit 1
+		;;
+	esac
+    fi
 else
     # check the local software's source exist or not
     for local_sw in ${local_sws[@]}
@@ -86,7 +144,7 @@ if [ "x$?" != "x0" ]; then
     exit 1
 fi
 
-# check the based command
+# check some basic commands
 basecmds=(yum lsb_release awk cut uname)
 for basecmd in ${basecmds[@]}  
 do
@@ -100,16 +158,16 @@ do
 	    lsb_release)
 		(${MY_YUM} install redhat-lsb) >>${LOGFILE}2>&1
 		if [ "x$?" = "x0" ]; then
-		    echo "ERROR: yum repo server has a error when run command [${MY_YUM} install redhat-lsb]."
+		    echo "ERROR: yum repo server has an error when running command [${MY_YUM} install redhat-lsb]."
 		    exit 1
 		fi
 		;;
 	    *)
-		echo "ERROR: command [${basecmd}] not exist. Make sure you have installed it, and have added it to the command path."
+		echo "ERROR: command [${basecmd}] does not exist. Make sure you have installed it, and have added it to the command path."
 		exit 1
 	esac
     fi
-    echo "INFO: command ${basecmd} exist"
+    echo "INFO: command ${basecmd} exists"
 done
 
 osname=`uname -o`
@@ -172,16 +230,15 @@ done
 echo "INFO: install dependent library finish"
 
 # remove pdsh and qt-dev
-echo "INFO: remove pdsh and qt-dev trafodion scripts get confused."
+echo "INFO: remove pdsh and qt-dev commands to avoid problems with trafodion scripts"
 (${MY_YUM} erase pdsh) >>${LOGFILE}2>&1
 (${MY_YUM} erase qt-dev) >>${LOGFILE}2>&1
 
 # check and set the java
 echo "INFO: check and set java environment"
-javadir=`\ls -L ${MY_JVM_PATH} | grep "${MY_JAVA_VER}-"`
+javadir=`\ls -L ${MY_JVM_PATH} | grep "${MY_JAVA_VER}-" | head -n 1`
 javapath="${MY_JVM_PATH}/${javadir}"
-dirs="ASSEMBLY_EXCEPTION  bin  include  jre  jre-abrt  lib  LICENSE" \
-				     " tapset  THIRD_PARTY_README"
+
 if [ ! -d ${javapath} ]; then
      echo "ERROR: java dir [${javapath}] isn't right"
      exit 1
@@ -189,22 +246,32 @@ fi
 
 javahome=`grep JAVA_HOME ~/.bashrc | wc -l`
 if [ "x${javahome}" = "x0" ]; then
+    echo -en "\n# Added by traf_checkset_env.sh of trafodion\n" >> $HOME/.bashrc
     echo -en "export JAVA_HOME=${javapath}\n" >> $HOME/.bashrc
     echo -en "export PATH=\$PATH:\$JAVA_HOME/bin\n" >> $HOME/.bashrc
+else
+    java_version=`${JAVA_HOME}/bin/java -version 2>&1 | awk 'NR==1{ gsub(/"/,""); print $3}'`
+    case ${java_version} in
+	1.7.*)
+	    echo "INFO: java version is [$java_version]"
+	    ;;
+	*)
+	    echo "ERROR: java version is [$java_version]. Only 1.7.x versions are presently supported."
+	    exit 1
+    esac
 fi
 
 # check and set locale
-local_locale=`locale | grep -v "xen_US.UTF-8"`
-if [ "${local_locale}" != "x" ]; then
-    echo "WARN: locale is not right, this script modify the locale to "\
-         "\"en_US.UTF-8\" from "
-    echo "[${local_locale}]"
-    lang_set=`grep LANG ~/.bashrc | wc -l`
-    if [ "x${lang_set}" = "x0" ]; then
+local_locale=`locale | grep -v "en_US.UTF-8" | head -n 1`
+if [ "x${local_locale}" != "x" ]; then
+    lang_set=`grep LANG ~/.bashrc | awk -F= '{ print $2 }'`
+    if [ "x${lang_set}" != "xen_US.UTF-8" ]; then
+	echo -en "\n# Added by traf_checkset_env.sh of trafodion\n" >> $HOME/.bashrc
 	echo -en "export LANG=\"en_US.UTF-8\"\n" >> $HOME/.bashrc
     fi
-    lc_all_set=`grep LC_ALL ~/.bashrc | wc -l`
-    if [ "x${lc_all_set}" = "x0" ]; then
+    lc_all_set=`grep LC_TIME ~/.bashrc | awk -F= '{ print $2 }'`
+    if [ "x${lc_all_set}" != "xen_US.UTF-8" ]; then
+	echo -en "\n# Added by traf_checkset_env.sh of trafodion\n" >> $HOME/.bashrc
 	echo -en "export LC_ALL=\"en_US.UTF-8\"\n" >> $HOME/.bashrc
     fi
 fi
@@ -224,7 +291,7 @@ if [ ! -e ${MY_DOWNLOAD_SW_DIST} ]; then
     echo "INFO: mkdir [${MY_DOWNLOAD_SW_DIST}]"
     mkdir ${MY_DOWNLOAD_SW_DIST}
 fi
-echo "INFO: install tools with command:"
+echo "INFO: install tools with command:"\
 "    [./traf_tools_setup.sh -d ${MY_DOWNLOAD_SW_DIST} -i ${MY_INSTALL_SW_DIST}]]"
 ./traf_tools_setup.sh -d ${MY_DOWNLOAD_SW_DIST} -i ${MY_INSTALL_SW_DIST}
 if [ "x$?" = "x0" ]; then
@@ -237,6 +304,7 @@ fi
 
 tooldirexist=`grep TOOLSDIR ~/.bashrc | wc -l`
 if [ "x${tooldirexist}" = "x0" ]; then
+    echo -en "\n# Added by traf_checkset_env.sh of trafodion\n" >> $HOME/.bashrc
     echo -en "export TOOLSDIR=${MY_INSTALL_SW_DIST}\n" >> $HOME/.bashrc
     echo -en "export PATH=\$PATH:\$TOOLSDIR/apache-maven-3.3.3/bin\n" >> $HOME/.bashrc
 fi