专栏首页编程学习园地PHP数据库操作二:memcache用法分析

PHP数据库操作二:memcache用法分析

本文实例讲述了PHP数据库操作之memcache用法。分享给大家供大家参考,具体如下:

在一个高并发的web应用中,数据库存取瓶颈一直是个大问题,一旦达到某个极限,数据库很容易崩溃,但是如果我们把常用的数据放到内存中,在需要的时候从内存中取,不光读取速度快,而且节约数据库IO。

memcache简介

Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。简单的说就是将数据调用到内存中,然后从内存中读取,从而大大提高读取速度。

memcache的mem是内存(memory),cache是缓存,结合是内存缓存的意思。我们应用memcache时,读取数据先从memcache内读取,若查找不到再去数据库里查找,并将数据存入memcache,待下次查找时便能轻易找到。

需要注意:

memcache是内存型的数据库 ,因为内存的关闭释放的特性,memcache也无法持久化存储内容;

memcache内部是分块存储,所以大于1M的数据也无法存储。

memcache依赖libevent库,安装前需确认已经安装了libevent库。

memcache是一个轻量级的内存型数据库,只支持key-value型的存储。

memcache中没有关于用户,密码的设置,所以在配置时要配置防火墙的端口限制连接,以达到安全的目的。

使用repcached也能轻易实现memcache的单master单slave主从复制。

memcache的应用场景

存储大量不需要持久存储或数据库内已存在不会变动的数据。

读取数据非常频繁数据,要求小于1M。

数据类型简单的key-value型数据。

计算好的结果和渲染后的网页模板文件。

因其原子递增性,可以用来计数。

因为可以设置数据过期时间的特性,存储期限数据。不过需要注意,memcache会在分配的内存不足时以最近最少使用原则(LRU)重用内存,可能会导致信息提前被删除。

用memcache存储session信息,以达到多服务器session共享。需要配置:php.ini:

session.save_handler = memcache //设置session的储存方式为memcache

memcache.hash_strategy = "consistent"//设置memcache的hash算法为一致性哈希算法。

session.save_path = "tcp:/ip:port" ///

/设置session储存的位置,多台memcache用逗号隔开。

memcache服务器的安装

memcache的安装简单,服务器可以在其官网

,解压后在其目录下运行./configure -prefix=/path编译,然后make / make test / make install 得到可以直接执行的二进制文件。

使用./memcached命令即可开启服务器,其常用参数如下:

-p port 监听端口 (默认: 11211)

-d 以后台方式运行Memcached

-u username 运行Memcached的账户

-m n 最大的内存使用, 单位是MB,默认 64 MB

-c connections 最大连接数量, 默认是 1024

memcache的常用命令

用memcache客户端或telnet连接到memcache后,就可以对memcache进行操作了。

memcache数据结构简单,所以命令行命令也很少,下面以一条常用命令来简析一下命令格式:

add key flags expire_time length rn value

flags:是否压缩/序列化,通常为0。

expire_time:从存储后多久过期。以秒(s)为单位,最大为30天的长度,超过30天的长度被视为时间戳表示"到什么时候过期",若设为0表示永不过期。

length:value长度,输入长度回车之后,命令行会读取你接下来输入的length个字符。

set key flags expire_time length //如果有值则覆盖原值,没有则新增,add在有值时会存储失败

get key //获取key的值

replace key flags expire_time length// 替换一个已存在的key

append/preappend key flags expire_time length// 给key的value后面/前面添加新内容。

preappend key flags expire_time length // 给key的value前面添加新内容。

inc/dec key [n] //key的值递增/递减1/[n]

delete key //删除一个key

flush_all [n] //[在n秒后]删除全部数据

stats [options] //获取memcache[有关某一项]的详细信息

PHP的memcache扩展及应用

linux系统,直接挑选版本(推荐最新stable稳定版)下载,解压后在解压目录下用phpize工具产生configure文件,并用它安装,安装完成后在/php.ini中添加extension。具体可参考前文:

windows下要点击链接右边的“windows logo DLL”链接,并在新打开的页面中,按照版本、32位/64位、线程安全/非线程安全来选择自己所需要的扩展,具体选项可以在phpinfo();页面看到。下载完成后,将其放入phppath/ext/目录下,然后在php.ini中添加extension=php_memcacache.dll;重启服务器完成安装。

在phpinfo()页面中看到memcache扩展后/

/,说明安装成功,我们就可以在php脚本中使用关于memcache的类函数库了。

在手册中我们可以找到许多关于php的memcache扩展的使用,以下是一个典型的memcache使用流程。

$m=new Memcache();

$m->connect($host,$port);

