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

推薦する

Docker で Java 8 Spring Boot アプリケーションを開発する方法

この記事では、ローカル マシンに Java 8 をインストールせずに、Java 8 を使用して簡単な...

MySQL EXPLAIN ステートメントの使用例

目次1. 使用方法2. 出力結果1.id 2.選択タイプ3.表4.パーティション5.タイプ6.可能な...

Linuxで静的ネットワーク接続を構成する方法

Linux システムのネットワーク接続を構成するのは難しい場合があります。幸いなことに、多くの新しい...

Nginxホットデプロイメントの実装

目次セマフォNginx ホットデプロイメント上記のブログ投稿に従ってください。ファイアウォールをオフ...

CentOS7 インストール GUI インターフェースとリモート接続の実装

ブラウザ (Web ドライバー) ベースの Selenium テクノロジを使用してデータをクロールす...

vuexサードパーティパッケージを使用してデータの永続性を実装する方法

目的: vuex で管理されている状態データを同時にローカルに保存できるようにします。独自のストレー...

nginx ロードバランシングを介して https にリダイレクトする方法

ウェブ上で証明書とキーをコピーするscp -rp -P52113 /application/ngin...

JSは賞金の重さに基づいて当選確率を計算します

目次1. シナリオ例1.1. 抽選の賞品名を設定する1.2. 各賞の重みを設定する1.3. ラッキー...

HTML のインラインブロックの空白を素早く削除する 5 つの方法

inline-block プロパティ値は、「インライン」要素のマージンとパディングを制御する必要があ...

Nginxはドメイン名のアクセス方法を定義しています

最近Nginxを構築しているのですが、ドメイン名でアクセスできません。 nginx 構成ファイル n...

MySQL、Oracle、SQL Server のページングクエリ例の分析

最近、Oracle、MySQL、SQL Server 2005 のデータ ページング クエリについて...

InnoDB のアーキテクチャと機能の詳細な説明 (InnoDB ストレージ エンジンの読書メモの要約)

背景スレッド•マスタースレッドコア バックグラウンド スレッドは主に、バッファー プール データをデ...

知っておくべき JS 配列削減の高度な使い方 25 選

序文Reduce は ES5 で追加された新しい従来の配列メソッドの 1 つです。forEach、f...

Dockerを使用してOracle_11gをインストールする方法

DockerでOracle_11gをインストールする1. oracle_11gイメージを取得する d...

MySQL マスタースレーブ同期の原理と応用

目次1. マスタースレーブ同期原理マスタースレーブ同期アーキテクチャ図(非同期同期)マスタースレーブ...