Rumah php教程 php手册 php中memcache读取数据批量写入mysql

php中memcache读取数据批量写入mysql

May 25, 2016 pm 04:38 PM

用 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();
}
Salin selepas log masuk

附:

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


本文地址:

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

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)