経験豊富な人が、プロフェッショナルで標準化されたMySQL起動スクリプトの開発方法を紹介します。

経験豊富な人が、プロフェッショナルで標準化されたMySQL起動スクリプトの開発方法を紹介します。

シェル スクリプト言語は、すべてのプログラミング言語の中で最も単純な言語であるため、資格のある Linux 運用および保守担当者は、シェル スクリプト プログラミングに精通している必要があります。シェル スクリプトが優れていなければ、運用および保守の道は始まる前に終わってしまう可能性があります。 ——老人教師

#!/bin/bash
# chkconfig: 2345 64 36 #システムの自動起動を構成する# 説明: 非常に高速で信頼性の高い SQL データベース エンジン。
##############################################################
# ファイル名: mysqld
# バージョン: V1.0
# 著者: oldboy
# 組織: www.oldboyedu.com
# 作成日時 : 2018-06-05 08:58:19
##############################################################
#システム関数ライブラリを導入します。/etc/init.d/functions

#基本パス定義 basedir='/application/mysql'
バインドディレクトリ='/application/mysql/bin'
ロックディレクトリ='/var/lock/subsys'                    
lock_file_path="$lockdir/mysql"
mysqld_pid_file_path='$basedir/data/`uname -n`.pid'

#成功プロンプト関数 log_success_msg(){
  #action は特別なプロンプト関数、$@ はすべてのパラメーターです。
  アクション "成功!$@" /bin/true
}
#失敗プロンプト関数 log_failure_msg(){
  アクション "ERROR! $@" /bin/false
 }
 
#mysql 開始関数 start(){
  echo $"MySQL を起動しています"
  #mysqld_safeが実行可能かどうかをテストする if test -x $bindir/mysqld_safe
  それから
    #バックグラウンド実行でmysqlコマンド$bindir/mysqld_safe &>/dev/null &が開始されます
    #戻り値を取得します retval=$?
    # 戻り値が0かどうか確認する
    [ $retval -eq 0 ]の場合
    それから
      #成功プロンプト関数を呼び出します。
      log_success_msg "mysql 起動"
      if test -w "$lockdir" #ロックディレクトリが書き込み可能かどうかを判断します。
      それから
        touch "$lock_file_path" #ロックファイルを作成します。
      フィ
      return $retval #戻り値を返すのはプロフェッショナルな行為です。
    それ以外
      log_failure_msg "MySQL 起動" #関数呼び出しが失敗したことを通知します。
      $retvalを返す
    フィ
  それ以外
    log_failure_msg "MySQL サーバーが見つかりませんでした ($bindir/mysqld_safe)"
  フィ
}
#MySQL 機能を停止します。
停止(){
  #mysql pid ファイルのサイズが 0 かどうかを判断します。
  テスト -s "$mysqld_pid_file_path" の場合
  それから
    #pidfile を読み込む
    mysqld_pid=`cat "$mysqld_pid_file_path"`
    #mysql pidに対応するプロセスが存在するかどうかを判断します。
    (kill -0 $mysqld_pid 2>/dev/null)の場合
    それから
      echo $"MySQL をシャットダウンしています"
      kill $mysqld_pid #MySQL コマンドを停止します。
      戻り値=$?
      [ $retval -eq 0 ]の場合
      それから
        log_success_msg "MySQL Stop" #停止成功関数を呼び出します。
        テスト -f "$lock_file_path"
        それから
          rm -f "$lock_file_path" #ロックファイルを削除します。
        フィ
        $retvalを返す
      それ以外
        log_failure_msg「MySQL 停止。」
        $retvalを返す
      フィ
    それ以外
      log_failure_msg "MySQL サーバー プロセス mysqld_pid が実行されていません!"
      rm "$mysqld_pid_file_path"
    フィ 
  それ以外
    log_failure_msg "MySQL サーバーの PID ファイルが null か、存在しません!"
  フィ
}
#渡されたパラメータを受け取り、対応する関数を実行します。
ケース「$1」
  始める)
    始める
    戻り値=$?
    ;;
  停止)
    停止
    戻り値=$?
    ;;
  再起動)
    停止
    睡眠2 #これはとても重要です。休憩してください。
    始める
    戻り値=$?
    ;;
  *)
    echo $"使用法:$0 {start|stop|restart}"
    出口2
エサック
exit $retval #スクリプトを実行した後、戻り値を持つ方がプロフェッショナルです。

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • MySQL 使用仕様の概要
  • 超詳細なMySQL使用仕様の共有
  • MySQLデータベースの使用仕様の概要
  • MySQL開発標準と使用スキルの概要
  • MySQL データベース開発仕様 [推奨]
  • MySQL データベースの命名標準と規則
  • Mysql テーブル作成とインデックス使用仕様の詳細な説明
  • MYSQL データベースの命名と設計仕様
  • プロフェッショナルなMySQL開発設計仕様とSQL記述仕様

<<:  jQueryはネストされたタブ機能を実装します

>>:  Linuxの相対パスと絶対パスの使用

推薦する

Nginx のパフォーマンスを向上させるための提案

Web アプリケーションが 1 台のマシンでのみ実行される場合、パフォーマンスを向上させるのは非常に...

30分でReact Hooksを包括的に理解できます

目次概要1. 使用状態1.1 3つの概念に関する質問1.2 例1.3 注記2. リデューサーを使用す...

HTML 5.1 学習: 14 の新機能とアプリケーション例

序文ご存知のとおり、HTML5 はインターネット コミュニティ全体に標準を提供する組織である Wor...

MySQL テーブルデータのインポートとエクスポートの例

この記事では、MySQL テーブル データのインポートおよびエクスポート操作について説明します。ご参...

HTMLの基礎を詳しく解説(第2部)

1. リストリスト ulコンテナーには、一貫した構造とスタイルを持つテキストまたはグラフの形式が読...

MYSQL ログとバックアップおよび復元の問題の詳細な説明

この記事では、参考までにMYSQLログとバックアップとリストアについて紹介します。具体的な内容は以下...

MySQL 5.7.17 圧縮バージョンのインストールノート

この記事では、参考までにMySQL 5.7.17圧縮版のインストール手順を紹介します。具体的な内容は...

JSにおける4つのデータ型判定方法

目次1. 型2. インスタンス3. コンストラクター4.toString() この記事では、4 つの...

プロセスのすべての情報を表示するLinuxメソッドの例

サーバー上にタスク プロセスがあります。 ps -ef | grep task を使用して表示すると...

Linuxでファイルの作成時間を表示する方法

1. はじめにLinux でファイルの作成時刻が見つかるかどうかは、ファイル システムの種類によって...

Windows での MySQL の詳細なインストール手順と基本的な使用方法

目次1. MySQLをダウンロードする2. MySQLをインストールする3. MySQL の基本的な...

JS はデータ URL をどのように理解するのでしょうか?

目次概要データ URL の使用を開始するデータURL構文複数言語の文字列のBase64エンコードとデ...

LeetCode の SQL 実装 (175. 2 つのテーブルの結合)

[LeetCode] 175.2つのテーブルを結合する表: 人物+-------------+--...

MySQL 8.0.20 インストール チュートリアル (画像とテキスト付き) (Windows 64 ビット)

1: mysql公式サイトからダウンロードhttps://dev.mysql.com/downlo...

Vue で webSocket を使用してリアルタイムの天気を更新する方法

目次序文webSocket の操作と例について:ウェブソケット1. webSocketについて2. ...