欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

php運(yùn)用memcache的完整實(shí)例

 更新時間:2021年01月08日 11:59:31   作者:pan_code  
這篇文章主要給大家介紹了關(guān)于php運(yùn)用memcache的完整實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

memcache實(shí)際上也是一個服務(wù)器,不過他是存在內(nèi)存里面的不是存在磁盤里面的

優(yōu)點(diǎn)

  • 速度很快

缺點(diǎn)

  • 不能永久存儲,存放大小受內(nèi)存限制沒有用戶名跟防火墻,mysql有
  • 不過緩存里面也不會存儲重要信息什么的,速度快就很ok,不過受內(nèi)存限制有點(diǎn)傷,畢竟內(nèi)存條比較貴

memcache如何安裝

以window舉例,

需要兩個文件

將.exe文件放在c盤下,

將.exe文件放在c盤下

ctrl+r 打開運(yùn)行,cmd進(jìn)入dos,

找到memcache的根目錄下

找到memcache的根目錄下

運(yùn)行指令memcached.exe -d install 進(jìn)行安裝 卸載就是uninstall

如果安裝成功 運(yùn)行指令memcached -h 查看一下

memcached -h

啟動memcache 運(yùn)行指令memcached.exe -d start 停止就是stop

去任務(wù)管理器看一下啟動了沒有,基本沒有啥踩雷的地方。啟動好之后,咱們就可以運(yùn)行memcache了。

去任務(wù)管理器看一下啟動了沒有

memcache的默認(rèn)端口號是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來弄)

運(yùn)行指令: telnet 127.0.0.1 11211(如果改端口號了,這里同步)

 telnet 127.0.0.1 11211

先打幾個空格再說

stats進(jìn)行查看

在memcache服務(wù)器里面的操作暫時不說了,主要說下在php里面的操作(今天他不是主角),

將php_memcache.dll放在php.ini下,可以ctrl+f尋找extension,然后在最后加上 * extension=php_memcache.dll*

然后 phpinfophpinfo查看一下有沒有問題

展示

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

這樣就說明創(chuàng)建了memcache緩存對象了

這樣就說明創(chuàng)建了mem緩存對象了

當(dāng)我們客戶端訪問服務(wù)器的時候,如果每一次都從數(shù)據(jù)庫讀取數(shù)據(jù)的話,如果訪問量比較大的話,就卡的很,主要是如果優(yōu)化比較費(fèi)錢,這種針對長期或者一段時間不會更改的網(wǎng)頁的內(nèi)容,如果是實(shí)時的話例如秒殺什么的需要高并發(fā)或者是頁面一直在更新,還是不能用緩存機(jī)制的好。

創(chuàng)建好之后,開始弄一個用戶列表的小例子

$me = new Memcache();
//連接memcache服務(wù)器
$me->connect('127.0.0.1',11211);
//pdo連接數(shù)據(jù)庫
$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里面的數(shù)據(jù)
//var_dump($me->get('row'));

if(!($row = $me->get('row'))){
 echo '還沒獲取,此時把數(shù)據(jù)庫的數(shù)據(jù)傳到memcache服務(wù)器里面';
 $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服務(wù)器獲取到數(shù)據(jù),
//如果沒有,則訪問數(shù)據(jù)庫里面的數(shù)據(jù)
//如果存在,則直接從memcache里面獲取數(shù)據(jù) (但是注意需要設(shè)置過期時間,不然永遠(yuǎn)都展示緩存里面的內(nèi)容了)

?>
<!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"  rel="external nofollow" integrity="sha384-9aIt2nRpC12Uk9gS9baDl411NQApFmC26EwAOH8WgZl5MYYxFfc+NcPb1dKGj7Sk" crossorigin="anonymous">
 <script src="https://cdn.jsdelivr.net/npm/jquery@3.5.1/dist/jquery.slim.min.js" integrity="sha384-DfXdz2htPH0lsSSs5nCTpuj/zy4C+OGpamoFVy38MVBnE+IbbVYUew+OrCXaRkfj" crossorigin="anonymous"></script>
 <script src="https://cdn.jsdelivr.net/npm/popper.js@1.16.0/dist/umd/popper.min.js" integrity="sha384-Q6E9RHvbIyZFJoft+2mJbHaEWldlvI9IOYy5n3zV9zzTtmI3UksdQRVvoxMfooAo" crossorigin="anonymous"></script>
 <script src="https://cdn.jsdelivr.net/npm/bootstrap@4.5.0/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" rel="external nofollow" rel="external nofollow" >清除緩存</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">資產(chǎn)</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>頁面數(shù)據(jù)全部來自Mysql數(shù)據(jù)庫!</p>
   </div>
   <?
  }else{
   ?>
   <div class="alert alert-success">
    <p>頁面數(shù)據(jù)全部來自Memcache緩存!</p>
   </div>
   <?
  }
  ?>
</div>

</body>
</html>

第一次是從數(shù)據(jù)庫讀取

第一次是從數(shù)據(jù)庫讀取

之后全部是從memcache里面拿數(shù)據(jù),不在經(jīng)過數(shù)據(jù)庫

之后全部是從memcache里面拿數(shù)據(jù),不在經(jīng)過數(shù)據(jù)庫

實(shí)現(xiàn)一鍵清除緩存

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

具體實(shí)現(xiàn)

<?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>";
}
?>

總結(jié)

到此這篇關(guān)于php運(yùn)用memcache的文章就介紹到這了,更多相關(guān)php運(yùn)用memcache內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論