$m->add($key,$value[,flags,$expire_time]);

$content=$m->get($key);

$m->close();

这是一个简单的memcache连接程序,在进行memcache分布式存储时,还需要用到$memcache->addServer()向memcache集群中添加服务器。

此外,还有get(),set(),flush(),delete()等方法,用法都大同小异,在手册上也能找得到,这里提供一个本站的php手册下载地址:

希望本文所述对大家PHP程序设计有所帮助。

原文链接:https://www.blog.zirun.me/php/4655.html

我来说两句

0 条评论
登录 后参与评论

相关文章

  • PHP数据库操作二:memcache用法分析

    本文实例讲述了PHP数据库操作之memcache用法。分享给大家供大家参考,具体如下: 在一个高并发的web应用中,数据库存取瓶颈一直是个大问题,一旦达到某个极...

    用户2323866
  • PHP数据库操作四:mongodb用法分析

    传统数据库中,我们要操作数据库数据都要书写大量的sql语句,而且在进行无规则数据的存储时,传统关系型数据库建表时对不同字段的处理也显得有些乏力,mongo应运而...

    用户8449980
  • PHP数据库操作三:redis用法分析

    memcache虽然好用,解决了数据库遇到高并发时的IO问题,但还有很多问题丞待解决:

    用户8449980
  • 部署LNMP动静分离并搭建memcache缓存服务器

    一、MemCache简介 MemCache 是一个自由、源码开放、高性能、分布式的分布式内存对象缓存系统,用于动态Web应用以减轻数据库的负载。它通过在内存中缓...

    小手冰凉
  • PHP中的数据库二、memcache

    在一个高并发的web应用中,数据库存取瓶颈一直是个大问题,一旦达到某个极限,数据库很容易崩溃,但是如果我们把常用的数据放到内存中,在需要的时候从内存中取,不光读...

    枕边书
  • PHP之Memcache和Memcached

    本篇文章向大家介绍的是PHP中的Memcache和Memcached ,有兴趣的朋友可以看一下

    码农编程进阶笔记
  • 企业级memcached缓存数据库结合php使用与web管理memcached

    环境 [root@cache01 ~]# cat /etc/redhat-release CentOS Linux release 7.4.1708 (Cor...

    863987322
  • 企业级memcached部署(session共享)

    服务端部署 第一个里程碑:安装依赖关系       Memcache用到了libevent这个库用于Socket的处理。 1 [root@nfs01 ~]# ...

    惨绿少年
  • memcache安装

    memcached是高性能的分布式内存缓存服务器,为了提高性能,memcached中的数据都保存在内存中,重启memcached及重启操作系统都会导致缓存中的数...

    Java架构师必看
  • 系统的讲解 - PHP 缓存技术

    缓存已经成了项目中是必不可少的一部分,它是提高性能最好的方式,例如减少网络I/O、减少磁盘I/O 等,使项目加载速度变的更快。

    新亮
  • 玩玩Memcache缓存组件For PHP

    AlicFeng
  • 从原理PHP缓存技术讲解场景系统

    缓存已经成了项目中是必不可少的一部分,它是提高性能最好的方式,例如减少网络I/O、减少磁盘I/O 等,使项目加载速度变的更快。

    叫我可儿呀
  • Memcached安装以及PHP的调用

    一:安装libevent由于memcached安装时,需要使用libevent类库,所以先安装libPHP ...

    Java架构师必看
  • memcache和memcached的区别

    Marser
  • 学习笔记0711----NOSQL之memcached

    MemCache是一个自由、源码开放、高性能、分布式的分布式内存对象缓存系统,用于动态Web应用以减轻数据库的负载。它通过在内存中缓存数据和对象来减少读取数据库...

    嘻哈记
  • Memcached 缓存系统的-介绍、安装以及应用

    一. memcached 是什么? memcached is a high-performance, distributed memory object ca...

    Java架构师必看
  • PHP中关于php.ini参数优化详解

    无论是apache还是nginx,php.ini都是适合的。而php-fpm.conf适合nginx+fcgi的配置

    砸漏
  • 2021年最新PHP 面试、笔试题汇总(二)

    require是无条件包含,也就是如果一个流程里加入require,无论条件成立与否都会先执行require,当文件不存在或者无法打开的时候,会提示错误,并且会...

    码农编程进阶笔记
  • nginx+php负载均衡集群环境中的session共享方案梳理

    在网站使用nginx+php做负载均衡情况下,同一个IP访问同一个页面会被分配到不同的服务器上,如果session不同步的话,就会出现很多问题,比如说最常见的登...

    洗尽了浮华

扫码关注云+社区

领取腾讯云代金券