免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123下一页
最近访问板块 发新帖
查看: 10250 | 回复: 20
打印 上一主题 下一主题

[性能] PHP之中使共享内存进行高速数据更新的一种方案 [复制链接]

论坛徽章:
1
技术图书徽章
日期:2013-12-05 23:25:45
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2005-12-15 15:31 |只看该作者 |倒序浏览
[性能] PHP之中使用共享内存进行高速数据更新的一种方案

    如果在你实际的应用之中,你确实需要高速数据更新的操作,那么我们认为你已经具备以下先决条件:
    能够按照实际应用的需要而调整服务器
    关于这句话,大家自己可以明白意思的,不明白的自己想一想,如果没有达到这个要求,你是否有必要高速数据更新的操作, 或者先看看最后的附加说明.

    先见的参考文档:
1. http://w.yi.org/ftp/FAPM/PHP/php_manual_zh/ref.shmop.html
说明: PHP功能, 共享内存功能函数, 此处用于PHP直接操作内存, 提供高速数据操作
开启: 编译PHP的时候,加上参数: -enable-shmop
附注: 这个准备工作, 非常简单

2. http://w.yi.org/ftp/FAPM/PHP/php_manual_zh/ref.sem.html
说明: PHP功能, IPC通信相关功能函数, 此处用于使用信号量实现互斥
开启: 编译PHP的时候,加上参数: --enable-sysvsem
附注: 这个准备工作, 同样非常简单

3. http://www.huihoo.com/os/process/main.htm
说明: 学习资料, 进程的同步与互斥, 通俗的讲解了进程互斥的概念
附注: 学习资料,看看即可

4. http://www.huihoo.com/os/process/monitor.htm
说明: 学习资料, 信号量, 讲解了信号量在进程互斥之中的使用
附注: 学习资料,看看即可

5. http://www.ccw.com.cn/htm/app/aprog/01_4_25_3.asp
说明: 学习资料, 在PHP中实现进程间通讯, 讲解了如何在PHP之中利用共享内存和IPC视线进程间通讯
附注: 学习资料,看看即可


6. http://pear.php.net/package/System_SharedMemory/
说明: PEAR库, System_SharedMemory, 一个共享内存的PEAR库
支持: 使用pear管理程序, pear install System_SharedMemory-0.1.0
附注: 这个才正是我们所需要的.

    System_SharedMemory在PEAR的说明为"common OO-style shared memory API", 也就是"使用通常面向对象的模式操作共享内存的应用程序接口", 后面我们可以看到, 使用它来操作共享内存, 确实很简单, 要操做一个变量, 就和普通的对象的属性操作(使用set和get)类似了.

    首先, System_SharedMemory可以使用如下的多种途径来进行共享内存操作:

PHP加速模块:     'eaccelerator' => 'Eaccelerator',   // Eaccelerator (Turck MMcache fork)
PHP加速模块:     'mmcache'      => 'Mmcache',        // Turck MMCache
PHP加速模块:     'Memcache'     => 'Memcached',      // Memched
共享内存模块:     'shmop_open'   => 'Shmop',          // Shmop
PHP加速模块:     'apc_fetch'    => 'Apc',            // APC
Apache功能:      'apache_note'  => 'Apachenote',     // Apache note
Systemv模块:     'shm_get_var'  => 'Systemv',        // System V
sqlite数据库模块: 'sqlite_open'  => 'Sqlite',         // SQLite
使用文件模拟:      'file'         => 'File',           // Plain text
PHP加速模块:      'fsockopen'    => 'Sharedance',     // Sharedance


    以上所说的PHP加速模块是认为他在某一层面对PHP进行了加速.

    我们可以根据实际的情况,选用一种途径. 如果没有指定途径, 那么System_SharedMemory会自动从上直下检测是否存在类似途径的操作函数, 而自动选择途径.

    因为我的实验环境是*nix系统, 所以我选择了其中之一 Shmop 模式, 当然其他模式也完全是可以的, 只要你加了对应的编译参数或者扩展模块.

    以下为计数的演示代码:

  1. <?php
  2.     /// 引用System_SharedMemory库
  3.     include_once 'System/SharedMemory.php';

  4.     $intUpdateValue = 255;
  5.     /// 数据库数据更新操作阀值, 255以内刚好一个字符

  6.     /// 实例化System_SharedMemory对象
  7.     $Shared =& System_SharedMemory::factory();

  8.     /// 获取Count的值, 并+1, 如果没有初始化过, 值为0+1
  9.     $intCount = intval($Shared->get('Count')) + 1;

  10.     if($intCount >= 255){
  11.        /// 计数器自增, 每255次
  12.                 $Shared->set('Count', '0');
  13.                 /// 计数器清零, 开始下一计数循环

  14.                 /// 数据库操作
  15.                 /// 数据库更新数据操作, 计数字段+=$intCount
  16.     } else {
  17.                 $Shared->set('Count', strval($intCount));
  18.                 /// 使用共享内存保存计数器值
  19.     }

  20.         echo("$intCount");
  21.         /// 显示本次循环计数器值
  22. ?>
复制代码


    现在把上面的这段代码演示一下子,你会看到一个高速数据更新计数器就这么简单了.
   
    附加说明: 一个小的站点也可以使用这个模块, 因为它可以自动的那个选择共享内存的操作途径, 如果没有对内存操作的函数, 他自动选择使用文件模拟.

