[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 |
---|