ロギングのためにPHPで関数を生成しようとしています
lang
1debug_log($falename, $data)
はファイルが存在しないとき$fileを生成して、それに$dataを追加します。
ただし、これは同時実行や長い文字列にも対応しておかねばならず、高性能である必要があります。
そのため、今思いつくベストな方法は下記のとおりです。
今のところは問題なく作動していますが、もっと簡潔に行う方法があれば教えていただけないでしょうか。
lang
1function debug_log($filename, $data) 2{ 3 // $fileが存在することを確認する 4 $fp = @fopen($filename, 'x'); 5 if ($fp) 6 fclose($fp); 7 8 // アペンドする 9 $filelock = strlen($data) > 4096; // PIPE_BUFは4096 (Linux)と仮定する 10 11 $fp = fopen($filename, 'a'); 12 if ($filelock && !flock($fp, LOCK_EX)) 13 throw new Exception('ファイルをロックすることができません: '.$filename); 14 fwrite($fp, $data); 15 if ($filelock) 16 flock($fp, LOCK_UN); 17 fclose($fp); 18}
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。