phpでアクセス解析を作っているのですが、
解析データをログファイルに書き込みする際に
たまにデータが全部消えてしまう現象に陥りました。
下記コードでログファイルに書き込み処理をしています。
どなたか原因が分かる方、ご教授お願いいたします。
// ログデータ処理
$logdata = file($counter->logfile);
list($time,$host) = explode("\t",$logdata[0]);// 比較のため直前のホスト取得
if($host != $counter->host and // 連続アクセスは処理しない
!$out_flag){// 除外ホストは処理しない
$str =
time()."\t".// 時間
$counter->host."\t".// ホスト
$counter->agent."\t".// ユーザーエージェント
$counter->referer."\t".// リンク元
"\t\n";
$lp = fopen($counter->logfile,"w");
$lock = flock($lp,LOCK_EX);
if($lock){
fputs($lp,$str);
$i = 1;
foreach($logdata as $value){
fputs($lp,$value);
$i++;
if($i >= $counter->loglimit){break;}// ログ上限に達したら抜ける
}
}
flock($lp,LOCK_UN);
fclose($lp);
}
A 回答 (1件)
- 最新から表示
- 回答順に表示
No.1
- 回答日時:2011/11/04 12:27
fopen($counter->logfile,"w");の時点でファイルは空になっていますから、このタイミングで(ロックする前に)他からfile()で読んだら何もない状態です。
比較のための直前ホストの取得などはfile()で読み込んだものでもいいですが、実際に「書き込み」をするときには、"rw"で開く→ロック→全行を再取得→ファイルポインタを先頭に戻す→追加データ+再取得データを書き込み→ロック解除でないとマズイのでは?
この回答への補足
ご解答ありがとうございます。
具体的なコードが分からず困っております。
もし差し支えなければ教えていただければ幸いです。
どうかよろしくお願いいたします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
- 家族6人の食費いくらぐらいですか? - 食費 [締切済 - 2016/10/06]
- 「赤ら顔」がコンプレックスの方に朗報。専門化粧水がすごい![PR] voice
- 新築の家の天井の高さ - 一戸建て 締切済
- 口臭女子の悩みを10秒解決する「飲む香水」とは![PR] x-voice
- 「確定申告」納税額が0円の場合、申告はしなくてもよい? -駐車場運営- ..
- Excel 条件付き書式設定について - Windows 10 締切済
- テレビとパソコンのwi-fi接続 - テレビ [解決済 - 2016/02/03]
- 仕事の携帯着信について - ビジネスマナー・ビジネス文書 解決済
- 【結婚?キャリア?】ライフスタイルの選択に迷える人へ[PR] X-voice
- ノートPC(windows10)でイヤホンマイクが使えない - ノートパソコン [解..
関連するQ&A
- 1 javascriptとPHPを用いた自作アクセス解析について
- 2 ロリポップでPHPのアクセス解析を設置したいのですが…
- 3 【PHP】アクセス過多でファイル書き込み失敗時ならどうすれば?
- 4 PHP3で作ったプログラムをPHP4、PHP5で動作させる事は可能ですか
- 5 アクセス解析を作ってます。クッキーについて
- 6 PHPをさわっているのですが、日本語ファイル名のPHPファイルは実行で
- 7 phpのテキストファイルの書き込み
- 8 phpでMySQLのデータベースにアクセスする際、
- 9 MySQL, PHP をインストール後、データベースにアクセスできません。
- 10 PHP 確認画面から入力画面に戻ると入力したデータが消える。
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
人気Q&Aランキング
-
4
PHPでフォームからデータDBに書...
-
5
複数行のデータのPOST処理に関して
-
6
phpでショッピングカート機能を...
-
7
sqlで日付が一番古いデータの月...
-
8
MYSQLとSQLの違い
-
9
pg_copy_fromの使い方について...
-
10
MAX関数を使ってからLEFT JOIN...
-
11
php mysql で WHERE句内に変数...
-
12
VB.NET
-
13
mysql複数レコードをまとめて削...
-
14
Winsockで、localhostに接続時...
-
15
DataSet(DataTable)の使い方
-
16
テキストボックスに入れた内容...
-
17
データ読込時のタイムアウト
-
18
アラートでyes noを作りたいです。
-
19
距離から緯度経度を求める方法
-
20
PHPで一度に複数ページのスクレ...
おすすめ情報
公式facebook
公式twitter