php共享内存实现
接着上上篇博客http://blog.csdn.net/wzllai/article/details/8231974 里面的问题,如何避免每次请求都包含文件。自己写扩展对当前业务来说解决显然有点小题大做,在php中其实可以用共享内存来解决这个问题。
共享内存是一种最为高效的进程间通信(IPC)方式,进程可以直接读写内存,而不需要任何数据的拷贝。php源码扩展中有个与共享内存相关的扩展。一个是shmop扩展,默认没有安装,在编译php时候需要--enable-shmop,该扩展在*nix和window 2000下都可以用,另外一个sysvshm是System V IPC函数的封装,只能在*nix下用,需要用时候在编译php的时候需要开启--enable-sysvmsg。
用sysvshm函数写一个简单的列子用共享内存读取一个300k大小的文件:
define("UMASK", 0644); $size = 310000; $key = ftok(__FILE__, "P"); if (false == ($sh = shm_attach($key, $size, UMASK))) die("shm open error"); $ret = @shm_get_var($sh, 1); if (!$ret) { $str = file_get_contents("file"); shm_put_var($sh, 1, $str); $ret = shm_get_var($sh, 1); } //deal $ret ...
通过ab测试同样条件下直接用file_get_contents(“file”)比,在文件比较小的情况下用共享内存貌似还没有直接读取文件效率高,当文件变大的时候共享内存的优势才能体现出来。一般严谨的情况下,在多进程下向共享内存存入数据的时候需要引入引入互斥机制,需要Semaphore系列下的sysvsem模块或者文件锁配合,使用信号或者文件锁来实现写入锁定。
define("UMASK", 0644); $size = 310000; $key = ftok(__FILE__, "P"); if (false == ($sh = shm_attach($key, $size, UMASK))) die("shm open error"); $ret = @shm_get_var($sh, 1); if (!$ret) { $str = file_get_contents("file"); $skey = ftok(__FILE__, "s"); $semid=sem_get($skey); sem_acquire($semid); shm_put_var($sh, 1, $str); sem_release($semid); $ret = shem_get_Var($sh, 1); //使用文件锁解决并发互斥 //$fp = fopen("file.lock", "w+") //if (flock($fp, LOCK_EX|LOCK_NB)) { // shm_put_var($sh, 1, $str); // fclose($fp) //} else { // $ret = $str; //} } //deal $ret ...
声明:该文观点仅代表作者本人,牛骨文系教育信息发布平台,牛骨文仅提供信息存储空间服务。
- 上一篇: 指针的赋值与引用的赋值
- 下一篇: [转]PHP之中使用共享内存进行高速数据更新的一种方案