シェル スクリプト言語は、すべてのプログラミング言語の中で最も単純な言語であるため、資格のある 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 を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
Web アプリケーションが 1 台のマシンでのみ実行される場合、パフォーマンスを向上させるのは非常に...
目次概要1. 使用状態1.1 3つの概念に関する質問1.2 例1.3 注記2. リデューサーを使用す...
序文ご存知のとおり、HTML5 はインターネット コミュニティ全体に標準を提供する組織である Wor...
この記事では、MySQL テーブル データのインポートおよびエクスポート操作について説明します。ご参...
1. リストリスト ulコンテナーには、一貫した構造とスタイルを持つテキストまたはグラフの形式が読...
この記事では、参考までにMYSQLログとバックアップとリストアについて紹介します。具体的な内容は以下...
この記事では、参考までにMySQL 5.7.17圧縮版のインストール手順を紹介します。具体的な内容は...
目次1. 型2. インスタンス3. コンストラクター4.toString() この記事では、4 つの...
サーバー上にタスク プロセスがあります。 ps -ef | grep task を使用して表示すると...
1. はじめにLinux でファイルの作成時刻が見つかるかどうかは、ファイル システムの種類によって...
目次1. MySQLをダウンロードする2. MySQLをインストールする3. MySQL の基本的な...
目次概要データ URL の使用を開始するデータURL構文複数言語の文字列のBase64エンコードとデ...
[LeetCode] 175.2つのテーブルを結合する表: 人物+-------------+--...
1: mysql公式サイトからダウンロードhttps://dev.mysql.com/downlo...
目次序文webSocket の操作と例について:ウェブソケット1. webSocketについて2. ...