| [162] | 1 | #!/bin/bash | 
|---|
|  | 2 | # Program: | 
|---|
|  | 3 | #   NutchEz management interface | 
|---|
|  | 4 | # Author: | 
|---|
|  | 5 | #   Waue, Shunfa, Rock {waue, shunfa, rock}@nchc.org.tw | 
|---|
|  | 6 | # Version: | 
|---|
|  | 7 | #    1.0 | 
|---|
|  | 8 | # History: | 
|---|
|  | 9 | #   2010/06/07  Rock    First release (1.0) | 
|---|
|  | 10 |  | 
|---|
| [172] | 11 | # [Variables Declaration] # | 
|---|
| [186] | 12 | DIALOG="dialog" | 
|---|
| [162] | 13 | main_choice= | 
|---|
| [186] | 14 | lang= | 
|---|
| [162] | 15 |  | 
|---|
| [172] | 16 | # [PATH Declaration] # | 
|---|
| [186] | 17 | NutchEZ_Install_PATH="/opt/nutchez" | 
|---|
|  | 18 | Tomcat_HOME="/opt/nutchez/tomcat" | 
|---|
|  | 19 | NutchEZ_HOME="/home/nutchuser/nutchez" | 
|---|
| [224] | 20 | Work_Path=$NutchEZ_HOME/system | 
|---|
| [171] | 21 |  | 
|---|
| [219] | 22 | #Work_Path="./" | 
|---|
|  | 23 | #Work_Path_J=0 | 
|---|
|  | 24 | ##  Work Path setup ## | 
|---|
|  | 25 | #echo $0 | grep '/' || Work_Path_J=1 | 
|---|
|  | 26 | #if [ "$Work_Path_J" == "0"  ]; then | 
|---|
|  | 27 | # Work_Path=$(echo $0 | sed 's/nutchez//') | 
|---|
|  | 28 | #fi | 
|---|
| [196] | 29 |  | 
|---|
| [186] | 30 | # [Env Declaration] # | 
|---|
| [209] | 31 | . $Work_Path/lang/lang_en_US_nutchez | 
|---|
| [186] | 32 |  | 
|---|
| [172] | 33 | # [Functions Declaration] # | 
|---|
| [186] | 34 | ## [Pre-check for language] ## | 
|---|
|  | 35 | function prepare_lang(){ | 
|---|
|  | 36 | lang=$(locale | grep 'LANG=' | cut -d "=" -f2) | 
|---|
|  | 37 |  | 
|---|
|  | 38 | # if lang=zh then source lang_zh_TW_nutchez | 
|---|
| [237] | 39 | echo $lang | grep 'zh' && source $Work_Path/lang/lang_zh_TW | 
|---|
| [186] | 40 | } | 
|---|
|  | 41 |  | 
|---|
|  | 42 |  | 
|---|
|  | 43 | ## [Pre-Check for nutch_nodes file] ## | 
|---|
| [162] | 44 | function prepare_check(){ | 
|---|
| [172] | 45 | # 若無 nutchez_nodes 則跳出 | 
|---|
|  | 46 | if [ ! -e "${NutchEZ_HOME}/system/nutch_nodes" ]; then | 
|---|
| [186] | 47 | $DIALOG --clear --backtitle "$dia_back" --title "$dia_pre_check_title_1" \ | 
|---|
|  | 48 | --msgbox "$dia_pre_check_msg_1 $NutchEZ_HOME/system/nutch_nodes !!!" 10 40 | 
|---|
| [162] | 49 | exit | 
|---|
|  | 50 | fi | 
|---|
|  | 51 |  | 
|---|
| [172] | 52 | # 判斷 nutch_nodes 和 nutch_nodes.back | 
|---|
|  | 53 | # 第一次執行則要求 user 更新 /etc/hosts | 
|---|
|  | 54 | if [ ! -e "${NutchEZ_HOME}/system/nutch_nodes.bak" ]; then | 
|---|
| [186] | 55 | $DIALOG --clear --backtitle "$dia_back" --title "$dia_pre_check_title_2" \ | 
|---|
|  | 56 | --yesno "$dia_pre_check_yesno_1\n$dia_pre_check_yesno_2" 10 55 | 
|---|
| [162] | 57 |  | 
|---|
| [186] | 58 | echo -e "$pre_check_echo_1" | 
|---|
| [219] | 59 | $Work_Path/duplicate_del "${NutchEZ_HOME}/system/nutch_nodes" | 
|---|
|  | 60 | su root -c "$Work_Path/duplicate_del /etc/hosts && $Work_Path/add_hosts ${NutchEZ_HOME}/system/nutch_nodes /etc/hosts" | 
|---|
| [172] | 61 | # 若密碼輸入失敗則跳出 | 
|---|
|  | 62 | if [ $? == "1" ]; then | 
|---|
| [186] | 63 | echo "$pre_check_echo_2" | 
|---|
| [172] | 64 | exit | 
|---|
|  | 65 | fi | 
|---|
| [249] | 66 | cp -f "${NutchEZ_HOME}/system/nutch_nodes" "${NutchEZ_HOME}/system/nutch_nodes.bak" | 
|---|
|  | 67 |  | 
|---|
| [172] | 68 | # 若 nutch_nodes 被更新過,則要求更新 /etc/hosts | 
|---|
|  | 69 | elif [ ${NutchEZ_HOME}/system/nutch_nodes -nt ${NutchEZ_HOME}/system/nutch_nodes.bak ]; then | 
|---|
| [186] | 70 | $DIALOG --clear --backtitle "$dia_back" --title "$dia_pre_check_title_2" \ | 
|---|
|  | 71 | --yesno "$dia_pre_check_yesno_3\n$dia_pre_check_yesno_2" 10 55 | 
|---|
| [165] | 72 |  | 
|---|
| [186] | 73 | echo -e "$pre_check_echo_1" | 
|---|
| [219] | 74 | $Work_Path/duplicate_del "${NutchEZ_HOME}/system/nutch_nodes" | 
|---|
|  | 75 | su root -c "$Work_Path/duplicate_del /etc/hosts && $Work_Path/add_hosts ${NutchEZ_HOME}/system/nutch_nodes /etc/hosts" | 
|---|
| [172] | 76 | # 若密碼輸入失敗則跳出 | 
|---|
|  | 77 | if [ $? == "1" ]; then | 
|---|
| [186] | 78 | echo "$pre_check_echo_2=" | 
|---|
| [172] | 79 | exit | 
|---|
|  | 80 | fi | 
|---|
|  | 81 | fi | 
|---|
| [162] | 82 | } | 
|---|
|  | 83 |  | 
|---|
| [172] | 84 | ## [Main Menu] ## | 
|---|
| [162] | 85 | function main_menu(){ | 
|---|
|  | 86 | main_choice="/tmp/main_choice" | 
|---|
|  | 87 |  | 
|---|
| [186] | 88 | $DIALOG --clear --backtitle "$dia_back" \ | 
|---|
|  | 89 | --title "$dia_main_title_1" \ | 
|---|
|  | 90 | --menu "$dia_choose" 15 60 7 \ | 
|---|
|  | 91 | "cluster_status" "$dia_main_menu_1_1" \ | 
|---|
|  | 92 | "cluster_setup" "$dia_main_menu_1_2" \ | 
|---|
|  | 93 | "server_setup" "$dia_main_menu_1_3" \ | 
|---|
|  | 94 | "tomcat_switch" "$dia_main_menu_1_4" \ | 
|---|
|  | 95 | "tomcat_port" "$dia_main_menu_1_5" \ | 
|---|
|  | 96 | "lang_switch" "$dia_main_menu_1_6" \ | 
|---|
|  | 97 | "exit" "$dia_exit" 2>$main_choice | 
|---|
| [162] | 98 | } | 
|---|
|  | 99 |  | 
|---|
| [174] | 100 | ## [Cluster Status (datanode & tasktracker)] ## | 
|---|
|  | 101 | function cluster_status(){ | 
|---|
|  | 102 | IP_list=$(cat $NutchEZ_HOME/system/nutch_nodes | grep -v '^$' | grep -v '#'  | awk '{print $1}') | 
|---|
|  | 103 | clusterStatus="/tmp/clusterStatus" | 
|---|
|  | 104 | rm $clusterStatus 2> /dev/null | 
|---|
|  | 105 | #printf '%16s\t %11s\t %10s\t %25s\n' "[IP] [Hostanme] [Network] [Dtatnode & Tasktracker]" >>$clusterStatus | 
|---|
| [186] | 106 | echo -e "$cluster_status_echo_1" >>$clusterStatus | 
|---|
| [174] | 107 | echo -e "------------------------------------------------------------------------" >>$clusterStatus | 
|---|
| [186] | 108 | echo -e "\n$cluster_status_echo_2" | 
|---|
| [174] | 109 | for ip in $IP_list | 
|---|
|  | 110 | do | 
|---|
|  | 111 | # Check Network status | 
|---|
|  | 112 | ip_status="online" | 
|---|
|  | 113 | ping -c1 -w1 $ip 2>&1 > /dev/null || ip_status="offline" | 
|---|
|  | 114 | # Check Hadoop/Nutch service through ssh | 
|---|
| [243] | 115 | Task_Data_status="shutdown" | 
|---|
| [174] | 116 | if [ $ip_status == "online" ]; then | 
|---|
|  | 117 | Task_Data=$(ssh -o StrictHostKeyChecking=no $ip "jps |grep TaskTracker ; jps | grep  DataNode") | 
|---|
|  | 118 | fi | 
|---|
|  | 119 |  | 
|---|
| [175] | 120 | [ -z "$Task_Data" ] || Task_Data_status="running" | 
|---|
| [174] | 121 | host_name=$(cat $NutchEZ_HOME/system/nutch_nodes | grep $ip | awk '{print $2}') | 
|---|
| [186] | 122 | echo -e "$ip  $host_name \t\t $ip_status \t $Task_Data_status" >>$clusterStatus | 
|---|
| [174] | 123 | #    printf '%16s\t %11s\t %10s\t %25s\n' "$ip $host_name $ip_status $Task_Data_status" >>$clusterStatus | 
|---|
|  | 124 | done | 
|---|
|  | 125 |  | 
|---|
| [186] | 126 | read -p "$cluster_status_read_1" | 
|---|
|  | 127 | $DIALOG --clear --backtitle "$dia_back" \ | 
|---|
|  | 128 | --title "$dia_cluster_status_title_1" --textbox $clusterStatus 20 90 | 
|---|
| [210] | 129 |  | 
|---|
|  | 130 | # Back to main menu | 
|---|
|  | 131 | main_menu | 
|---|
|  | 132 | menu_choose | 
|---|
| [174] | 133 | } | 
|---|
|  | 134 |  | 
|---|
| [183] | 135 |  | 
|---|
| [186] | 136 | ## [Server Setup (namenode & jobtracker)] ## | 
|---|
| [183] | 137 | function server_setup(){ | 
|---|
|  | 138 | serverSetup=/tmp/serverSetup | 
|---|
|  | 139 | pid_name=$(jps | grep NameNode) | 
|---|
|  | 140 | pid_job=$(jps | grep JobTracker) | 
|---|
|  | 141 |  | 
|---|
|  | 142 | if [ -z "$pid_name" -a -z "$pid_job" ]; then | 
|---|
| [186] | 143 | $DIALOG --clear --backtitle "$dia_back" --title "$dia_server_title_1" \ | 
|---|
|  | 144 | --msgbox "$dia_server_msg_1" 7 50 | 
|---|
| [183] | 145 | elif [ -z "$pid_name" -a -n "$pid_job" ]; then | 
|---|
| [186] | 146 | $DIALOG --clear --backtitle "$dia_back" --title "$dia_server_title_1" \ | 
|---|
|  | 147 | --msgbox "$dia_server_msg_2" 7 50 | 
|---|
| [183] | 148 | elif [ -n "$pid_name" -a -z "$pid_job" ]; then | 
|---|
| [186] | 149 | $DIALOG --clear --backtitle "$dia_back" --title "$dia_server_title_1" \ | 
|---|
|  | 150 | --msgbox "$dia_server_msg_3" 7 50 | 
|---|
| [183] | 151 | else | 
|---|
| [186] | 152 | $DIALOG --clear --backtitle "$dia_back" --title "$dia_server_title_1" \ | 
|---|
|  | 153 | --msgbox "$dia_server_msg_4" 7 50 | 
|---|
| [183] | 154 | fi | 
|---|
|  | 155 |  | 
|---|
| [186] | 156 | $DIALOG --clear --backtitle "$dia_back" --title "$dia_server_title_2" \ | 
|---|
|  | 157 | --menu "$dia_choose" 15 65 4 \ | 
|---|
|  | 158 | "start" "$dia_server_menu_1_1" \ | 
|---|
| [243] | 159 | "shutdown" "$dia_server_menu_1_2" \ | 
|---|
| [186] | 160 | "restart" "$dia_server_menu_1_3" \ | 
|---|
| [237] | 161 | "main" "$dia_backto_main" 2>$serverSetup | 
|---|
| [183] | 162 |  | 
|---|
|  | 163 | if [ "$(cat $serverSetup)" == "start" ]; then | 
|---|
|  | 164 | $NutchEZ_Install_PATH/nutch/bin/start-dfs.sh | 
|---|
|  | 165 | $NutchEZ_Install_PATH/nutch/bin/start-mapred.sh | 
|---|
| [237] | 166 | # Back to main menu | 
|---|
|  | 167 | main_menu | 
|---|
|  | 168 | menu_choose | 
|---|
| [243] | 169 | elif [ "$(cat $serverSetup)" == "shutdown" ]; then | 
|---|
| [183] | 170 | $NutchEZ_Install_PATH/nutch/bin/stop-dfs.sh | 
|---|
|  | 171 | $NutchEZ_Install_PATH/nutch/bin/stop-mapred.sh | 
|---|
| [237] | 172 | # Back to main menu | 
|---|
|  | 173 | main_menu | 
|---|
|  | 174 | menu_choose | 
|---|
| [183] | 175 | elif [ "$(cat $serverSetup)" == "restart" ]; then | 
|---|
|  | 176 | $NutchEZ_Install_PATH/nutch/bin/stop-dfs.sh | 
|---|
|  | 177 | $NutchEZ_Install_PATH/nutch/bin/stop-mapred.sh | 
|---|
|  | 178 | $NutchEZ_Install_PATH/nutch/bin/start-dfs.sh | 
|---|
|  | 179 | $NutchEZ_Install_PATH/nutch/bin/start-mapred.sh | 
|---|
| [237] | 180 | # Back to main menu | 
|---|
|  | 181 | main_menu | 
|---|
|  | 182 | menu_choose | 
|---|
|  | 183 | elif [ "$(cat $serverSetup)" == "main" ]; then | 
|---|
|  | 184 | main_menu | 
|---|
|  | 185 | menu_choose | 
|---|
| [183] | 186 | else | 
|---|
|  | 187 | exit | 
|---|
|  | 188 | fi | 
|---|
| [210] | 189 |  | 
|---|
| [183] | 190 | } | 
|---|
|  | 191 |  | 
|---|
|  | 192 |  | 
|---|
| [172] | 193 | ## [Cluster Setup (datanode & tasktracker)] ## | 
|---|
| [162] | 194 | function cluster_setup(){ | 
|---|
| [172] | 195 | # 從 nutch_nodes 讀出 ip 和 hostname | 
|---|
|  | 196 | #IP_list=$(cat $NutchEZ_HOME/system/nutch_nodes | grep -v '^$' | grep -v '#' | awk '{print $1}') | 
|---|
|  | 197 | #HOST_list=$(cat $NutchEZ_HOME/system/nutch_nodes | grep -v '^$' | grep -v '#' | awk '{print $2}') | 
|---|
|  | 198 | LIST_status="off" | 
|---|
|  | 199 | allpart="/tmp/allpart" | 
|---|
|  | 200 | runNodes="/tmp/runNodes" | 
|---|
|  | 201 | clusterSetup="/tmp/clusterSetup" | 
|---|
| [162] | 202 |  | 
|---|
| [186] | 203 | $DIALOG --clear --backtitle "$dia_back" \ | 
|---|
|  | 204 | --title "$dia_cluster_setup_title_1" \ | 
|---|
|  | 205 | --menu "$dia_choose" 15 55 3 \ | 
|---|
|  | 206 | "All" "$dia_cluster_setup_menu_1_1" \ | 
|---|
|  | 207 | "Part" "$dia_cluster_setup_menu_1_2" \ | 
|---|
| [237] | 208 | "Main" "$dia_backto_main" 2>$allpart | 
|---|
| [162] | 209 |  | 
|---|
| [172] | 210 | # 判斷是否選 all 和 part,若是 all 直接到服務選單,若是 part 則先到機器選單 | 
|---|
| [177] | 211 | if [ "$(cat $allpart)" == "All" ]; then | 
|---|
| [172] | 212 | cat $NutchEZ_HOME/system/nutch_nodes | grep -v '^$' | grep -v '#'  | awk '{print $1}' >$runNodes | 
|---|
| [177] | 213 | elif [ "$(cat $allpart)" == "Part" ]; then | 
|---|
| [186] | 214 | $DIALOG --clear --backtitle "$dia_back" --title "$dia_cluster_setup_title_2" \ | 
|---|
|  | 215 | --checklist "$dia_cluster_setup_check_1" 15 55 7 $(cat $NutchEZ_HOME/system/nutch_nodes | \ | 
|---|
| [172] | 216 | grep -v '^$' | grep -v '#'  | awk '{print $1 "\t" $2 "\t" "$LIST_status" }') 2>$runNodes | 
|---|
| [243] | 217 | #    read -p "$runNodes and $(cat $runNodes)" | 
|---|
| [237] | 218 | elif [ "$(cat $allpart)" == "Main" ]; then | 
|---|
|  | 219 | main_menu | 
|---|
|  | 220 | menu_choose | 
|---|
| [177] | 221 | else | 
|---|
|  | 222 | exit | 
|---|
| [172] | 223 | fi | 
|---|
|  | 224 |  | 
|---|
| [177] | 225 | if [ -z "$(cat $runNodes)" ]; then | 
|---|
| [180] | 226 | exit | 
|---|
| [243] | 227 | else | 
|---|
|  | 228 | $(cat $runNodes) | sed -i 's/"//g' $runNodes | 
|---|
| [177] | 229 | fi | 
|---|
|  | 230 |  | 
|---|
| [186] | 231 | $DIALOG --clear --backtitle "$dia_back" --title "$dia_cluster_setup_title_3" \ | 
|---|
|  | 232 | --menu "$dia_choose" 15 65 4 \ | 
|---|
|  | 233 | "start" "$dia_cluster_setup_menu_2_1" \ | 
|---|
| [243] | 234 | "shutdown" "$dia_cluster_setup_menu_2_2" \ | 
|---|
| [186] | 235 | "restart" "$dia_cluster_setup_menu_2_3" \ | 
|---|
| [238] | 236 | "main" "$dia_backto_main" 2>$clusterSetup | 
|---|
| [162] | 237 |  | 
|---|
|  | 238 | if [ "$(cat $clusterSetup)" == "start" ]; then | 
|---|
| [186] | 239 | echo -e "\n$cluster_setup_echo_1" | 
|---|
|  | 240 | for node in $(cat $runNodes) | 
|---|
| [162] | 241 | do | 
|---|
| [176] | 242 | ssh -o StrictHostKeyChecking=no $node "$NutchEZ_Install_PATH/nutch/bin/hadoop-daemon.sh start datanode \ | 
|---|
| [186] | 243 | ; $NutchEZ_Install_PATH/nutch/bin/hadoop-daemon.sh start tasktracker" 2>/dev/null | 
|---|
|  | 244 | [ $? == "0" ] || echo "$cluster_setup_echo_error $node !!!" | 
|---|
| [162] | 245 | done | 
|---|
| [237] | 246 | main_menu | 
|---|
|  | 247 | menu_choose | 
|---|
| [243] | 248 | elif [ "$(cat $clusterSetup)" == "shutdown" ]; then | 
|---|
| [186] | 249 | echo -e "\n$cluster_setup_echo_3" | 
|---|
| [172] | 250 | for node in $(cat $runNodes) | 
|---|
| [162] | 251 | do | 
|---|
| [176] | 252 | ssh -o StrictHostKeyChecking=no $node "$NutchEZ_Install_PATH/nutch/bin/hadoop-daemon.sh stop datanode \ | 
|---|
| [186] | 253 | ; $NutchEZ_Install_PATH/nutch/bin/hadoop-daemon.sh stop tasktracker" 2>/dev/null | 
|---|
|  | 254 | [ $? == "0" ] || echo "$cluster_setup_echo_error $node !!!" | 
|---|
| [162] | 255 | done | 
|---|
| [237] | 256 | main_menu | 
|---|
|  | 257 | menu_choose | 
|---|
| [177] | 258 | elif [ "$(cat $clusterSetup)" == "restart"  ]; then | 
|---|
| [186] | 259 | echo -e "\n$cluster_setup_echo_5" | 
|---|
| [172] | 260 | for node in $(cat $runNodes) | 
|---|
|  | 261 | do | 
|---|
| [176] | 262 | ssh -o StrictHostKeyChecking=no $node "$NutchEZ_Install_PATH/nutch/bin/hadoop-daemon.sh stop datanode \ | 
|---|
| [177] | 263 | ; $NutchEZ_Install_PATH/nutch/bin/hadoop-daemon.sh stop tasktracker \ | 
|---|
|  | 264 | ; $NutchEZ_Install_PATH/nutch/bin/hadoop-daemon.sh start datanode \ | 
|---|
| [186] | 265 | ; $NutchEZ_Install_PATH/nutch/bin/hadoop-daemon.sh start tasktracker" 2>/dev/null | 
|---|
|  | 266 | [ $? == "0" ] || echo "$cluster_setup_echo_error $node !!!" | 
|---|
| [172] | 267 | done | 
|---|
| [237] | 268 | main_menu | 
|---|
|  | 269 | menu_choose | 
|---|
| [238] | 270 |  | 
|---|
|  | 271 | elif [ "$(cat $clusterSetup)" == "main"  ]; then | 
|---|
|  | 272 | main_menu | 
|---|
|  | 273 | menu_choose | 
|---|
| [237] | 274 | else | 
|---|
| [177] | 275 | exit | 
|---|
| [162] | 276 | fi | 
|---|
| [237] | 277 | # Back to main menu | 
|---|
|  | 278 | #    main_menu | 
|---|
|  | 279 | #    menu_choose | 
|---|
| [162] | 280 | } | 
|---|
|  | 281 |  | 
|---|
| [172] | 282 | ## [Tomcat Severice start/stop/restart] ## | 
|---|
| [162] | 283 | function tomcat_switch(){ | 
|---|
| [186] | 284 | tom_pids=$(ps x | grep -v 'grep' | grep "tomcat" | awk '{print $1}') | 
|---|
|  | 285 | if [ -n "$tom_pids" ]; then | 
|---|
|  | 286 | $DIALOG --clear --backtitle "$dia_back" --title "$dia_tomcat_switch_title_1" \ | 
|---|
|  | 287 | --msgbox "$dia_tomcat_switch_msg_1" 7 50 | 
|---|
| [162] | 288 | else | 
|---|
| [186] | 289 | $DIALOG --clear --backtitle "$dia_back" --title "$dia_tomcat_switch_title_1" \ | 
|---|
|  | 290 | --msgbox "$dia_tomcat_switch_msg_2" 7 50 | 
|---|
| [162] | 291 | fi | 
|---|
|  | 292 | tomcatSwitch="/tmp/tomcatSwitch" | 
|---|
| [186] | 293 | $DIALOG --clear --backtitle "$dia_back" --title "$dia_tomcat_switch_title_2" \ | 
|---|
|  | 294 | --menu "$dia_choose" 15 55 4 \ | 
|---|
|  | 295 | "start" "$dia_tomcat_switch_menu_1_1" \ | 
|---|
| [243] | 296 | "shutdown" "$dia_tomcat_switch_menu_1_2" \ | 
|---|
| [186] | 297 | "restart" "$dia_tomcat_switch_menu_1_3" \ | 
|---|
| [237] | 298 | "main" "$dia_backto_main" 2>$tomcatSwitch | 
|---|
| [162] | 299 |  | 
|---|
| [177] | 300 | if [ "$(cat $tomcatSwitch)" == "exit" ]; then | 
|---|
|  | 301 | exit 0 | 
|---|
| [237] | 302 |  | 
|---|
|  | 303 | elif [ "$(cat $tomcatSwitch)" == "main" ]; then | 
|---|
|  | 304 | main_menu | 
|---|
|  | 305 | menu_choose | 
|---|
| [177] | 306 | fi | 
|---|
|  | 307 |  | 
|---|
|  | 308 | # jude $Tomcat_HOME/bin/startup.sh | 
|---|
|  | 309 | if [ ! -e $Tomcat_HOME/bin/startup.sh ]; then | 
|---|
| [186] | 310 | echo -e "\n$tomcat_switch_echo_1 $Tomcat_HOME/bin/startup.sh" | 
|---|
| [177] | 311 | exit | 
|---|
|  | 312 | fi | 
|---|
|  | 313 |  | 
|---|
| [184] | 314 | if [ ! -e $Tomcat_HOME/bin/shutdown.sh ]; then | 
|---|
| [186] | 315 | echo -e "\n$tomcat_switch_echo_1 $Tomcat_HOME/bin/shutdown.sh" | 
|---|
| [177] | 316 | exit | 
|---|
|  | 317 | fi | 
|---|
|  | 318 |  | 
|---|
| [162] | 319 | if [ "$(cat $tomcatSwitch)" == "start" ]; then | 
|---|
| [186] | 320 | echo "$tomcat_switch_echo_3" | 
|---|
| [176] | 321 | $Tomcat_HOME/bin/startup.sh | 
|---|
| [243] | 322 | elif [ "$(cat $tomcatSwitch)" == "shutdown" ]; then | 
|---|
| [186] | 323 | echo "$tomcat_switch_echo_4" | 
|---|
| [176] | 324 | $Tomcat_HOME/bin/shutdown.sh | 
|---|
| [186] | 325 | for tom_pid in $tom_pids | 
|---|
|  | 326 | do | 
|---|
|  | 327 | kill -9 $tom_pid 2>/dev/null | 
|---|
|  | 328 | done | 
|---|
| [162] | 329 | elif [ "$(cat $tomcatSwitch)" == "restart" ]; then | 
|---|
| [186] | 330 | echo "$tomcat_switch_echo_5" | 
|---|
| [176] | 331 | $Tomcat_HOME/bin/shutdown.sh | 
|---|
| [186] | 332 | for tom_pid in $tom_pids | 
|---|
|  | 333 | do | 
|---|
|  | 334 | kill -9 $tom_pid 2>/dev/null | 
|---|
|  | 335 | done | 
|---|
| [176] | 336 | $Tomcat_HOME/bin/startup.sh | 
|---|
| [162] | 337 | else | 
|---|
|  | 338 | exit 0 | 
|---|
|  | 339 | fi | 
|---|
| [210] | 340 |  | 
|---|
|  | 341 | # Back to main menu | 
|---|
|  | 342 | main_menu | 
|---|
|  | 343 | menu_choose | 
|---|
| [162] | 344 | } | 
|---|
|  | 345 |  | 
|---|
| [172] | 346 | ## [Tomcat Port Change] ## | 
|---|
| [162] | 347 | function tomcat_port(){ | 
|---|
|  | 348 |  | 
|---|
| [176] | 349 | if [ ! -e $Tomcat_HOME/conf/server.xml ]; then | 
|---|
| [186] | 350 | $DIALOG --clear --backtitle "$dia_back" --title "$dia_tomcat_port_title_1" \ | 
|---|
|  | 351 | --msgbox "$dia_tomcat_port_msg_1 $Tomcat_HOME/conf/server.xml !!!" 10 50 | 
|---|
| [162] | 352 | exit | 
|---|
|  | 353 | fi | 
|---|
|  | 354 | tomcatPort="/tmp/tomcatPort" | 
|---|
| [186] | 355 | $DIALOG --clear --backtitle "$dia_back" --title "$dia_tomcat_port_title_2" \ | 
|---|
|  | 356 | --inputbox "$dia_tomcat_port_input_1" 10 55 2>$tomcatPort | 
|---|
| [162] | 357 |  | 
|---|
| [177] | 358 | if [ -z "$(cat $tomcatPort)" ]; then | 
|---|
| [210] | 359 | # Back to main menu | 
|---|
|  | 360 | main_menu | 
|---|
|  | 361 | menu_choose | 
|---|
| [162] | 362 | else | 
|---|
| [176] | 363 | modify_line_nu=$(cat -n $Tomcat_HOME/conf/server.xml | grep -v SSL | grep 'HTTP/1.1' | grep '<Connector' | awk '{print $1}') | 
|---|
| [182] | 364 | sed -i "${modify_line_nu}c <Connector port=\"$(cat $tomcatPort)\" protocol=\"HTTP/1.1\"" $Tomcat_HOME/conf/server.xml | 
|---|
| [186] | 365 |  | 
|---|
|  | 366 | tom_pids=$(ps x | grep -v 'grep' | grep "tomcat" | awk '{print $1}') | 
|---|
| [176] | 367 | $Tomcat_HOME/bin/shutdown.sh | 
|---|
| [186] | 368 | for tom_pid in $tom_pids | 
|---|
|  | 369 | do | 
|---|
|  | 370 | kill -9 $tom_pid 2>/dev/null | 
|---|
|  | 371 | done | 
|---|
| [176] | 372 | $Tomcat_HOME/bin/startup.sh | 
|---|
| [162] | 373 | fi | 
|---|
| [210] | 374 |  | 
|---|
|  | 375 | # Back to main menu | 
|---|
|  | 376 | main_menu | 
|---|
|  | 377 | menu_choose | 
|---|
| [162] | 378 | } | 
|---|
|  | 379 |  | 
|---|
|  | 380 |  | 
|---|
| [172] | 381 | ## [Language Change] ## | 
|---|
| [162] | 382 | function lang_switch(){ | 
|---|
|  | 383 | langSwitch="/tmp/langSwitch" | 
|---|
| [186] | 384 | $DIALOG --clear --backtitle "$dia_back" --title "$dia_lang_title_1" \ | 
|---|
|  | 385 | --menu "$dia_choose" 15 55 3 \ | 
|---|
|  | 386 | "en_US" "$dia_lang_menu_1_1" \ | 
|---|
|  | 387 | "zh_TW" "$dia_lang_menu_1_2" \ | 
|---|
| [237] | 388 | "main" "$dia_backto_main" 2>$langSwitch | 
|---|
| [162] | 389 | # | 
|---|
| [177] | 390 | if [ "$(cat $langSwitch)" == "Exit" ]; then | 
|---|
|  | 391 | exit | 
|---|
| [186] | 392 | elif [ "$(cat $langSwitch)" == "en_US" ]; then | 
|---|
| [209] | 393 | source $Work_Path/lang/lang_en_US_nutchez | 
|---|
| [186] | 394 | main_menu | 
|---|
|  | 395 | menu_choose | 
|---|
|  | 396 | elif [ "$(cat $langSwitch)" == "zh_TW" ]; then | 
|---|
| [209] | 397 | source $Work_Path/lang/lang_zh_TW_nutchez | 
|---|
| [186] | 398 | main_menu | 
|---|
|  | 399 | menu_choose | 
|---|
| [177] | 400 | fi | 
|---|
| [162] | 401 | } | 
|---|
|  | 402 |  | 
|---|
| [186] | 403 | ## [Menu_choose] ## | 
|---|
|  | 404 | function menu_choose(){ | 
|---|
| [162] | 405 | case $(cat $main_choice) in | 
|---|
| [174] | 406 | "cluster_status") | 
|---|
|  | 407 | cluster_status;; | 
|---|
| [186] | 408 | "cluster_setup") | 
|---|
|  | 409 | cluster_setup;; | 
|---|
| [183] | 410 | "server_setup") | 
|---|
|  | 411 | server_setup;; | 
|---|
| [162] | 412 | "tomcat_switch") | 
|---|
|  | 413 | tomcat_switch;; | 
|---|
|  | 414 | "tomcat_port") | 
|---|
|  | 415 | tomcat_port;; | 
|---|
|  | 416 | "lang_switch") | 
|---|
|  | 417 | lang_switch;; | 
|---|
|  | 418 | esac | 
|---|
| [186] | 419 | } | 
|---|
|  | 420 |  | 
|---|
|  | 421 | # [Main Code] # | 
|---|
|  | 422 | if [ $USER != "nutchuser" ]; then | 
|---|
|  | 423 | echo -e "\n$user_error" | 
|---|
|  | 424 | exit | 
|---|
|  | 425 | fi | 
|---|
|  | 426 |  | 
|---|
|  | 427 | prepare_lang | 
|---|
|  | 428 | prepare_check | 
|---|
|  | 429 | main_menu | 
|---|
|  | 430 | menu_choose | 
|---|