summaryrefslogtreecommitdiff
path: root/start_services.sh
blob: f206f363ada59d134524c32a6b8091a3d8ae1fce (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
#!/bin/bash

# 此脚本用于拉起分布式各个服务
# 使用方法:
# 1. 启动所有服务: ./start_services.sh all
# 2. 启动某个服务: ./start_services.sh [samgr|huks|deviceauth|softbus|dm|dfs|datamgr]

BIN_PATH="/system/bin"

# 定义map,保存参数和对应执行的shell命令
# 如果需要增加服务启动,直接往此map中增加字段即可
declare -A COMMAND_MAP=(
  ["samgr"]="./samgr > /system/log/samgr.log 2>&1 &"
  ["huks"]="./sa_main /system/profile/huks_service.xml > /system/log/huks_service.log 2>&1 &"
  ["deviceauth"]="./deviceauth_service > /system/log/device_auth.log 2>&1 &"
  ["softbus"]="./sa_main /system/profile/softbus_server.xml > /system/log/softbus_server.log 2>&1 &"
  ["dm"]="./sa_main /system/profile/device_manager.xml > /system/log/device_manager.log 2>&1 &"
  ["dfs"]="./sa_main /system/profile/distributedfiledaemon.xml > /system/log/distributedfiledaemon.log 2>&1 &"
  ["datamgr"]="./sa_main /system/profile/distributeddata.xml > /system/log/datamgr.log 2>&1 &"
)

# 不同服务的前驱依赖关系
declare -A CMD_REQUIRES=(
  ["samgr"]=""
  ["huks"]="samgr"
  ["deviceauth"]="samgr huks"
  ["softbus"]="samgr huks deviceauth"
  ["dm"]="samgr huks deviceauth softbus"
  ["dfs"]="samgr huks deviceauth softbus dm"
  ["datamgr"]="samgr huks deviceauth softbus dm"
)

start_order=("samgr" "huks" "deviceauth" "softbus" "dm" "dfs" "datamgr")

# 日志打印函数
log() {
  case $1 in
    error)
      echo "[ERROR] $2"
      ;;
    info)
      echo "[INFO] $2"
      ;;
    debug)
      if [ "$DEBUG_MODE" == "true" ]; then
        echo "[DEBUG] $2"
      fi
      ;;
    *)
      echo "Invalid log level: $1"
      ;;
  esac
}

check_process_running() {
  if pgrep -x "$1" > /dev/null; then
    return 0
  else
    return 1
  fi
}

start_process() {
  process_name=$1
  deps="${CMD_REQUIRES[$process_name]}"

  for dep in $deps; do
    if check_process_running "$dep"; then
      log info "Process '$dep' is already running"
      continue
    fi
    if [ "${COMMAND_MAP[$dep]+isset}" ]; then
      log info "Starting process '$dep'..."
      eval ${COMMAND_MAP[$dep]}
      sleep 1
    else
      log error "Invalid dependency: $dep"
      exit 1
    fi
  done

  if check_process_running "$process_name"; then
    log info "Process '$process_name' is already running"
  else
    log info "Starting ddd process '$process_name'..."
    if [ "${COMMAND_MAP[$process_name]+isset}" ]; then
      eval ${COMMAND_MAP[$process_name]}
    else
      log error "Invalid process: $process_name"
      exit 1
    fi
  fi
}

# 判断参数是否为空
if [ -z "$1" ]; then
  log error "Usage: $0 [all|samgr|huks|deviceauth|softbus|device_manager|dfs|datamgr]"
  exit 1
fi

# 新建日志目录
if [ ! -d "/system/log" ]; then
  log info "/system/log directory not exist, create it"
  sudo mkdir -p /system/log
fi

# 以IP地址生成SN号
if [ ! -e "/etc/SN" ]; then
  log info "SN file not exist, add content to it."
  ipv4_address=$(ip -4 addr show scope global | grep inet | awk '{print $2}' | cut -d '/' -f 1)
  echo "$ipv4_address" | sudo tee /etc/SN > /dev/null
fi

# 软链接动态库
if [ ! -e "/usr/lib64/libsec_shared.z.so" ]; then
  log info "libsec_shared.z.so not exist, create it"
  ln -s /usr/lib64/libboundscheck.so /usr/lib64/libsec_shared.z.so
fi

# 检查 $LD_LIBRARY_PATH 是否包含 "/system/lib64",如果不包含则加入
if [[ ":$LD_LIBRARY_PATH:" != *":/system/lib64:"* ]]; then
  log info "/system/lib64 not in LD_LIBRARY_PATH, add it."
  export LD_LIBRARY_PATH="/system/lib64:$LD_LIBRARY_PATH"
fi

# 检查是否关闭selinux,如果未关闭则关闭
selinux_status=$(getenforce)
if [ "$selinux_status" = "Enforcing" ]; then
    echo "SELinux set to Permissive..."
    sudo setenforce 0
fi

# 如果未开启binder,开启binder
if [ ! -e "/dev/binder" ]; then
  log info "Starting insert binder"
  # 如果当前内核已经自带了binder,则直接进行binder的挂载
  if grep -q '^CONFIG_ANDROID_BINDER_IPC=y$' /boot/config-$(uname -r); then
    mkdir /dev/binderfs
    sudo mount -t binder binder /dev/binderfs
    sudo ln -s /dev/binderfs/binder /dev/binder
  else # 内核没有开启binder,插入相关binder的ko
    if [ ! -f "/lib/modules/$(uname -r)/binder/binder_linux.ko" ]; then
        log error "no binder ko find, please install binder."
        exit 1
    fi
    insmod /lib/modules/$(uname -r)/binder/binder_linux.ko
  fi
fi

cd ${BIN_PATH} || exit
# 如果有进程还在,暂停服务防止双进程存在
if pgrep -x "samgr" > /dev/null; then
  log info "service is running, stop it"
  /system/bin/stop_services.sh all
  sleep 2
fi

# 验证参数并执行相应命令
if [ "$1" == "all" ]; then
  log info "Starting all services..."
  for key in "${start_order[@]}"; do
    log info "Starting $key service..."
    # 执行命令
    eval ${COMMAND_MAP[$key]}
    sleep 1
  done
else
  if [ "${COMMAND_MAP[$1]+isset}" ]; then
    log info "Starting $1 service..."
    # 执行命令
    start_process "$1"
  else
    log error "Invalid parameter: $1"
    exit 1
  fi
fi

log info "Done."