老鸟带你开发专业规范的MySQL启动脚本

2022-05-22 0 538

每一个合格的Linux运维人员都应该做到熟练或精通Shell脚本编程,因为Shell脚本语言差不多是所有编程语言里最简单的语言,如果Shell脚本不行,意味着运维之路可能还没开始就将要终结。——老男孩老师

#!/bin/bash
# chkconfig: 2345 64 36 #配置系统自启动
# description: A very fast and reliable SQL database engine.
##############################################################
# File Name: mysqld
# Version: V1.0
# Author: oldboy
# Organization: www.oldboyedu.com
# Created Time : 2018-06-05 08:58:19
##############################################################
#引入系统函数库
. /etc/init.d/functions

#基础路径定义
basedir='/application/mysql'
bindir='/application/mysql/bin'
lockdir='/var/lock/subsys'                    
lock_file_path="$lockdir/mysql"
mysqld_pid_file_path='$basedir/data/`uname -n`.pid'

#成功提示函数
log_success_msg(){
  #action为特殊的提示函数,$@为所有参数。
  action "SUCCESS! $@" /bin/true
}
#失败提示函数
log_failure_msg(){
  action "ERROR! $@" /bin/false
 }
 
#mysql启动函数
start(){
  echo $"Starting MySQL"
  #测试mysqld_safe是否可执行
  if test -x $bindir/mysqld_safe
  then
    #后台执行启动mysql命令
    $bindir/mysqld_safe &>/dev/null &
    #获取返回值
    retval=$?
    #判断返回值是否为0
    if [ $retval -eq 0 ]
    then
      #调用成功提示函数。
      log_success_msg "mysql Startup"
      if test -w "$lockdir" #判断锁目录是否可写。
      then
        touch "$lock_file_path" #创建锁文件。
      fi
      return $retval #给返回值是专业的表现。
    else
      log_failure_msg "MySQL Startup" #调用失败函数提示。
      return $retval
    fi
  else
    log_failure_msg "Couldn't find MySQL server ($bindir/mysqld_safe)"
  fi
}
#停止MySQL函数。
stop(){
  #判断mysql pid file大小是否为0。
  if test -s "$mysqld_pid_file_path"
  then
    #读取pidfile
    mysqld_pid=`cat "$mysqld_pid_file_path"`
    #判断mysql pid对应的进程是否存在。
    if (kill -0 $mysqld_pid 2>/dev/null)
    then
      echo $"Shutting down MySQL"
      kill $mysqld_pid #停止MySQL命令。
      retval=$?
      if [ $retval -eq 0 ]
      then
        log_success_msg "MySQL Stop" #调用停止成功函数。
        if test -f "$lock_file_path"
        then
          rm -f "$lock_file_path" #删除锁文件。
        fi
        return $retval
      else
        log_failure_msg "MySQL Stop."
        return $retval
      fi
    else
      log_failure_msg "MySQL server process mysqld_pid is not running!"
      rm "$mysqld_pid_file_path"
    fi 
  else
    log_failure_msg "MySQL server PID file is null or not exist!"
  fi
}
#接收传参判断并执行相应函数。
case "$1" in
  start)
    start
    retval=$?
    ;;
  stop)
    stop
    retval=$?
    ;;
  restart)
    stop
    sleep 2 #这里很重要,要休息一下。
    start
    retval=$?
    ;;
  *)
    echo $"Usage:$0 {start|stop|restart}"
    exit 2
esac
exit $retval  #执行脚本后,有返回值才更专业。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持NICE源码。

免责声明:
1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

NICE源码网 MySql 老鸟带你开发专业规范的MySQL启动脚本 https://www.niceym.com/44161.html