memcache實際上也是一個服務器,不過他是存在記憶體里面的不是存在磁盤里面的
- 優點
速度很快 - 缺點
不能永久存盤,存放大小受記憶體限制沒有用戶名跟防火墻,mysql有
不過快取里面也不會存盤重要資訊什么的,速度快就很ok,不過受記憶體限制有點傷,畢竟記憶體條比較貴
memcache如何安裝
以window舉例,

將.exe檔案放在c盤下,

ctrl+r 打開運行,cmd進入dos,
找到memcache的根目錄下

運行指令memcached.exe -d install 進行安裝 卸載就是uninstall
如果安裝成功 運行指令memcached -h 查看一下

啟動memcache 運行指令memcached.exe -d start 停止就是stop
去任務管理器看一下啟動了沒有,基本沒有啥踩雷的地方,啟動好之后,咱們就可以運行memcache了,

memcache的默認埠號是11211,
如果你想更改埠號讓別人查不到的話,需要去注冊表
regedit
找到HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\memcached Server

將這個值改為"c:\memcached\memcached.exe" -p 20000 -d runservice 即可,這樣的話訪問得按照20000的埠訪問了
然后我這里用的telnet來操作(也可以下載secureCRT來弄)
運行指令: telnet 127.0.0.1 11211(如果改埠號了,這里同步)

先打幾個空格再說

在memcache服務器里面的操作暫時不說了,主要說下在php里面的操作(今天他不是主角),
將php_memcache.dll放在php.ini下,可以ctrl+f尋找extension,然后在最后加上 * extension=php_memcache.dll*
然后 phpinfo
查看一下有沒有問題

$me = new Memcache();
var_dump($me);
這樣就說明創建了memcache快取物件了

當我們客戶端訪問服務器的時候,如果每一次都從資料庫讀取資料的話,如果訪問量比較大的話,就卡的很,主要是如果優化比較費錢,這種針對長期或者一段時間不會更改的網頁的內容,如果是實時的話例如秒殺什么的需要高并發或者是頁面一直在更新,還是不能用快取機制的好,
創建好之后,開始弄一個用戶串列的小例子
$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/bootstrap@4.5.0/dist/css/bootstrap.min.css" 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">清除快取</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里面拿資料,不在經過資料庫

實作一鍵清除快取
<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>";
}
?>
轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/243329.html
標籤:其他
上一篇:再見~20級網路學生
下一篇:第一篇
