前言
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\" 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\">资产</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\" rel=\"external nofollow\" rel=\"external nofollow\" 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>\"; } ?>
总结
暂无评论内容