php-運用memcache的小例子

memcache實際上也是一個服務器,不過他是存在內存裏面的不是存在磁盤裏面的

  1. 優點
    速度很快
  2. 缺點
    不能永久存儲,存放大小受內存限制沒有用戶名跟防火牆,mysql有
    不過緩存裏面也不會存儲重要信息什麼的,速度快就很ok,不過受內存限制有點傷,畢竟內存條比較貴

memcache如何安裝

以window舉例,
需要兩個文件
將.exe文件放在c盤下,
將.exe文件放在c盤下
ctrl+r 打開運行,cmd進入dos,
找到memcache的根目錄下
找到memcache的根目錄下
運行指令memcached.exe -d install 進行安裝 卸載就是uninstall
如果安裝成功 運行指令memcached -h 查看一下
memcached -h
啓動memcache 運行指令memcached.exe -d start 停止就是stop
去任務管理器看一下啓動了沒有,基本沒有啥踩雷的地方。啓動好之後,咱們就可以運行memcache了。
去任務管理器看一下啓動了沒有
memcache的默認端口號是11211,
如果你想更改端口號讓別人查不到的話,需要去註冊表
regedit
找到HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\memcached Server
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\memcached Server
將這個值改爲"c:\memcached\memcached.exe" -p 20000 -d runservice 即可,這樣的話訪問得按照20000的端口訪問了"c:\memcached\memcached.exe" -p 20000 -d runservice
然後我這裏用的telnet來操作(也可以下載secureCRT來弄)
運行指令: telnet 127.0.0.1 11211(如果改端口號了,這裏同步)



















 telnet 127.0.0.1 11211

先打幾個空格再說
stats進行查看
在memcache服務器裏面的操作暫時不說了,主要說下在php裏面的操作(今天他不是主角),
將php_memcache.dll放在php.ini下,可以ctrl+f尋找extension,然後在最後加上 * extension=php_memcache.dll*


然後 phpinfophpinfo查看一下有沒有問題
展示

$me = new Memcache();
var_dump($me);

這樣就說明創建了memcache緩存對象了
這樣就說明創建了mem緩存對象了
當我們客戶端訪問服務器的時候,如果每一次都從數據庫讀取數據的話,如果訪問量比較大的話,就卡的很,主要是如果優化比較費錢,這種針對長期或者一段時間不會更改的網頁的內容,如果是實時的話例如秒殺什麼的需要高併發或者是頁面一直在更新,還是不能用緩存機制的好。

創建好之後,開始弄一個用戶列表的小例子


$me = new Memcache();
//連接memcache服務器
$me->connect('127.0.0.1',11211);
//pdo連接數據庫
$dsn = "mysql:host=localhost;dbname=www.hm.com";
$username = "hmcom";
$password = "123456";
$pdo = new PDO($dsn,$username,$password);
$pdo->exec('set names utf8');
$pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);


//判斷是否拿到memcache裏面的數據
//var_dump($me->get('row'));

if(!($row = $me->get('row'))){
   
   
    echo '還沒獲取,此時把數據庫的數據傳到memcache服務器裏面';
    $sql = "select * from `user` where id > 0";
    $smt = $pdo->prepare($sql);
    $smt->execute();
    $result = $smt->fetchAll();
    $me->set('row',$result,0,50);
    $s = 1;
}else{
   
   
    $s = 0;
}

//判斷是否從memcache服務器獲取到數據,
//如果沒有,則訪問數據庫裏面的數據
//如果存在,則直接從memcache裏面獲取數據 (但是注意需要設置過期時間,不然永遠都展示緩存裏面的內容了)

?>
<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>查看所有用戶</title>
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/[email protected]/dist/css/bootstrap.min.css" integrity="sha384-9aIt2nRpC12Uk9gS9baDl411NQApFmC26EwAOH8WgZl5MYYxFfc+NcPb1dKGj7Sk" crossorigin="anonymous">
    <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/jquery.slim.min.js" integrity="sha384-DfXdz2htPH0lsSSs5nCTpuj/zy4C+OGpamoFVy38MVBnE+IbbVYUew+OrCXaRkfj" crossorigin="anonymous"></script>
    <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/umd/popper.min.js" integrity="sha384-Q6E9RHvbIyZFJoft+2mJbHaEWldlvI9IOYy5n3zV9zzTtmI3UksdQRVvoxMfooAo" crossorigin="anonymous"></script>
    <script src="https://cdn.jsdelivr.net/npm/[email protected]/dist/js/bootstrap.min.js" integrity="sha384-OgVRvuATP1z7JjHLkuOU7Xw704+h835Lr+6QL9UvYjZE3Ipu6Tp75j7Bh/kR0JKI" crossorigin="anonymous"></script>
</head>
<body>
<div class="container">
    <h2 class="page-header">查看用戶:</h2>
    <a class="btn btn-warning" href="clear.php">清除緩存</a>
    <table class="table table-striped">
        <thead class="thead-dark ">
        <tr>
            <th scope="col">編號</th>
            <th scope="col">用戶名</th>
            <th scope="col">年齡</th>
            <th scope="col">資產</th>
        </tr>
        </thead>
        <tbody>
        <?
        foreach ($row as $k => $rows){
   
   
            ?>
            <tr>
                <th scope="row"><?=$rows['id']?></th>
                <td><?=$rows['name']?></td>
                <td><?=$rows['age']?></td>
                <td><?=$rows['money']?></td>
            </tr>
            <?
        }
        ?>
        </tbody>
    </table>
        <?
        if($s){
   
   
            ?>
            <div class="alert alert-danger">
                <p>頁面數據全部來自Mysql數據庫!</p>
            </div>
            <?
        }else{
   
   
            ?>
            <div class="alert alert-success">
                <p>頁面數據全部來自Memcache緩存!</p>
            </div>
            <?
        }
        ?>
</div>

</body>
</html>

第一次是從數據庫讀取第一次是從數據庫讀取
之後全部是從memcache裏面拿數據,不在經過數據庫
之後全部是從memcache裏面拿數據,不在經過數據庫
實現一鍵清除緩存


<a href="clear.php" class='btn btn-success'>清除緩存</a>

具體實現

<?php
/**
 * Created by PhpStorm.
 * User: lenovo
 * Date: 2020/12/28
 * Time: 14:31
 */

$mem = new Memcache();
//連接memcache
$mem->connect("127.0.0.1",'11211');
//清空緩存
//$mem->flush();
if($mem->flush()){
   
   
    echo "<script>location='index.php'</script>";
}
?>
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章