php运用memcache的完整实例

前言

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

总结

到此这篇关于php运用memcache的文章就介绍到这了,更多相关php运用memcache内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • PHP Memcached应用实现代码

    肖理达 (KrazyNio AT hotmail.com), 2006.04. 06, 转载请注明出处 一.memcached 简介 在很多场合,我们都会听到 memcached 这个名字,但很多同学只是听过,并没有用过或实际了解过,只知道它是一个很不错的东东.这里简单介绍一下,memcached 是高效.快速的分布式内存对象缓存系统,主要用于加速 WEB 动态应用程序. 二.memcached 安装 首先是下载 memcached 了,目前最新版本是 1.1.12,直接从官方网站即可下载到 m

  • PHP中的Memcache详解

    一.Memcache简介 Memcache是danga.com的一个项目,最早是为 LiveJournal 服务的,目前全世界不少人使用这个缓存项目来构建自己大负载的网站,来分担数据库的压力.它可以应对任意多个连接,使用非阻塞的网络IO.由于它的工作机制是在内存中开辟一块空间,然后建立一个HashTable,Memcached管理这些HashTable,所以速度非常快. 二.Memcache和memcached的区别 为什么会有Memcache和memcached两种名称?其实Memcache是

  • php扩展memcached和memcache的安装配置方法

    php连接memcached缓存服务器的客户端有两个,一个是memcache是比较底层的开发库,memcached是比较新的开发库,php安装这两个扩展中的任意一个后就可以在编写php代码时使用的memcached缓存数据,达到缓存php执行的结果 1.安装memcache tar -zxvf memcache-2.2.7.tgz cd memcache-2.2.7 /usr/local/php/bin/phpize ./configure –with-php-config=/usr/local

  • PHP memcache扩展的三种安装方法

    关于比较请看http://code.google.com/p/memcached/wiki/PHPClientComparison.推荐使用新的memcached,安装方法基本同下面,只是需要先安装libmemcached,如果还需要启用压缩,还需要安装zlib.用 PECL 编译共享 PECL 扩展库 $ pecl install extname 然后就是一长串的自动执行,最后程序告诉你You should add "extension=memcache.so" to php.ini

  • PHP操作Memcache实例介绍

    b/s: 基于浏览器和服务器架构 web程序 c/s: QQ SVN client客户端+ 服务器 简单的基于文本行的协议: redis memcache 区别: 都是存储数据的,memcache直接保存到内存中,redis 保存到内存中,关闭之后保存到硬盘中,memcache 重启电脑,关闭服务都会造成数据丢失 (1)保存在内存中 (2)重启电脑,重启服务全部数据都消失 (3)LRU算法,根据最近使用的变量,将长时间没使用的变量删除 PHP如何操作memcache 1,php加载扩展php_m

  • PHP 使用memcached简单示例分享

    1.添加扩展包 复制代码 代码如下: php_memcache.dll 2.在PHP.INI添加 复制代码 代码如下: extension=php_memcache.dll 3.程序 复制代码 代码如下: <?php     //创建一个mem对象实例     $mem=new Memcache;     if(!$mem->connect("10.18.110.213",11211)){         die('连接失败!');     }     //增加     /

  • php运用memcache的完整实例

    前言 memcache实际上也是一个服务器,不过他是存在内存里面的不是存在磁盘里面的 优点 速度很快 缺点 不能永久存储,存放大小受内存限制没有用户名跟防火墙,mysql有 不过缓存里面也不会存储重要信息什么的,速度快就很ok,不过受内存限制有点伤,毕竟内存条比较贵 memcache如何安装 以window举例, 将.exe文件放在c盘下, ctrl+r 打开运行,cmd进入dos, 找到memcache的根目录下 运行指令memcached.exe -d install 进行安装 卸载就是un

  • JavaScript实现简洁的俄罗斯方块完整实例

    本文实例讲述了JavaScript实现简洁的俄罗斯方块.分享给大家供大家参考,具体如下: 先来看看运行效果图: 完整实例代码如下: <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>俄罗斯方块</title> <style ty

  • Spring集成MyBatis完整实例(分享)

    为了梳理前面学习的<Spring整合MyBatis(Maven+MySQL)一>与<Spring整合MyBatis(Maven+MySQL)二>中的内容,准备做一个完整的示例完成一个简单的图书管理功能,主要使用到的技术包含Spring.MyBatis.Maven与MySQL等.最后的运行效果如下: 项目结构如下: 一.新建一个基于Maven的Web项目 1.1.创建一个简单的Maven项目,项目信息如下: 1.2.修改层面信息,在项目上右键选择属性,再选择"Project

  • jQuery实现导航滚动到指定内容效果完整实例【附demo源码下载】

    本文实例讲述了jQuery实现导航滚动到指定内容效果.分享给大家供大家参考,具体如下: 做页面制作也有两年了,其中也做过许多页面效果,有简单的,也有复杂的,今天就来分享一个导航滚动到内容的特效. 平时我们做导航滚动到内容都是通过锚点来做,刷的一下就直接跳到内容了,没有一丝的滚动效果,而且 url 链接最后会有"小尾巴",今天我就介绍一款 jquery 做的滚动的特效,既可以设置滚动速度,又可以在 url 链接上没有"小尾巴". html: <!DOCTYPE

  • jQuery动态添加可拖动元素完整实例(附demo源码下载)

    本文实例讲述了jQuery动态添加可拖动元素的方法.分享给大家供大家参考,具体如下: 运行效果截图如下: 具体代码如下: index.html: <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html> <head> <meta http-equiv="Content-Type&

  • jQuery+vue.js实现的九宫格拼图游戏完整实例【附源码下载】

    本文实例讲述了jQuery+vue.js实现的九宫格拼图游戏.分享给大家供大家参考,具体如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> * { margin: 0; padding: 0; } /*#piclist { width: 600p

  • C#(.net)水印图片的生成完整实例

    本文以一个完整实例讲述了C#水印图片的生成方法.是非常实用的技巧.分享给大家供大家参考. 具体实例代码如下: /* * * 使用说明: * 建议先定义一个WaterImage实例 * 然后利用实例的属性,去匹配需要进行操作的参数 * 然后定义一个WaterImageManage实例 * 利用WaterImageManage实例进行DrawImage(),印图片水印 * DrawWords()印文字水印 * */ using System; using System.Drawing; using

  • js实现会跳动的日历效果(完整实例)

    一.简介 编写一个会动的日历,日历上面有年月日,周几,时分秒,效果如下: 年月日,周几,时分秒都会随着系统时间的走动而改变 二.代码 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scal

  • WebGL利用FBO完成立方体贴图效果完整实例(附demo源码下载)

    本文实例讲述了WebGL利用FBO完成立方体贴图效果的方法.分享给大家供大家参考,具体如下: 这篇主要记录WebGL的一些基本要点,顺便也学习下如何使用FBO与环境贴图.先看下效果图(需要支持WebGL,Chrome,火狐,IE11). 主要实现过程如下,先用FBO输出当前环境在立方体纹理中,再画出当前立方体,最后画球,并且把FBO关联的纹理贴在这个球面上. 开始WebGL时,最好有些OpenGL基础,在前面讲Obj完善与MD2时,大家可能已经发现了,因为着色器的添加使用,原来一些Opengl大

  • JavaScript实现简单的四则运算计算器完整实例

    本文实例讲述了JavaScript实现简单的四则运算计算器.分享给大家供大家参考,具体如下: 运行效果图如下: 完整实例代码如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>computer</title> <script> function compute(){ str1=Number

随机推荐