経験豊富な人が、プロフェッショナルで標準化された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の相対パスと絶対パスの使用

推薦する

MySQL の最適化: サブクエリの代わりに結合を使用する

サブクエリの代わりにJOINを使用するMySQL はバージョン 4.1 以降で SQL サブクエリを...

JavaScript の isPrototypeOf 関数

目次1. isPrototypeOf()例 1、オブジェクト クラス インスタンス:例 2: Hum...

Ubuntuが仮想マシンでインターネットに接続できない問題の解決策

インターネットに接続できない仮想マシンをセットアップするのは非常に面倒です。ここでは、Ubuntu ...

vue keepAlive キャッシュクリア問題事例の詳細な説明

Keepalive は Vue プロジェクトでのキャッシュによく使用され、基本的な要件を満たすのに非...

MySQLテーブルを削除する方法

MySQL でテーブルを削除するのは非常に簡単ですが、削除コマンドを実行するとすべてのデータが消えて...

Vue ページレンダリングにおけるキーの適用例チュートリアル

導入フロントエンドプロジェクトの開発プロセスでは、el-table によって表示される結果列がコンポ...

画像とテキストでHTTPヘッダーのあらゆる側面を理解する

HTTPヘッダーとはHTTP は「Hypertext Transfer Protocol」の略です。...

MySQL でファイルデータをインポートする際の 1290 エラーの解決方法

エラーシナリオcmd の mysql コマンドを使用して、学生情報テーブルにデータを追加します。デー...

あなたのウェブサイトはIE8に適していますか?

オリンピック期間中にIE8ベータ2がリリースされ、英語版のリリースに合わせて中国語版も第一波でリリー...

MySQLトリガーの使用

目次1. トリガーの紹介1. トリガーとは何ですか? 2. トリガーの特徴2. トリガーを作成する1...

thead、tfoot、tbodyを使用して表を作成します

これらの 3 つのタグを間違った方法で使用して、タイトルを表に沿わせたり、tbody の高さを固定し...

HTML ファイルにフラッシュ ビデオ形式 (flv、swf) ファイルを埋め込む方法

Flash ファイル形式: .FLV および .SWFフラッシュ ビデオ形式には、.flv と .s...

Node.jsがES6モジュールを処理する方法の詳細な説明

目次1. 2つのモジュールの違い2. Node.jsとの違い3. CommonJSモジュールの読み込...

Mysql GTID Mha 設定方法

Gtid + Mha + Binlog サーバー構成: 1: テスト環境OS: CentOS 6.5...

Linux での MySQL の文字化け問題の解決方法

プロジェクトはサーバーと対話し、post を通じてサーバー側の jsp にアクセスし、jsp はサー...