質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
シェルスクリプト

シェルスクリプトは、UNIX系のOSもしくはコマンドラインインタプリタ向けに記述されたスクリプト。bash/zshといったシェルによって実行されるため、このように呼ばれています。バッチ処理などに使用されており、テキストファイルに書かれた命令を順に実行します。

Webサーバー

Webサーバーとは、HTTPリクエストに応じて、クライアントに情報を提供するシステムです。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

シェル

シェル(shell)はUnix や Linux 系のOSで使用されるコマンドインタプリタを指します。

Q&A

解決済

4回答

6589閲覧

Web上での操作によってサーバー上でシェルスクリプトを実行したい

Mits_Dev

総合スコア1

シェルスクリプト

シェルスクリプトは、UNIX系のOSもしくはコマンドラインインタプリタ向けに記述されたスクリプト。bash/zshといったシェルによって実行されるため、このように呼ばれています。バッチ処理などに使用されており、テキストファイルに書かれた命令を順に実行します。

Webサーバー

Webサーバーとは、HTTPリクエストに応じて、クライアントに情報を提供するシステムです。

Webサイト

一つのドメイン上に存在するWebページの集合体をWebサイトと呼びます。

シェル

シェル(shell)はUnix や Linux 系のOSで使用されるコマンドインタプリタを指します。

0グッド

0クリップ

投稿2020/12/21 17:58

Webページ上で特定の操作をした時に(ボタンを押すなど)Webサーバー内に予め作っておいたシェルスクリプトを実行したいのですが、どのような方法で実現できますでしょうか。

具体的にはパスワード保護したページ上のボタンをクリックすることで身内で遊ぶために使っているMinecraftサーバを起動させたいと考えています。(常に私が張り付いていられるわけではないのでメンバーが遊びたいときに起動できるようにしたい)

ITに明るくない友人もメンバーに入っていますので、各々がSSHして起動などは避けたいのでWeb上から操作したいです。

また、このような機能を実装する上でのセキュリティ上の懸念等ありましたらご教授いただけると幸いです。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答4

0

ベストアンサー

web開発やlinuxの基本的な事が分かっている前提の回答です。

1番簡単な方法

  1. 特定のWEBページアクセスしたらファイル(/path/to/server.startまたは/path/to/server.stop)を配置する処理をする
  2. ファイルが存在したら、稼働中のプロセスの有無を確認し、適宜startまたはstopをするシェルスクリプトを組む
  3. cronで毎分シェルスクリプトを動作させる

※ファイルの有無の不整合に対する処理などは適宜やりましょう

2番目簡単な方法

  1. サーバーを起動するスクリプト,停止するスクリプトを用意する
  2. それら実行するコマンドのsudo権限をwebプログラムの実行ユーザーに与える(apacheなど、適宜設定)
  3. start、stopそれぞれのスクリプトを実行するwebプログラム(phpの場合だとexecを実行)を配置する

言語によるが、普通に実行するだけだと処理が終わらないので注意する事。
※例としてphpの場合だと以下のようにリダイレクトしつつexecを使う

function execInBackground($cmd) { if (substr(php_uname(), 0, 7) == "Windows"){ pclose(popen("start /B ". $cmd, "r")); } else { exec($cmd . " > /dev/null &"); } }

投稿2020/12/21 18:48

hentaiman

総合スコア6426

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

tanat

2020/12/21 18:54

1番簡単な方法が楽でいいですね。
Mits_Dev

2020/12/22 02:54

わかりやすく解説していただきありがとうございます! 実際に試してみようと思います。
guest

0

そのwebサーバで動くサーバサイド言語で(必要に応じてsudo経由やnohupをつけて)シェルスクリプトを叩かせれば良いです。

SELinuxの設定が必要になったりしますが、
例えばPHP exec sudoで調べてみるとイメージが湧くかと思いますよ。

投稿2020/12/21 18:51

tanat

総合スコア18727

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

シェルスクリプトを動かすだけだったら昨今の仮想化されたサーバーならセキュリティ上の懸念もそうないでしょう。そもそも危ないもの置かなければいい話なんで。作るのも容易いです。

しかし Minecraft サーバーの管理となると難易度は段違いになるでしょう。シェルスクリプトを動かすのはよいですが、プロセスを切り離す必要がありますし、ユーザーが違うと止めるにも一苦労しそうです。

とは書いたもののダーティな方法ならそこそこ行けなくはないかも?nohupsg を使って立ち上げ psgrepsed 駆使すれば停止できそうな気がします。

投稿2020/12/21 18:25

A_kirisaki

総合スコア2853

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

https化したほうがいいと思います

投稿2020/12/22 01:09

退会済みユーザー

退会済みユーザー

総合スコア0

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問