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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

2回答

1365閲覧

PHPからのコマンド実行がコマンドラインからの動作と異なる

ginga_uvs

総合スコア4

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

1クリップ

投稿2019/12/19 11:19

ログの中からある文字を含む最後の行を取得したいので

PHP上から
EXEC(’grep 検索文字 access_log ');
とし、最後の行を取得していましたが

access_logが膨大な量になり時間が掛かるようになてしまった為

TACとGREPを利用し早く取得できるようになりました
tac access_log | grep -m 1 検索文字
(コマンド上では即結果が戻ります)

しかしこれをPHPのEXECで行うとなぜか

EXEC(’grep 検索文字 access_log ');

とほぼ変わらないような時間が掛かってしまいます

この処理をshにして、PHPからはそのシェルを実行しても結果はおなじです。
コマンドからそのshを実行するとすぐに返ってきます。

何か参考になる情報いただけると助かります
(もうお手上げです)

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

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

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

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

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

m.ts10806

2019/12/19 19:44

「時間が掛かる」は「動作が異なる」とは違うのでは?
ginga_uvs

2019/12/20 00:06

はい、確かに動作がことなっているのだとうと思うのですが 結果自体はPHPから実行しても正しい(時間が掛かりすぎているだけ) 実行しているコマンド自体はコマンドラインからと同じものなので、同じ結果になるだとうと予想していたのですが・・・ その後の検証の結果では ①コマンドラインからだと、TACされながらGREPが行われているので、1件目が見つかると終了する ②PHPからだとTACされたものが全て完了し(どこかのメモリ上に確保される?)それに対しGREPがされる、このような動作の違いの為、大量のログファイルにすると、TACの処理に時間が掛かってしまっているように見受けられるのですが、どうにも理由も対策方法もわからないのです。。。
otn

2019/12/20 05:49

> ginga_uvsさん 質問に書いてあることをコメントで繰り返し書くのは止めましょう。何行も読んで、追加の情報量がゼロだとがっかりします。 質問の意図に対しては、このような趣旨の返事をすれば良いかと。 「出力結果が異なる」わけではないが「一瞬で終わる」「1分以上かかる」の違いを「動作が異なる」と表現した。
otn

2019/12/20 06:16

試したところ、ginga_uvsさんと同じくphpだと時間がかかる場合と、どちらも一瞬で終わる場合がありますね。phpinfo() を比べてみます。OSバージョンは同じなのですが。
guest

回答2

0

レンタルサーバーにかぎらず、
webブラウザからのphp実行は、
webサーバープロセスからの実行であって、
telnetなどのコンソール接続でのphp実行とは
ユーザーが異なります。

ユーザーが異なると、
OS上のリソースの使い方も異なる場合があり、
環境変数や実行可能なプログラム類も制限があったり、
外部プログラムの実行に何らかの制限をかけていたり
CPUリソースを抑えられていたるする可能性もありえます。

サーバー管理者に問い合わせするべき話です。

投稿2019/12/19 11:28

編集2019/12/19 11:29
退会済みユーザー

退会済みユーザー

総合スコア0

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

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

0

strace php ファイル名でシステムコール呼び出しを調べると、

rt_sigaction(SIGPIPE, {SIG_IGN, [], SA_RESTORER, 0x3e70c32570}, NULL, 8) = 0
というシステムコールが出ていて、SIGPIPEを無視するように設定しています。
これは、php -r "echo 0;"でも同様に行われるので、PHPの実行の際は常にということでしょうね。

つまり、パイプの後段のプロセス(grep)が終了しても前段のtacは終了しません。
直接的には、それが原因です。

「PHP SIGPIPE」「PHP シグナル」等でググっても、ノイズが多くてPHPがそうしている理由がわかりません。

試行錯誤で、これで行けるようです。シェルを対話モードにするために-iを付ける。

PHP

1$x = exec("sh -i -c 'tac access_log | grep -m 1 検索文字'");

これでうまくいく理由は、おそらく、シェルを対話モードにするとシェルが起動されてからシグナル関連の設定をやり直すからと思われますが、詳しくは分からず。

投稿2019/12/20 23:59

編集2019/12/21 08:51
otn

総合スコア84559

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問