/*********经验会与我们一起成长的
比如多个进程同时写入这个文件,在处理这个文件的时候又有SQL写入,再清空文件的时候又有SQL写入等等这些情况,如何判断,要求做到数据不丢失,出错能及时处理。
*********/楼主主要是控制住文件写入权限,你可以试着用flock();它返回的是一个布尔值,附加手册详情:flock(PHP 3 >= 3.0.7, PHP 4, PHP 5)
flock -- 轻便的咨询文件锁定
说明
bool flock ( int handle, int operation [, int &wouldblock] )
PHP 支持以咨询方式(也就是说所有访问程序必须使用同一方式锁定, 否则它不会工作)锁定全部文件的一种轻便方法。
注: 在 Windows 下 flock() 将会强制执行。
flock() 操作的 handle 必须是一个已经打开的文件指针。operation 可以是以下值之一:
要取得共享锁定(读取程序),将 operation 设为 LOCK_SH(PHP 4.0.1 以前的版本设置为 1)。
要取得独占锁定(写入程序),将 operation 设为 LOCK_EX(PHP 4.0.1 以前的版本中设置为 2)。
要释放锁定(无论共享或独占),将 operation 设为 LOCK_UN(PHP 4.0.1 以前的版本中设置为 3)。
如果你不希望 flock() 在锁定时堵塞,则给 operation 加上 LOCK_NB(PHP 4.0.1 以前的版本中设置为 4)。
flock() 允许你执行一个简单的可以在任何平台中使用的读取/写入模型(包括大部分的 Unix 派生版和甚至是 Windows)。如果锁定会堵塞的话(EWOULDBLOCK 错误码情况下),请将可选的第三个参数设置为 TRUE。锁定操作也可以被 fclose() 释放(代码执行完毕时也会自动调用)。 如果成功则返回 TRUE,失败则返回 FALSE。 例子 1. flock() 例子
<?php$fp = fopen("/tmp/lock.txt", "w+");if (flock($fp, LOCK_EX)) { // 进行排它型锁定
    fwrite($fp, "Write something here\n");
    flock($fp, LOCK_UN); // 释放锁定
} else {
    echo "Couldn't lock the file !";
}
fclose($fp);
?>  
注: 由于 flock() 需要一个文件指针, 因此你可能需要一个锁定文件来保护到你打算通过写模式打开来截断的文件的访问(在 fopen() 函数中加入 "w" 或 "w+")。
警告 
flock() 不能在 NFS 以及其他的一些网络文件系统中正常工作。详细资料请检查你的操作系统文档。
在部分操作系统中,flock() 以处理级执行。当用一个多线程服务器 API(比如 ISAPI)时,您可能不可以依靠 flock() 来保护文件,因为在同一服务器内运行在其它线程的 PHP 脚本可以对该文件进行处理。
flock() 不支持旧的文件系统,如 FAT 以及它的派生系统。因此,它在这种情况下经常会返回一个 FALSE 值(尤其是指 Windows 98 的用户)。

解决方案 »

  1.   

    有些疑问:
    这样的处理方式,如何即时给客户端返回信息?
    是所有的sql操作都写入该文件,还是有选择地写入?
    如果给文件加锁,当别的进程遇到文件被锁的情况如何处理?是忽略还是等待?
    读取文件的进程用何种语言如何运行?定时自动运行?
      

  2.   

    HELLOYOU0,这样的处理方式,如何即时给客户端返回信息?
    有选择性的,如果是有必要及时返回给用户的SQL就即时处理,不需要及时返回的SQL写到文件中去。
    如果给文件加锁,当别的进程遇到文件被锁的情况如何处理?是忽略还是等待?
    肯定是要等待,不能忽略的。
    读取文件的进程用何种语言如何运行?定时自动运行?
    读文件用的也是PHP,在一个负载小的时候自动运行
      

  3.   

    有选择性的,如果是有必要及时返回给用户的SQL就即时处理,不需要及时返回的SQL写到文件中去。
    -----------
      sql语句的执行是依赖于现有数据的,改变了sql语句执行的顺序可能导致数据的被破坏,如何处理?如果给文件加锁,当别的进程遇到文件被锁的情况如何处理?是忽略还是等待?
    ---------
    确信这个等待比直接等待sql的运行时间短?
      

  4.   

    没必要另做。如果你正在使用mysql的话,在insert语句里加入LOW_PRIORITY关键字,他就会等没人读表时才会执行。
      

  5.   

    如果存在抢占flock呢,就是同时有几个文件需要锁定
      

  6.   

    读文件用的也是PHP,在一个负载小的时候自动运行
    -----------------
    如何判断负载小?判断负载的程序如何运行?不间断运行?