では早速、コードをお見せしましょう。具体的なコードは次のとおりです。 #!/bin/bash cd `dirname $0` CUR_SHELL_DIR=`pwd` CUR_SHELL_NAME=`ベース名 ${BASH_SOURCE}` #ここで jar パッケージ名を変更します JAR_NAME="xxxxxxxxxxxx.jar" JAR_PATH=$CUR_SHELL_DIR/$JAR_NAME #JAVA_MEM_OPTS=" -server -Xms1024m -Xmx1024m -XX:PermSize=128m" JAVA_MEM_OPTS="" #SPRING_PROFILES_ACTIV="-Dspring.profiles.active=eureka2" SPRING_PROFILES_ACTIV="" LOG_DIR=$CUR_SHELL_DIR/ログ LOG_PATH=$LOG_DIR/${JAR_NAME}.log エコーヘルプ() { echo -e "構文: sh $CUR_SHELL_NAME start|stop" } [ -z $1 ]の場合; エコーヘルプ 出口1 フィ if [ ! -d "$LOG_DIR" ];その後 mkdir "$LOG_DIR" フィ if [ ! -f "$LOG_PATH" ];その後 「$LOG_DIR」をタッチ フィ [ "$1" == "start" ] の場合; # サーバーをチェック PIDS=`ps --no-heading -C java -f --width 1000 | grep $JAR_NAME | awk '{print $2}'` if [ -n "$PIDS" ]; then echo -e "エラー: $JAR_NAME はすでに開始されており、PID は ${PIDS} です。" 出口1 フィ echo "$JAR_NAME を起動しています..." # 始める nohup java $JAVA_MEM_OPTS -jar $SPRING_PROFILES_ACTIV $JAR_PATH >> $LOG_PATH 2>&1 & カウント=0 while [ $COUNT -lt 1 ]; 実行する 睡眠1 COUNT=`ps --no-heading -C java -f --width 1000 | grep "$JAR_NAME" | awk '{print $2}' | wc -l` [ $COUNT -gt 0 ]の場合; 壊す フィ 終わり PIDS=`ps --no-heading -C java -f --width 1000 | grep "$JAR_NAME" | awk '{print $2}'` echo "${JAR_NAME} が起動しました。PID は ${PIDS} です。" echo "詳細については、${LOG_PATH} のログ ファイルを確認してください。" elif [ "$1" == "stop" ];その後 PIDS=`ps --no-heading -C java -f --width 1000 | grep $JAR_NAME | awk '{print $2}'` if [ -z "$PIDS" ]; then echo "エラー: $JAR_NAME が起動していません!" 出口1 フィ echo -e "$JAR_NAME を停止しています..." $PIDSのPIDに対して、 $PID > /dev/null 2>&1 を強制終了します 終わり カウント=0 while [ $COUNT -lt 1 ]; 実行する 睡眠1 カウント=1 $PIDSのPIDに対して; PID_EXIST=`ps --no-heading -p $PID` [ -n "$PID_EXIST" ]の場合; カウント=0 壊す フィ 終わり 終わり echo -e "${JAR_NAME} が停止しました。PID は ${PIDS} です。" それ以外 エコーヘルプ 出口1 フィ 上記のコードは、jarパッケージ名を変更するだけで使用できます。 jar パッケージを起動します。 jarパッケージを停止
要約する 上記は、Linux で SpringBoot jar プログラムを起動および停止して、シェル スクリプトを展開する方法です。皆様のお役に立てれば幸いです。ご質問がある場合は、メッセージを残していただければ、すぐに返信いたします。また、123WORDPRESS.COM ウェブサイトをサポートしてくださっている皆様にも感謝申し上げます。 以下もご興味があるかもしれません:
|
>>: MySQLの指定順序ソートクエリについての簡単な説明
Python 3のインストール1. 依存環境をインストールするPython3 はインストール プロセ...
序文データベース トランザクションに関して言えば、トランザクションの ACID 特性、分離レベル、解...
Docker はますます多くのシナリオで使用されています。コマンドラインツールに慣れていない人にとっ...
この記事では、携帯電話認証コードログインを実装するためのVueの具体的なコードを参考までに共有します...
レプリケーションとは、マスター データベースの DDL および DML 操作をバイナリ ログを介して...
Tomcat のデフォルトのログは java.util.logging を使用しますが、これにはい...
MySQL における Regexp の一般的な使用法特定の文字列を含むあいまい一致# コンテンツフィ...
MySQL を使用する際、フィールドをソートしたりクエリしたりすることがよくあります。通常は、中国語...
解決:リンクのターゲット属性値をターゲット フレームワーク名と同じに設定するだけです。具体的な手順:...
MySQL クエリ キャッシュはデフォルトでオンになっています。ある程度、クエリの効果は向上しますが...
1. 動的パラメータ2.6.0 以降では、角括弧で囲まれた JavaScript 式をディレクティブ...
目次再実行ログディスクデータを直接更新するのではなく、最初にメモリデータを更新する必要があるのはなぜ...
今朝、私は Wampserver を使用してローカルの win7 マシン上に PHP 環境を構築し、...
今日、牛南ニュースリリースシステムについて学んでいたとき、牛南先生はスクロールバーに関するいくつかの...
インターネット上には Linux サーバーを監視するためのツール、コンポーネント、プログラムが多数あ...