source: nutchez-0.2/src/shell/master_remove.sh @ 224

Last change on this file since 224 was 224, checked in by waue, 14 years ago

更改檢查work_path 的路徑設定方法
檢查更新流程

File size: 3.8 KB
Line 
1#!/bin/bash
2# Program:
3#   remove shell script for master uninstall
4# Author:
5#   Waue, Shunfa, Rock {waue, shunfa, rock}@nchc.org.tw
6# Version:
7#    1.0
8# History:
9#   
10
11source /home/nutchuser/nutchez/system/lang_link
12
13##########  echo function  ##########
14function debug_info () {
15  if [ $? -eq 0 ]; then
16    echo -e "\033[1;35;40m info - $1 \033[0m"
17  fi
18}
19
20
21function show_info () {
22  if [ $? -eq 0 ]; then
23    echo -e "\033[1;32;40m $1 \033[0m"
24  fi
25}
26##########end echo function ##########
27
28nutch_PATH=/home/nutchuser/nutchez/system
29
30
31# check root
32function check_root(){
33  debug_info "check_root"
34  if [ $USER != "root" ]; then
35    show_info "$MR_check_root_1" # "請切換成 root 身份執行移除程式!!!"
36    exit
37  fi
38  show_info "$MR_check_root_2" # "已確認為root身份, 將繼續執行此移除程式!"
39}
40
41# shutdown service
42function shutdown_service () {
43  show_info "$MR_shutdown_service_echo_1" # "停止其他尚未關閉的slaves服務..."
44  slaves_list=`cat $nutch_PATH'/nutch_nodes' | cut -d' ' -f1`
45  for nutch_node in $slaves_list
46  do
47    show_info "驗證叢集狀態"
48    TaskTrackerStatus=`ssh -o StrictHostKeyChecking=no $nutch_node "jps |grep TaskTracker |sed 's/[0-9]* //g'"`
49    DataNodeStatus=`ssh -o StrictHostKeyChecking=no $nutch_node "jps |grep DataNode |sed 's/[0-9]* //g'"`
50
51    if [ $TaskTrackerStatus == "TaskTracker" ]; then
52       show_info "TaskTracker@$nutch_node is running, we will shutdown it!"
53       su nutchuser -c "ssh nutchuser@$nutch_node /opt/nutchez/nutch/bin/hadoop-daemon.sh stop tasktracker"
54    fi
55
56    if [ $DataNodeStatus == "DataNode" ]; then
57       show_info "DataNode@$nutch_node is running, we will shutdown it!"
58       show_info "Shutdown $nutch_node."
59       su nutchuser -c "ssh nutchuser@$nutch_node /opt/nutchez/nutch/bin/hadoop-daemon.sh stop datanode"
60    fi
61  done
62  show_info "$MR_shutdown_service_echo_2" # "關閉本機服務..."
63  su nutchuser -c "/opt/nutchez/nutch/bin/stop-all.sh"
64  su nutchuser -c "/opt/nutchez/tomcat/bin/shutdown.sh"
65  show_info "$MR_shutdown_service_echo_3" # "本機服務已關閉"
66}
67
68# 移除檔案及資料夾
69function remove_folders () {
70  rm /usr/local/bin/nutchez
71  show_info "$MR_remove_folders_echo_1" # "正在刪除安裝時所建立的檔案及資料夾..."
72  rm -rf /opt/nutchez
73  rm -rf /var/nutchez
74  show_info "$MR_remove_folders_echo_2" # "安裝時所建立的檔案及資料夾已刪除"
75}
76
77
78# 還原/etc/hosts
79function edit_hosts () {
80  show_info "$MR_edit_hosts_echo_1" # "修改/etc/hosts..."
81#  slaves_list=`cat $nutch_PATH'/nutch_nodes' | cut -d' ' -f1`
82#  for nutch_node in $slaves_list
83#  do
84#    Line_NO=`cat /etc/hosts | grep -n $nutch_node | sed 's/:.*//g'`
85#    if [[ $Line_NO -ge 1 ]]; then
86#      sed -i ''$Line_NO'd' /etc/hosts
87#    fi
88#  done
89  cat > /etc/hosts < /home/nutchuser/nutchez/system/hosts.bak
90  show_info "$MR_edit_hosts_echo_2" # "完成修改/etc/hosts"
91}
92
93# 移除使用者
94function user_delete () {
95  show_info "$MR_user_delete_echo_1" # "正在刪除nutchuser使用者..."
96  userdel -r nutchuser
97  show_info "$MR_user_delete_echo_2" # "使用者nutchuser已刪除"
98}
99
100# Main function
101function main () {
102  show_info "$MR_main_echo_1" #"警告 - 此一程式為移除nutchEZ程式, 若您為誤執行此一程式, 請按Ctrl+c離開此程序!"
103  show_info "$MR_main_echo_2" #"本執行程序將會移除安裝nutchEZ時所新增的檔案及nutchuser使用者帳號"
104# 詢問是否繼續
105  read -p "$MR_main_echo_3" confirm # "請問是否確定移除此一節點:1.確定 2.取消"
106# 確認移除
107  if [ $confirm -eq 1 ]; then
108    check_root
109    shutdown_service
110    remove_folders
111    edit_hosts
112    user_delete
113    show_info "$MR_main_echo_4" # "移除程序已完成!"
114  elif [ $confirm -eq 2 ]; then
115    show_info "$MR_main_echo_5" # "您已取消移除程序!"
116    show_info "$MR_main_echo_6" # "若要移除請再重新執行!"
117  fi
118}
119
120main
121
Note: See TracBrowser for help on using the repository browser.