php多进程处理大数据库 php多线程处理大数据( 三 )


如果必须要写的话,用别的方法进行同步 。
如调用flock对文件进行加锁等 。
或建立临时文件,并在另外的线程中等待这个文件的消失while(file_exits('xxx'));这样就等于这个临时文件存在时,表示其实线程正在操作 。
如果没有了这个文件,说明其它线程已经释放了这个 。
2.尽量不要从runThread在执行fputs后取这个socket中读取数据 。
因为要实现多线程,需要的用非阻塞模式 。
即在像fgets这样的函数时立即返回 。

所以读写数据就会出问题 。
如果使用阻塞模式的话,程序就不算是多线程了 。
他要等上面的返回才执行下面的程序 。
所以如果需要交换数据最后利用外面文件或数据中完成 。
实在想要的话就用socket_set_nonblock($fp)来实现 。
说了这么多,倒底这个有没有实际的意义呢?在什么时候需要这种用这种方法呢?答案是肯定的 。
大家知道 。
在一个不断读取网络资源的应用中,网络的速度是瓶颈 。
如果采多这种形式就可以同时以多个线程对不同的页面进行读取 。
关于php多进程处理大数据库和php多线程处理大数据的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。

推荐阅读