搜尋
首頁php教程php手册php中memcache读取数据批量写入mysql

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

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

<?php
public function cldata() {
    $memcache_obj = new Memcache;
    $memcache_obj->connect(&#39;127.0.0.1&#39;, &#39;11211&#39;);
    $all_items = $memcache_obj->getExtendedStats(&#39;items&#39;);
    foreach ($all_items as $option => $vall) {
        if (isset($all_items[$option][&#39;items&#39;])) {
            $items = $all_items[$option][&#39;items&#39;];
            foreach ($items as $number => $item) {
                $str = $memcache_obj->getExtendedStats(&#39;cachedump&#39;, $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], &#39;datadb&#39;)) continue;
        $ksv = str_replace(&#39;datadb&#39;, &#39;&#39;, $keys[$i]);
        /*$logdata = unserialize(S(&#39;login&#39;.$ksv));//登录写入
        if(is_array($logdata)){
        $this->addsuidinlogin($logdata[0],$logdata[1],$logdata[2],1);
        }   */
        /*$sdata = unserialize(S(&#39;regadd&#39;.$ksv));//注册写入
        if(is_array($sdata)){
        $this->baiduad($sdata[0],$sdata[1],$sdata[2],$sdata[3],$sdata[4],1);
        }
        */
        $regdata = unserialize(S(&#39;datadb&#39; . $ksv));
        $ress[] = $regdata; //开源代码phprm.com
        S(&#39;datadb&#39; . $ksv, null);
    }
    $addb = M()->db(66, C(&#39;DB_WEB_AD&#39;)); //批量写入 addall
    $addb->table(&#39;mj_ad_count&#39;)->addall($ress);
    echo M()->getLastSql();
}

附:

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


本文地址:

转载随意,但请附上文章地址:-)

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具