Files
open-im-server/script/msg_gateway_start.sh
T

54 lines
2.1 KiB
Bash
Raw Normal View History

2021-05-26 18:58:28 +08:00
#!/usr/bin/env bash
#Include shell font styles and some basic information
source ./style_info.cfg
source ./path_info.cfg
source ./function.sh
2022-03-01 15:32:47 +08:00
ulimit -n 200000
2022-04-24 17:54:02 +08:00
list1=$(cat $config_path | grep openImMessageGatewayPort | awk -F '[:]' '{print $NF}')
2021-10-08 17:50:09 +08:00
list2=$(cat $config_path | grep openImWsPort | awk -F '[:]' '{print $NF}')
2022-09-12 19:32:24 +08:00
list3=$(cat $config_path | grep messageGatewayPrometheusPort | awk -F '[:]' '{print $NF}')
2021-05-26 18:58:28 +08:00
list_to_string $list1
rpc_ports=($ports_array)
list_to_string $list2
ws_ports=($ports_array)
2022-09-12 19:32:24 +08:00
list_to_string $list3
prome_ports=($ports_array)
2022-09-12 19:56:15 +08:00
if [ ${#rpc_ports[@]} -ne ${#ws_ports[@]} ]; then
2021-05-26 18:58:28 +08:00
2022-09-12 19:32:24 +08:00
echo -e ${RED_PREFIX}"ws_ports does not match push_rpc_ports or prome_ports in quantity!!!"${COLOR_SUFFIX}
2022-04-06 11:47:01 +08:00
exit -1
2021-05-26 18:58:28 +08:00
fi
#Check if the service exists
#If it is exists,kill this process
check=$(ps aux | grep -w ./${msg_gateway_name} | grep -v grep | wc -l)
if [ $check -ge 1 ]; then
oldPid=$(ps aux | grep -w ./${msg_gateway_name} | grep -v grep | awk '{print $2}')
2021-09-13 15:48:19 +08:00
kill -9 ${oldPid}
2021-05-26 18:58:28 +08:00
fi
#Waiting port recycling
2021-09-13 21:25:06 +08:00
sleep 1
2021-05-26 18:58:28 +08:00
cd ${msg_gateway_binary_root}
for ((i = 0; i < ${#ws_ports[@]}; i++)); do
2022-09-12 19:32:24 +08:00
nohup ./${msg_gateway_name} -rpc_port ${rpc_ports[$i]} -ws_port ${ws_ports[$i]} -prometheus_port ${prome_ports[$i]} >>../logs/openIM.log 2>&1 &
2021-05-26 18:58:28 +08:00
done
#Check launched service process
2021-09-13 21:25:06 +08:00
sleep 3
2021-05-26 18:58:28 +08:00
check=$(ps aux | grep -w ./${msg_gateway_name} | grep -v grep | wc -l)
allPorts=""
if [ $check -ge 1 ]; then
allNewPid=$(ps aux | grep -w ./${msg_gateway_name} | grep -v grep | awk '{print $2}')
for i in $allNewPid; do
2021-09-13 15:48:19 +08:00
ports=$(netstat -netulp | grep -w ${i} | awk '{print $4}' | awk -F '[:]' '{print $NF}')
allPorts=${allPorts}"$ports "
2021-05-26 18:58:28 +08:00
done
2021-10-08 17:50:09 +08:00
echo -e ${SKY_BLUE_PREFIX}"SERVICE START SUCCESS"${COLOR_SUFFIX}
2021-05-26 18:58:28 +08:00
echo -e ${SKY_BLUE_PREFIX}"SERVICE_NAME: "${COLOR_SUFFIX}${YELLOW_PREFIX}${msg_gateway_name}${COLOR_SUFFIX}
echo -e ${SKY_BLUE_PREFIX}"PID: "${COLOR_SUFFIX}${YELLOW_PREFIX}${allNewPid}${COLOR_SUFFIX}
echo -e ${SKY_BLUE_PREFIX}"LISTENING_PORT: "${COLOR_SUFFIX}${YELLOW_PREFIX}${allPorts}${COLOR_SUFFIX}
else
2021-10-26 12:02:07 +08:00
echo -e ${YELLOW_PREFIX}${msg_gateway_name}${COLOR_SUFFIX}${RED_PREFIX}"SERVICE START ERROR, PLEASE CHECK openIM.log"${COLOR_SUFFIX}
2021-05-26 18:58:28 +08:00
fi