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

(编辑:jimmy 日期: 2025/1/18 浏览:2)

每一个合格的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=$"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=$"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=$"Usage:$0 {start|stop|restart}"
    exit 2
esac
exit $retval  #执行脚本后,有返回值才更专业。

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

一句话新闻
微软与英特尔等合作伙伴联合定义“AI PC”:键盘需配有Copilot物理按键
几个月来,英特尔、微软、AMD和其它厂商都在共同推动“AI PC”的想法,朝着更多的AI功能迈进。在近日,英特尔在台北举行的开发者活动中,也宣布了关于AI PC加速计划、新的PC开发者计划和独立硬件供应商计划。
在此次发布会上,英特尔还发布了全新的全新的酷睿Ultra Meteor Lake NUC开发套件,以及联合微软等合作伙伴联合定义“AI PC”的定义标准。