[CakePHP]SplFileInfo::openFileエラーの対応方法

[CakePHP2.2.3]

CakePHP2.xから、app/tmp/cache/modelsやapp/tmp/cache/persistent内のキャッシュファイルが生成される際に、パーミッションの問題で以下のようなエラーが出ることが多いです。

Warning: SplFileInfo::openFile(/www/app/tmp/cache/persistent/cake_core_cake_console_) [splfileinfo.openfile]: failed to open stream: Permission denied in /www/lib/Cake/Cache/Engine/FileEngine.php on line 292

この問題はファイル所有者とアクセスユーザーが違うので発生しているのですが、umaskを設定することで解決できます。
実際のコードは、core.phpの最下部にあるキャッシュ設定にmaskオプション追加するだけです。

[php]
//app/Config/core.php
Cache::config(‘_cake_core_’, array(
‘engine’ => $engine,
‘prefix’ => $prefix . ‘cake_core_’,
‘path’ => CACHE . ‘persistent’ . DS,
‘serialize’ => ($engine === ‘File’),
‘duration’ => $duration,
‘mask’ => 0666,
));
Cache::config(‘_cake_model_’, array(
‘engine’ => $engine,
‘prefix’ => $prefix . ‘cake_model_’,
‘path’ => CACHE . ‘models’ . DS,
‘serialize’ => ($engine === ‘File’),
‘duration’ => $duration,
‘mask’ => 0666,
));
[/php]

追記:Cache:write();を使う方は、以下のように別途、defaultの設定も追加しておいた方がいいでしょう。bootstrapに以下を追加しておきましょう。

[php]
//app/Config/bootstrap.php
Cache::config(‘default’, array(
‘mask’ => 0666,
));
[/php]

1 Comment

  1. SPYDER
    2014/04/10

    クーロン実行時に、パーミッションエラーになって
    困っていました。

    大変参考になりました。
    ありがとうございます。

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.