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

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

ただいまの
回答率

88.59%

launchdで動かすとPermission deniedでエラーとなる

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,975

KojiHys

score 7

前提・実現したいこと

PHPで作成したBOTをMacのローカル環境で定期実行をしたいが、launchdで動かすとPermission deniedでエラーとなる

発生している問題・エラーメッセージ

テスト用にテキストファイルを書き出すスクリプト(index.php)を作成しました。
ターミナルで手動で正常動作を確認した上で、
launchdを使用して定期実行を試したところ動作せず、下記のエラーが出て困っています。

エラーメッセージ
Warning: file_put_contents(phpOutput.txt): failed to open stream: Permission denied in /Applications/MAMP/htdocs/hoge/index.php on line 5

ご回答の程、よろしくお願いいたします。

該当のソースコード

[PHP]
<?php

$file = 'phpOutput.txt';
$Message = "成功しました";
file_put_contents($file,$Message, FILE_APPEND);

?>

[plist]
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key>
<string>phpTest</string>
<key>ProgramArguments</key>
<array>
<string>/Applications/MAMP/bin/php/php7.1.6/bin/php</string>
<string>/Applications/MAMP/htdocs/hoge/index.php</string>
</array>
<key>StartInterval</key>
<integer>15</integer>
<key>StandardOutPath</key>
<string>/Applications/MAMP/htdocs/hoge/output.txt</string>
<key>StandardErrorPath</key>
<string>/Applications/MAMP/htdocs/hoge/error.txt</string>
</dict>
</plist>

試したこと

[動作の確認]
・設定した間隔(15秒)毎に、(Warning: file_put_contents(phpOutput.txt): failed to open stream: Permission denied in )が表示される
・ブラウザとターミナルからindex.phpを実行→正常動作
・よって、launchdは定期実行しようとしているが、アクセス権限の不備で動作していない

[/htdocs/hoge/配下の権限の確認]
・/Applications/MAMP/htdocs/hoge/配下のpermissionは(755)だった
・phpOutput.txtのpermissionをchmodで666に変更
→エラーの状態変わらず

[launchdをrootで実行]
・sudo luanchctl load hoge.plistを実行。(Path had bad ownership/permissions)とエラーが出たため、ownerとgroupを、admin,staff→root,wheelに変更
・sudo luanchctl load hoge.plistを実行。実行エラーは出なくなったが、index.phpは動作せず。←今ここ

補足情報(言語/FW/ツール等のバージョンなど)

・使用環境:MacOS Sierra バージョン 10.12.6
・使用言語:PHP 7.1.6
・hoge.plistの配置場所:~/Library/LaunchAgents/hoge.plist
・index.phpの配置場所:~/Applications/MAMP/htdocs/hoge/index.php

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • m.ts10806

    2017/09/22 10:18

    プログラムコード(およびエラーメッセージ)は```で囲ってください。(わからなければ質問編集画面でコード部分を選択し<code>ボタンを押してください)

    キャンセル

回答 1

checkベストアンサー

+1

plist / エラーメッセージ の中と 補足情報に書かれている index.php の PATH が、異なりますが、どちらが正しいですか?
とりあえず、エラーメッセージのパスが正しい PATH と仮定して回答します。


Mac OS の launchd から起動されるプログラムは、ログインユーザーで実行されて、カレントディレクトリは、 / (ルートディレクトリ)になると思います。

そのため、 / に phpOutput.txt を作ろうとして、「file_put_contents(phpOutput.txt): failed to open stream: Permission denied」のエラーが発生しているのではないかと推測します。

プログラムに対し、以下の変更をしたらどうなるでしょうか?

  1. $file = 'phpOutput.txt'; を $file = '/Applications/MAMP/htdocs/hoge/phpOutput.txt'; の様にすべてのファイルパスを / (ルートディレクトリ)からのフルパスで、記入したらどうなるでしょうか?

  2. フルパスでも NG の場合、$file = '/Users/アカウント名/phpOutput.txt'; のように ホームディレクトリの下の場所で、フルパスに変更したらどうなるでしょうか?

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/09/22 21:11 編集

    早速のご回答ありがとうございました。1)の解決方法で無事動作しました。

    $file = 'phpOutput.txt'; を $file = '/Applications/MAMP/htdocs/hoge/phpOutput.txt'; の様にすべてのファイルパスを / (ルートディレクトリ)からのフルパスで、記入したらどうなるでしょうか?

    「ログインユーザーで実行されて、カレントディレクトリは、 / (ルートディレクトリ)になる」この観点がすっかり抜けておりました。

    大変助かりました。ありがとうございました。

    キャンセル

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

  • ただいまの回答率 88.59%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る