php从memcache读取数据再批量写入mysql的方法


Posted in PHP onDecember 29, 2014

本文实例讲述了php从memcache读取数据再批量写入mysql的方法。分享给大家供大家参考。具体分析如下:

用 Memcache 可以缓解 php和数据库压力下面代码是解决高负载下数据库写入瓶颈问题,遇到最实用的:写入ip pv uv的时候,用户达到每分钟几万访问量,要记录这些数据,实时写入数据库必定奔溃.

用以下技术就能解决,还有如用户注册,同一时间断内,大量用户注册,可以缓存后一次性写入到数据库,代码如下:

public function cldata(){ 

$memcache_obj = new Memcache; 

    $memcache_obj->connect('127.0.0.1', '11211'); 

    $all_items = $memcache_obj->getExtendedStats('items'); 

    foreach($all_items as $option=>$vall){ 

        if (isset($all_items[$option]['items'])) { 

                 $items = $all_items[$option]['items']; 

                 foreach ($items as $number => $item) { 

                       $str    = $memcache_obj->getExtendedStats('cachedump', $number, 0); 

                       $line   = $str[$option]; 

if(is_array($line) && count($line) > 0){ 

    foreach($line as $key => $value) { 

        $keys[] = $key; 

} 

} 

} 

} 

} 

 

    dump(count($keys));//获取到key 

    if(count($keys)>50){//要写入的数据条数       

        $end=50; 

    }else{ 

        $end=count($keys); 

    } 

      

    for($i=0;$i<=$end;$i++){ 

        if(!strstr($keys[$i],'datadb')) continue;       

        $ksv = str_replace('datadb','',$keys[$i]); 

          

    /*$logdata = unserialize(S('login'.$ksv));//登录写入 

    if(is_array($logdata)){ 

        $this->addsuidinlogin($logdata[0],$logdata[1],$logdata[2],1);        

    }   */ 

          

        /*$sdata = unserialize(S('regadd'.$ksv));//注册写入 

    if(is_array($sdata)){ 

        $this->baiduad($sdata[0],$sdata[1],$sdata[2],$sdata[3],$sdata[4],1);     

    } 

    */ 

        $regdata = unserialize(S('datadb'.$ksv));       

        $ress[]=$regdata;

        S('datadb'.$ksv,null); 

      

    }   

    $addb = M()->db(66,C('DB_WEB_AD'));//批量写入 addall 

    $addb->table('mj_ad_count')->addall($ress); 

    echo M()->getLastSql();    

}

补充:可以使用的工具如:memadmin 还有memadmin 文档.

希望本文所述对大家的php程序设计有所帮助。

PHP 相关文章推荐
MySQL相关说明
Jan 15 PHP
PHP中$_SERVER的详细参数与说明
Jul 29 PHP
php教程 插件机制在PHP中实现方案
Nov 02 PHP
PHP Error与Logging函数的深入理解
Jun 03 PHP
PHP SOCKET编程详解
May 22 PHP
PHP模板引擎Smarty内建函数详解
Apr 11 PHP
php 指定范围内多个随机数代码实例
Jul 18 PHP
php 将json格式数据转换成数组的方法
Aug 21 PHP
Laravel框架自定义验证过程实例分析
Feb 01 PHP
php7新特性的理解和比较总结
Apr 14 PHP
基于laravel Request的所有方法详解
Sep 29 PHP
Laravel (Lumen) 解决JWT-Auth刷新token的问题
Oct 24 PHP
php操作mongoDB实例分析
Dec 29 #PHP
Yii实现多数据库主从读写分离的方法
Dec 29 #PHP
php调用mysql存储过程实例分析
Dec 29 #PHP
php生成excel列名超过26列大于Z时的解决方法
Dec 29 #PHP
php+mysqli实现批量替换数据库表前缀的方法
Dec 29 #PHP
PHP跨平台获取服务器IP地址自定义函数分享
Dec 29 #PHP
PHP中使用xmlreader读取xml数据示例
Dec 29 #PHP
You might like
phpfans留言版用到的install.php
2007/01/04 PHP
Php中用PDO查询Mysql来避免SQL注入风险的方法
2013/04/25 PHP
Apache实现Web Server负载均衡详解(不考虑Session版)
2013/07/05 PHP
php实现的DateDiff和DateAdd时间函数代码分享
2014/08/16 PHP
php中运用http调用的GET和POST方法示例
2014/09/29 PHP
PHP实现过滤各种HTML标签
2015/05/17 PHP
Zend Framework生成验证码并实现验证码验证功能(附demo源码下载)
2016/03/22 PHP
php实现批量删除挂马文件及批量替换页面内容完整实例
2016/07/08 PHP
php PDO实现的事务回滚示例
2017/03/23 PHP
如何让PHP编码更加好看利于阅读
2019/05/12 PHP
javascript 同时在IE和FireFox获取KeyCode的代码
2010/02/07 Javascript
兼容IE与firefox火狐的回车事件(js与jquery)
2010/10/20 Javascript
javascript取消文本选定的实现代码
2010/11/14 Javascript
JavaScript+html5 canvas制作的圆中圆效果实例
2016/01/27 Javascript
JS实现的颜色实时渐变效果完整实例
2016/03/25 Javascript
JS识别浏览器类型(电脑浏览器和手机浏览器)
2016/11/18 Javascript
jQuery窗口拖动功能的实现代码
2017/02/04 Javascript
Vue.js学习示例分享
2017/02/05 Javascript
微信小程序商城项目之淘宝分类入口(2)
2017/04/17 Javascript
vue 过滤器filter实例详解
2018/03/14 Javascript
Nuxt.js实现校验访问浏览器类型的中间件
2018/08/24 Javascript
Postman动态获取返回值过程详解
2020/06/30 Javascript
Python使用自带的ConfigParser模块读写ini配置文件
2016/06/26 Python
python获取文件路径、文件名、后缀名的实例
2018/04/23 Python
有关Python的22个编程技巧
2018/08/29 Python
opencv实现静态手势识别 opencv实现剪刀石头布游戏
2019/01/22 Python
python pexpect ssh 远程登录服务器的方法
2019/02/14 Python
对Python3 序列解包详解
2019/02/16 Python
在python中创建指定大小的多维数组方式
2019/11/28 Python
Django模板获取field的verbose_name实例
2020/05/19 Python
Flask处理Web表单的实现方法
2021/01/31 Python
CSS3实现千变万化的文字阴影text-shadow效果设计
2016/04/26 HTML / CSS
CSS3实现时间轴效果
2016/07/11 HTML / CSS
澳大利亚Mocha官方网站:包、钱包、珠宝和配饰
2019/07/18 全球购物
亲子拓展活动方案
2014/02/20 职场文书
3.15国际消费者权益日主题活动活动总结
2014/03/16 职场文书