wait_for_process.sh

来自「视频监控网络部分的协议ddns,的模块的实现代码,请大家大胆指正.」· Shell 代码 · 共 115 行

SH
115
字号
#!/bin/sh############################################################################ NOTE: this script returns 0 (success) even in case of failure (except for# usage-error). This is because this script is executed under# mysql-test-run[.pl] and it's better to examine particular problem in log# file, than just having said that the test case has failed.###########################################################################basename=`basename "$0"`dirname=`dirname "$0"`###########################################################################. "$dirname/utils.sh"###########################################################################check_started(){  if [ ! -r "$pid_path" ]; then    log_debug "No PID-file ($pid_path) found -- not started."    return 1  fi  new_pid=`cat "$pid_path" 2>/dev/null`  err_code=$?  log_debug "err_code: $err_code; new_pid: $new_pid."  if [ $? -ne 0 -o -z "$new_pid" ]; then    log_debug "The process was not started."    return 1  fi  log_debug "The process was started."  return 0}###########################################################################check_stopped(){  if [ -r "$pid_path" ]; then    log_debug "PID-file '$pid_path' exists -- not stopped."    return 1  fi  log_debug "No PID-file ($pid_path) found -- stopped."  return 0}###########################################################################if [ $# -ne 4 ]; then  echo "Usage: $basename <pid file path> <total attempts> started|stopped <test id>"  exit 1fipid_path="$1"total_attempts="$2"event="$3"test_id="$4"log_file="$MYSQLTEST_VARDIR/log/$test_id.script.log"log_debug "-- $basename: starting --"log_debug "pid_path: '$pid_path'"log_debug "total_attempts: '$total_attempts'"log_debug "event: '$event'"log_debug "test_id: '$test_id'"log_debug "log_file: '$log_file'"###########################################################################case "$event" in  started)    check_fn='check_started';    ;;  stopped)    check_fn='check_stopped';    ;;  *)    log_error "Invalid third argument ('started' or 'stopped' expected)."    quit 0esac###########################################################################cur_attempt=1while true; do  log_debug "cur_attempt: $cur_attempt."  if ( eval $check_fn ); then    log_info "Success: the process has been $event."    quit 0  fi  [ $cur_attempt -ge $total_attempts ] && break  log_debug "Sleeping for 1 second..."  sleep 1  cur_attempt=`expr $cur_attempt + 1`donelog_error "The process has not been $event in $total_attempts secs."quit 0

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?