|
|
|
@ -22,6 +22,33 @@ OPENIM_ROOT=$(cd "$(dirname "${BASH_SOURCE[0]}")"/../.. && pwd -P)
|
|
|
|
|
[[ -z ${COMMON_SOURCED} ]] && source ${OPENIM_ROOT}/scripts/install/common.sh
|
|
|
|
|
|
|
|
|
|
SERVER_NAME="openim-rpc"
|
|
|
|
|
readonly OPENIM_RPC_CONFIG=${OPENIM_ROOT}/config
|
|
|
|
|
|
|
|
|
|
openim::rpc::service_name() {
|
|
|
|
|
local targets=(
|
|
|
|
|
openim-rpc-user
|
|
|
|
|
openim-rpc-friend
|
|
|
|
|
openim-rpc-msg
|
|
|
|
|
openim-rpc-group
|
|
|
|
|
openim-rpc-auth
|
|
|
|
|
openim-rpc-conversation
|
|
|
|
|
openim-rpc-third
|
|
|
|
|
)
|
|
|
|
|
echo "${targets[@]}"
|
|
|
|
|
}
|
|
|
|
|
IFS=" " read -ra OPENIM_RPC_SERVICE_TARGETS <<< "$(openim::rpc::service_name)"
|
|
|
|
|
readonly OPENIM_RPC_SERVICE_TARGETS
|
|
|
|
|
readonly OPENIM_RPC_SERVICE_LISTARIES=("${OPENIM_RPC_SERVICE_TARGETS[@]##*/}")
|
|
|
|
|
|
|
|
|
|
readonly OPENIM_API_SERVICE_TARGETS=(
|
|
|
|
|
openim-api
|
|
|
|
|
)
|
|
|
|
|
readonly OPENIM_API_SERVICE_LISTARIES=("${OPENIM_API_SERVICE_TARGETS[@]##*/}")
|
|
|
|
|
|
|
|
|
|
readonly OPENIM_API_PORT_TARGETS=(
|
|
|
|
|
${API_OPENIM_PORT}
|
|
|
|
|
)
|
|
|
|
|
readonly OPENIM_API_PORT_LISTARIES=("${OPENIM_API_PORT_TARGETS[@]##*/}")
|
|
|
|
|
|
|
|
|
|
readonly OPENIM_RPC_ALL_NAME_TARGETS=(
|
|
|
|
|
"${OPENIM_API_SERVICE_TARGETS[@]}"
|
|
|
|
@ -78,6 +105,10 @@ readonly OPENIM_RPC_ALL_PROM_PORT_TARGETS=(
|
|
|
|
|
)
|
|
|
|
|
readonly OPENIM_RPC_ALL_PROM_PORT_LISTARIES=("${OPENIM_RPC_ALL_PROM_PORT_TARGETS[@]##*/}")
|
|
|
|
|
|
|
|
|
|
echo "OPENIM_RPC_ALL_NAME_TARGETS: ${OPENIM_RPC_ALL_NAME_TARGETS[@]}"
|
|
|
|
|
echo "OPENIM_RPC_ALL_PROM_PORT_TARGETS: ${OPENIM_RPC_ALL_PROM_PORT_TARGETS[@]}"
|
|
|
|
|
echo "OPENIM_RPC_ALL_PORT_TARGETS: ${OPENIM_RPC_ALL_PORT_TARGETS[@]}"
|
|
|
|
|
|
|
|
|
|
openim::log::info "Starting ${SERVER_NAME} ..."
|
|
|
|
|
|
|
|
|
|
printf "+------------------------+-------+-----------------+\n"
|
|
|
|
@ -91,121 +122,78 @@ for ((i=0; i<$length; i++)); do
|
|
|
|
|
printf "+------------------------+-------+-----------------+\n"
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
# #service filename
|
|
|
|
|
# service_filename=(
|
|
|
|
|
# #api
|
|
|
|
|
# openim-api
|
|
|
|
|
# #rpc
|
|
|
|
|
# openim-rpc-user
|
|
|
|
|
# openim-rpc-friend
|
|
|
|
|
# openim-rpc-msg
|
|
|
|
|
# openim-rpc-group
|
|
|
|
|
# openim-rpc-auth
|
|
|
|
|
# openim-rpc-conversation
|
|
|
|
|
# openim-rpc-third
|
|
|
|
|
# )
|
|
|
|
|
|
|
|
|
|
# #service config port name
|
|
|
|
|
# service_port_name=(
|
|
|
|
|
# #api port name
|
|
|
|
|
# openImApiPort
|
|
|
|
|
# #rpc port name
|
|
|
|
|
|
|
|
|
|
# openImUserPort 10110
|
|
|
|
|
# openImFriendPort 10120
|
|
|
|
|
# openImMessagePort 10130
|
|
|
|
|
# openImGroupPort 10150
|
|
|
|
|
# openImAuthPort 10160
|
|
|
|
|
# openImConversationPort 10180
|
|
|
|
|
# openImThirdPort 10190
|
|
|
|
|
# )
|
|
|
|
|
|
|
|
|
|
# service_prometheus_port_name=(
|
|
|
|
|
# #api port name
|
|
|
|
|
# openImApiPort //${API_OPENIM_PORT}
|
|
|
|
|
# #rpc port name
|
|
|
|
|
# userPrometheusPort
|
|
|
|
|
# friendPrometheusPort
|
|
|
|
|
# groupPrometheusPort
|
|
|
|
|
# authPrometheusPort
|
|
|
|
|
# messagePrometheusPort
|
|
|
|
|
# conversationPrometheusPort
|
|
|
|
|
# thirdPrometheusPort
|
|
|
|
|
# )
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# This function starts a service based on the provided filename, port, and optional Prometheus port.
|
|
|
|
|
start_service() {
|
|
|
|
|
local cmd="./$1 --port $2 -c ${configfile_path}"
|
|
|
|
|
if [ -n "$3" ]; then
|
|
|
|
|
cmd="${cmd} --prometheus_port $3"
|
|
|
|
|
fi
|
|
|
|
|
echo "=====================start $1======================" >>$OPENIM_ROOT/logs/openIM.log
|
|
|
|
|
nohup $cmd >>$OPENIM_ROOT/logs/openIM.log 2>&1 &
|
|
|
|
|
sleep 1
|
|
|
|
|
local pid="netstat -ntlp|grep $2 |awk '{printf \$7}'|cut -d/ -f1"
|
|
|
|
|
echo -e "${GREEN_PREFIX}$1 start success, port number:$2 pid:$(eval $pid)$COLOR_SUFFIX"
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
cd $OPENIM_ROOT
|
|
|
|
|
cd $BIN_DIR
|
|
|
|
|
function openim::rpc::start_service() {
|
|
|
|
|
local binary_name="$1"
|
|
|
|
|
local service_port="$2"
|
|
|
|
|
local prometheus_port="$3"
|
|
|
|
|
|
|
|
|
|
echo "xxxxxxxxxxxxxxxxxxxxxxxx ${#OPENIM_RPC_ALL_NAME_TARGETS[*]}"
|
|
|
|
|
local cmd="${OPENIM_OUTPUT_HOSTBIN}/${binary_name} --port ${service_port} -c ${OPENIM_RPC_CONFIG}"
|
|
|
|
|
|
|
|
|
|
openim::util::stop_services_with_name ${#OPENIM_RPC_ALL_NAME_TARGETS[*]}
|
|
|
|
|
if [ -n "${prometheus_port}" ]; then
|
|
|
|
|
printf "Specifying prometheus port: %s\n" "${prometheus_port}"
|
|
|
|
|
cmd="${cmd} --prometheus_port ${prometheus_port}"
|
|
|
|
|
fi
|
|
|
|
|
nohup ${cmd} >> "${LOG_FILE}" 2>&1 &
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# Assuming OPENIM_RPC_ALL_NAME_TARGETS and other variables have been defined from the previous refactor.
|
|
|
|
|
# start all rpc services
|
|
|
|
|
for ((i = 0; i < ${#OPENIM_RPC_ALL_NAME_TARGETS[*]}; i++)); do
|
|
|
|
|
openim::util::stop_services_with_name "${OPENIM_RPC_ALL_NAME_TARGETS[$i]}"
|
|
|
|
|
openim::util::stop_services_with_name ${OPENIM_RPC_ALL_NAME_TARGETS[$i]}
|
|
|
|
|
openim::log::info "OpenIM ${OPENIM_RPC_ALL_NAME_TARGETS[$i]} config path: ${OPENIM_RPC_CONFIG}"
|
|
|
|
|
|
|
|
|
|
# Get the service and Prometheus ports.
|
|
|
|
|
service_ports=($(cat $config_path | grep ${OPENIM_RPC_ALL_PORT_TARGETS[$i]} | awk -F '[:]' '{print $NF}'))
|
|
|
|
|
prome_ports=($(cat $config_path | grep ${OPENIM_RPC_ALL_PROM_PORT_TARGETS[$i]} | awk -F '[:]' '{print $NF}'))
|
|
|
|
|
OPENIM_RPC_SERVICE_PORTS=( $(openim::util::list-to-string ${OPENIM_RPC_ALL_PORT_LISTARIES[$i]}) )
|
|
|
|
|
OPENIM_RPC_PROM_PORTS=( $(openim::util::list-to-string ${OPENIM_RPC_ALL_PROM_PORT_LISTARIES[$i]}) )
|
|
|
|
|
|
|
|
|
|
for ((j = 0; j < ${#service_ports[*]}; j++)); do
|
|
|
|
|
start_service "${OPENIM_RPC_ALL_NAME_TARGETS[$i]}" "${service_ports[$j]}" "${prome_ports[$j]}"
|
|
|
|
|
for ((j = 0; j < ${#OPENIM_RPC_SERVICE_PORTS[@]}; j++)); do
|
|
|
|
|
openim::log::info "Starting ${OPENIM_RPC_ALL_NAME_TARGETS[$i]} service, port: ${OPENIM_RPC_SERVICE_PORTS[j]}, prometheus port: ${OPENIM_RPC_PROM_PORTS[j]}, binary root: ${OPENIM_OUTPUT_HOSTBIN}/${OPENIM_RPC_ALL_NAME_TARGETS[$i]}"
|
|
|
|
|
openim::rpc::start_service "${OPENIM_RPC_ALL_NAME_TARGETS[$i]}" "${OPENIM_RPC_SERVICE_PORTS[j]}" "${OPENIM_RPC_PROM_PORTS[j]}"
|
|
|
|
|
done
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
openim::util::check_ports ${OPENIM_RPC_ALL_PORT_TARGETS[@]}
|
|
|
|
|
openim::util::check_ports ${OPENIM_RPC_ALL_PROM_PORT_TARGETS[@]}
|
|
|
|
|
|
|
|
|
|
# ---
|
|
|
|
|
for ((i = 0; i < ${#service_filename[*]}; i++)); do
|
|
|
|
|
#Check whether the service exists
|
|
|
|
|
service_name="ps |grep -w ${service_filename[$i]} |grep -v grep"
|
|
|
|
|
count="${service_name}| wc -l"
|
|
|
|
|
|
|
|
|
|
if [ $(eval ${count}) -gt 0 ]; then
|
|
|
|
|
pid="${service_name}| awk '{print \$2}'"
|
|
|
|
|
echo "${service_filename[$i]} service has been started,pid:$(eval $pid)"
|
|
|
|
|
echo "killing the service ${service_filename[$i]} pid:$(eval $pid)"
|
|
|
|
|
#kill the service that existed
|
|
|
|
|
kill -9 $(eval $pid)
|
|
|
|
|
sleep 0.5
|
|
|
|
|
fi
|
|
|
|
|
cd $OPENIM_ROOT
|
|
|
|
|
cd $BIN_DIR
|
|
|
|
|
# Get the rpc port in the configuration file
|
|
|
|
|
portList=$(cat $config_path | grep ${service_port_name[$i]} | awk -F '[:]' '{print $NF}')
|
|
|
|
|
openim::util::list-to-string ${portList}
|
|
|
|
|
service_ports=($ports_array)
|
|
|
|
|
|
|
|
|
|
portList2=$(cat $config_path | grep ${service_prometheus_port_name[$i]} | awk -F '[:]' '{print $NF}')
|
|
|
|
|
openim::util::list-to-string $portList2
|
|
|
|
|
prome_ports=($ports_array)
|
|
|
|
|
#Start related rpc services based on the number of ports
|
|
|
|
|
for ((j = 0; j < ${#service_ports[*]}; j++)); do
|
|
|
|
|
#Start the service in the background
|
|
|
|
|
if [ -z "${prome_ports[$j]}" ]; then
|
|
|
|
|
cmd="./${service_filename[$i]} --port ${service_ports[$j]} -c ${configfile_path} "
|
|
|
|
|
else
|
|
|
|
|
cmd="./${service_filename[$i]} --port ${service_ports[$j]} --prometheus_port ${prome_ports[$j]} -c ${configfile_path} "
|
|
|
|
|
fi
|
|
|
|
|
if [ $i -eq 0 -o $i -eq 1 ]; then
|
|
|
|
|
cmd="./${service_filename[$i]} --port ${service_ports[$j]}"
|
|
|
|
|
fi
|
|
|
|
|
echo "=====================start ${service_filename[$i]}======================">>$OPENIM_ROOT/logs/openIM.log
|
|
|
|
|
nohup $cmd >>$OPENIM_ROOT/logs/openIM.log 2>&1 &
|
|
|
|
|
sleep 1
|
|
|
|
|
pid="netstat -ntlp|grep $j |awk '{printf \$7}'|cut -d/ -f1"
|
|
|
|
|
echo -e "${GREEN_PREFIX}${service_filename[$i]} start success,port number:${service_ports[$j]} pid:$(eval $pid)$COLOR_SUFFIX"
|
|
|
|
|
done
|
|
|
|
|
done
|
|
|
|
|
# for ((i = 0; i < ${#service_filename[*]}; i++)); do
|
|
|
|
|
# #Check whether the service exists
|
|
|
|
|
# service_name="ps |grep -w ${service_filename[$i]} |grep -v grep"
|
|
|
|
|
# count="${service_name}| wc -l"
|
|
|
|
|
|
|
|
|
|
# if [ $(eval ${count}) -gt 0 ]; then
|
|
|
|
|
# pid="${service_name}| awk '{print \$2}'"
|
|
|
|
|
# echo "${service_filename[$i]} service has been started,pid:$(eval $pid)"
|
|
|
|
|
# echo "killing the service ${service_filename[$i]} pid:$(eval $pid)"
|
|
|
|
|
# #kill the service that existed
|
|
|
|
|
# kill -9 $(eval $pid)
|
|
|
|
|
# sleep 0.5
|
|
|
|
|
# fi
|
|
|
|
|
# cd $OPENIM_ROOT
|
|
|
|
|
# cd $BIN_DIR
|
|
|
|
|
# # Get the rpc port in the configuration file
|
|
|
|
|
# portList=$(cat $config_path | grep ${service_port_name[$i]} | awk -F '[:]' '{print $NF}')
|
|
|
|
|
# openim::util::list-to-string ${portList}
|
|
|
|
|
# service_ports=($ports_array)
|
|
|
|
|
|
|
|
|
|
# portList2=$(cat $config_path | grep ${service_prometheus_port_name[$i]} | awk -F '[:]' '{print $NF}')
|
|
|
|
|
# openim::util::list-to-string $portList2
|
|
|
|
|
# prome_ports=($ports_array)
|
|
|
|
|
# #Start related rpc services based on the number of ports
|
|
|
|
|
# for ((j = 0; j < ${#service_ports[*]}; j++)); do
|
|
|
|
|
# #Start the service in the background
|
|
|
|
|
# if [ -z "${prome_ports[$j]}" ]; then
|
|
|
|
|
# cmd="./${service_filename[$i]} --port ${service_ports[$j]} -c ${configfile_path} "
|
|
|
|
|
# else
|
|
|
|
|
# cmd="./${service_filename[$i]} --port ${service_ports[$j]} --prometheus_port ${prome_ports[$j]} -c ${configfile_path} "
|
|
|
|
|
# fi
|
|
|
|
|
# if [ $i -eq 0 -o $i -eq 1 ]; then
|
|
|
|
|
# cmd="./${service_filename[$i]} --port ${service_ports[$j]}"
|
|
|
|
|
# fi
|
|
|
|
|
# echo "=====================start ${service_filename[$i]}======================">>$OPENIM_ROOT/logs/openIM.log
|
|
|
|
|
# nohup $cmd >>$OPENIM_ROOT/logs/openIM.log 2>&1 &
|
|
|
|
|
# sleep 1
|
|
|
|
|
# pid="netstat -ntlp|grep $j |awk '{printf \$7}'|cut -d/ -f1"
|
|
|
|
|
# echo -e "${GREEN_PREFIX}${service_filename[$i]} start success,port number:${service_ports[$j]} pid:$(eval $pid)$COLOR_SUFFIX"
|
|
|
|
|
# done
|
|
|
|
|
# done
|
|
|
|
|