[ 本帖最后由 HonestQiao 于 2005-12-15 17:23 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2005-12-15 16:48 |只看该作者
版主大人说得过于简单,另外请举点其他方面的例子,不要老是计数器哈.
再有,版主中间那个灰字简直不好看清

论坛徽章:
62
2016科比退役纪念章
日期:2016-06-28 17:45:06奥兰多魔术
日期:2015-05-04 22:47:40菠菜神灯
日期:2015-05-04 22:35:07菠菜神灯
日期:2015-05-04 22:35:02NBA季后赛大富翁
日期:2015-05-04 22:33:34NBA常规赛纪念章
日期:2015-05-04 22:32:032015年亚洲杯纪念徽章
日期:2015-04-14 16:54:452015年亚洲杯之朝鲜
日期:2015-03-19 23:03:16明尼苏达森林狼
日期:2015-03-16 21:51:152015小元宵徽章
日期:2015-03-06 15:57:202015年迎新春徽章
日期:2015-03-04 09:55:282015年辞旧岁徽章
日期:2015-03-03 16:54:15
3 [报告]
发表于 2005-12-15 16:51 |只看该作者
如何做分布?
拜托能不能改一下字体颜色和背景

论坛徽章:
1
技术图书徽章
日期:2013-12-05 23:25:45
4 [报告]
发表于 2005-12-15 17:26 |只看该作者
其中的Mmcache和Sharedance支持远程调用的.

实际上是监听了一个端口来操作.

论坛徽章:
62
2016科比退役纪念章
日期:2016-06-28 17:45:06奥兰多魔术
日期:2015-05-04 22:47:40菠菜神灯
日期:2015-05-04 22:35:07菠菜神灯
日期:2015-05-04 22:35:02NBA季后赛大富翁
日期:2015-05-04 22:33:34NBA常规赛纪念章
日期:2015-05-04 22:32:032015年亚洲杯纪念徽章
日期:2015-04-14 16:54:452015年亚洲杯之朝鲜
日期:2015-03-19 23:03:16明尼苏达森林狼
日期:2015-03-16 21:51:152015小元宵徽章
日期:2015-03-06 15:57:202015年迎新春徽章
日期:2015-03-04 09:55:282015年辞旧岁徽章
日期:2015-03-03 16:54:15
5 [报告]
发表于 2005-12-15 17:43 |只看该作者
我做的系统过滤,就是你说的这么做的。使用共享内存读入所有的过滤词。
只不过不是使用php.共享内存处理小量的数据很有效。不相信内存表

论坛徽章:
1
技术图书徽章
日期:2013-12-05 23:25:45
6 [报告]
发表于 2005-12-15 17:55 |只看该作者
原帖由 北京野狼 于 2005-12-15 17:43 发表
我做的系统过滤,就是你说的这么做的。使用共享内存读入所有的过滤词。
只不过不是使用php.共享内存处理小量的数据很有效。不相信内存表



当然是较少数据量的操作比较合适.

如果数据量大,还是用专门的系统或者程序来实现

论坛徽章:
0
7 [报告]
发表于 2005-12-15 18:46 |只看该作者
我记得php的共享内存应该早有了吧,这么常用,实用的功能怎么老是推广不起来呢?

w-h-y-?

why?

论坛徽章:
1
技术图书徽章
日期:2013-12-05 23:25:45
8 [报告]
发表于 2005-12-15 20:40 |只看该作者
原帖由 wobushiwo 于 2005-12-15 18:46 发表
我记得php的共享内存应该早有了吧,这么常用,实用的功能怎么老是推广不起来呢?

w-h-y-?

why?




应为它本身提供的基本功能已经足够强大了, 很好用了.

论坛徽章:
1
荣誉会员
日期:2011-11-23 16:44:17
9 [报告]
发表于 2005-12-16 09:12 |只看该作者
PHP的应用绝大多数用mysql数据库,而mysql并不支持存储过程,不知道这样做是否真的能提升系统效率。

论坛徽章:
62
2016科比退役纪念章
日期:2016-06-28 17:45:06奥兰多魔术
日期:2015-05-04 22:47:40菠菜神灯
日期:2015-05-04 22:35:07菠菜神灯
日期:2015-05-04 22:35:02NBA季后赛大富翁
日期:2015-05-04 22:33:34NBA常规赛纪念章
日期:2015-05-04 22:32:032015年亚洲杯纪念徽章
日期:2015-04-14 16:54:452015年亚洲杯之朝鲜
日期:2015-03-19 23:03:16明尼苏达森林狼
日期:2015-03-16 21:51:152015小元宵徽章
日期:2015-03-06 15:57:202015年迎新春徽章
日期:2015-03-04 09:55:282015年辞旧岁徽章
日期:2015-03-03 16:54:15
10 [报告]
发表于 2005-12-16 09:29 |只看该作者
原帖由 tonera 于 2005-12-16 09:12 发表
PHP的应用绝大多数用mysql数据库,而mysql并不支持存储过程,不知道这样做是否真的能提升系统效率。


正常的大量数据的增删改,共享内存并不适合。heap也不太好,还是老老实实使用mysql

共享内存的使用环境比如做连接池,或者认证服务器——真正强大的session,

还有我做的那种过滤服务,通过后台守候进程和socket给其他服务器提供过滤信息服务
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP