Memcache简介

Memcached是什么?
    Memcached是由Danga Interactive开发的,高性能的,分布式的内存对象缓存系统,
      用于在动态应用中减少数据库负载,提升访问速度。

Memcached能缓存什么?
    通过在内存里维护一个统一的巨大的hash表,Memcached能够用来存储各种格式的数据,
     包括图像、视频、文件以及数据库检索的结果等。

Memcached快么?
    非常快。Memcached使用了libevent(如果可以的话,在linux下使用epoll)来均衡任何数量的打开链接,
      使用非阻塞的网络I/O,对内部对象实现引用计数(因此,针对多样的客户端,对象可以处在多样的状态),
      使用自己的页块分配器和哈希表,因此虚拟内存不会产生碎片并且虚拟内存分配的时间复杂度可以保证为O(1)。
      Danga Interactive为提升Danga Interactive的速度研发了Memcached。

Memcached的特点
    Memcached的缓存是一种分布式的,可以让不同主机上的多个用户同时访问,
      因此解决了共享内存只能单机应用的局限,更不会出现使用数据库做类似事情的时候,
      磁盘开销和阻塞的发生。

缓存数据:
      1.在内存中缓存数据    2.数据形态以key->value结构     3.安全度非常差的

Memcache安装

Windows下操作

1 在网上下载memcached-1.2.1-win32.zip。解压放某个盘下面,比如在c:\memcached
    2 在终端(cmd)下:
        D:\AppServ>memcached.exe -d install     安装
        D:\AppServ>memcached.exe -d uninstall 卸载
        D:\AppServ>memcached.exe -d start     启动
        D:\AppServ>memcached.exe -d stop     停止
            memcached.exe -h  获取所有帮助
    3 在启动之后连接:
        D:\AppServ> telnet 127.0.0.1 11211   --连接memcache端口11211
        使用quit退出。
    4 其他命令参数:
        启动Memcache 常用参数
        -p <num>   设置端口号(默认不设置为: 11211)
        -U <num>   UDP监听端口(默认: 11211, 0 时关闭) 
        -l <ip_addr> 绑定地址(默认:所有都允许,无论内外网或者本机更换IP,
            有安全隐患,若设置为127.0.0.1就只能本机访问)
        -d   独立进程运行
        ... -d start 启动memcached服务 
        ... -d restart 重起memcached服务 
        ... -d stop|shutdown 关闭正在运行的memcached服务 
        ... -d install 安装memcached服务 
        ... -d uninstall 卸载memcached服务 
        -u <username> 绑定使用指定用于运行进程<username>
        -m <num>  允许最大内存用量,单位M (默认: 64 MB)
        -P <file> 将PID写入文件<file>,可以使得后边进行快速进程终止, 需要与-d 一起使用
        -M 内存耗尽时返回错误,而不是删除项 
        -c  最大同时连接数,默认是1024 
        -f 块大小增长因子,默认是1.25 
        -n 最小分配空间,key+value+flags默认是48 
        -h 显示帮助

PHP开启Memcache模块

1.phpinfo()检测是否有memcache扩展

2.php扩展目录 extension_dir
        php_memcache.dll放置到php扩展目录下

3.php配置文件修改
        extension=php_memcache.dll

4.重启apache服务

Linux下安装操作:
        
    2.1 #为php环境安装memcache扩展

首先下载php7.0支持的扩展包 pecl-memcache-php7.zip
        地址:https://github.com/websupport-sk/pecl-memcache/archive/php7.zip

1. 将pecl-memcache-php7.zip文件传到服务器上 /root
    2. 解压文件后进入此目录
       unzip pecl-memcache-php7.zip
       cd pecl-memcache-php7
    3. 由于目录中没有configure配置环境文件
       执行 /usr/local/php/bin/phpize 来准备一个编译环境
    4. 配置: 加配置
       ./configure --with-php-config=/usr/local/php/bin/php-config

5. make && make install 编译和安装

6. 安装成功后就会产生一个memcache.so文件
       /usr/local/php/lib/php/extensions/no-debug-non-zts-20151012/
    7. 修改php配置文件
       vim  /usr/local/php/etc/php.ini
       添加以下信息
       722行 extension_dir='/usr/local/php/lib/php/extensions/no-debug-non-zts-20151012/';
             extension="memcache.so";
    8. 重启apache服务即可(查看phpinfo())

2.2 #安装memcache服务

memcached-1.4.4-3.el6.i686.rpm
    
       a.首先挂载ISO镜像文件  DVD1.ISO
               mount /dev/sr0 /mnt/cdrom/
     
       b.安装memcached
               yum -y install memcached

c.添加memcache用户
               useradd memcache

d.启动memcache服务    
               memcached -d -m 128 -l 127.0.0.1 -p 11211 -u memcache 
            
       
            查看端口     
            netstat –tunpl|grep :11211              
            win+r打开命令行窗口  连接测试
            telnet 192.168.185.252 11211     
          注意:
            如果输入telnet命令的时候 出现telnet不是内部命令
            windows系统->控制面板->程序和功能->打开和关闭Windows功能->勾选 telnet客户端
    
            stats       memcache命令:查看当前状态

e.设置开机自启动 
               chkconfig memcached on

f.如何杀掉后台进程
             pkill memcached

Memcache相关操作
    
####stats 查看状态
        STAT pid 1552                      服务进程的进程ID
        STAT uptime 3792                服务从启动到当前所经过的时间,单位是秒。
        STAT time 1262517674              服务器所在主机当前系统的时间,单位是秒。
        STAT version 1.2.6                   组件的版本。这里是我当前使用的1.2.6。
        STAT pointer_size 32             服务器所在主机操作系统的指针大小,一般为32或64.
        STAT curr_items 1                   表示存放当前的所有缓存对象的数量。不包括已经从缓存中删除的对象。
        STAT total_items 2                   表示从启动到当前,系统存储过的所有对象数量,包括已经删除的对象。
        STAT bytes 593                      表示系统存储缓存对象所使用的存储空间,单位为字节。
        STAT curr_connections 2           表示当前系统打开的连接数。
        STAT total_connections 28        表示从memcached服务启动到当前时间,系统打开过的连接的总数。

set  写入缓存
    set  键名  标记  有效时间  数据的长度
        
      set  love  10     0      10
      i love you
        键名
              最大不能超过250个字符
         标记
         是一个16位的无符号的整数,该标志将和需要存储的数据一起存储,并在客户端get数据时返回
         有效时间
              单位为秒
         数据长度
              单位是字节
         数据的值
         最大不能超过1024kb

get  获取缓存
        get  键名
        get  love

####delete  删除缓存
        delete   键名
        delete   love
        flush_all清空所有缓存

###PHP与Memcache的使用
    //实例化Memcache
    $memcache = new Memcache();
    
    //连接Memcache
    $memcache->connect('127.0.0.1','11211');
    $memcache->addServer('127.0.0.1','11211');
    
    //保存数据
    $memcache->set('name','xiaohigh',MEMCACHE_COMPRESSED,60);
    
    //获取数据
    $memcache->get('name')
    
    //清除所有数据
    $memcache->flush();

###PHP Memcahe类
    connect(ip, port)         连接一台memcache服务器 
    addServer(ip, port)     添加一台memcache服务器
    getExtendedStats()    获取连接池中所有的服务器信息
    getServerStatus(host, port)        获取指定服务器的连接状态
    add(key, value, tag, expires)             添加一条数据
    replace(key, value, tag, expires)     修改一条数据
    set(key, value, tag, expires)             添加或修改一条数据
    get(key)     根据键获取值
    delete(key) 删除指定一条数据
    flush() 删除全部
    close()  关闭连接
    getStats()     获取memcache服务器信息  返回数组
    getVersion()     获取m emcache服务器版本号

转载于:https://blog.51cto.com/haibobo/1943796

memcached 快速入门相关推荐

  1. 高性能RPC框架—----------------------Dubbo一站式快速入门

    https://blog.csdn.net/tangyang8941/article/details/88025412 一.Web应用架构的演变 ​    随着互联网的发展,网站应用的规模不断扩大,W ...

  2. 学Mysql怎样快速入门?

    学Mysql怎样快速入门? 前言 MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,目前属于 Oracle 旗下产品. MySQL 是最流行的关系型数据库管理系统之一,在 WEB ...

  3. 任务队列:celery快速入门及django中celery的用法

    文章目录 一.celey的简介 1.1 celery的工作机制 1.2 安装celery(5.2版本) 二.celery快速入门 2.1 选择broker 2.2 celery的简单使用 2.2.1 ...

  4. redis原理快速入门知识点总结

    redis原理快速入门知识点总结 1. 项目中缓存是如何使用的?为什么要用缓存?缓存使用不当会造成什么后果? 为什么用缓存? 1.高性能: 一些需要复杂操作耗时查出来的结果,且确定后面不怎么变化,但是 ...

  5. 香饽饽:腾讯强推的Redis天花板笔记,帮助初学者快速入门和提高(核心笔记+面试高频解析)

    前言 在目前的技术选型中,Redis 俨然已经成为了系统高性能缓存方案的事实标准,因此现在 Redis 也成为了后端开发的基本技能树之一. 基于上述情况,今天给大家分享一份我亲笔撰写的阿里内部< ...

  6. Shiro第一个程序:官方快速入门程序Qucickstart详解教程

    目录 一.下载解压 二.第一个Shiro程序 1. 导入依赖 2. 配置shiro配置文件 3. Quickstart.java 4. 启动测试 三.shiro.ini分析 四.Quickstart. ...

  7. 计算机入门新人必学,异世修真人怎么玩?新手快速入门必备技巧

    异世修真人怎么快速入门?最近新出来的一款文字修仙游戏,很多萌新不知道怎么玩?进小编给大家带来了游戏新手快速入门技巧攻略,希望可以帮到大家. 新手快速入门攻略 1.开局出来往下找婆婆,交互给点钱,旁边有 ...

  8. Spring Boot 2 快速教程:WebFlux 快速入门(二)

    2019独角兽企业重金招聘Python工程师标准>>> 摘要: 原创出处 https://www.bysocket.com 「公众号:泥瓦匠BYSocket 」欢迎关注和转载,保留摘 ...

  9. Apache Hive 快速入门 (CentOS 7.3 + Hadoop-2.8 + Hive-2.1.1)

    2019独角兽企业重金招聘Python工程师标准>>> 本文节选自<Netkiller Database 手札> 第 63 章 Apache Hive 目录 63.1. ...

  10. 《iOS9开发快速入门》——导读

    本节书摘来自异步社区<iOS9开发快速入门>一书中的目录,作者 刘丽霞 , 邱晓华,更多章节内容可以访问云栖社区"异步社区"公众号查看 目 录 前 言 第1章 iOS ...

最新文章

  1. 设计模式学习笔记:六大原则
  2. 记录一次阿里云服务器升级报错
  3. Java黑皮书课后题第4章:*4.9(给出字符的Unicode码)编写程序,得到一个字符的输入,然后显示其Unicode值
  4. Kafka高性能相关
  5. 企业实战_12_MyCat水平扩展_分库分表
  6. iOS音频的后台播放总结
  7. 【前端应该知道的那些事儿】运动学基础
  8. Windows核心编程_远线程方式实现Dll注入
  9. SSM整理笔记3——配置解析
  10. MySql 存储过程 退出
  11. three.js 文本_使用Three-bmfont-text在Three.js中创建文本
  12. 微信小程序input输入框控制金额格式
  13. 磊科NBR100企业有线路由器IP和Mac地址绑定教程
  14. 大数据之足球盘口赔率凯利必发数据采集爬虫
  15. Python爬取国家税务总局纳税信用A级纳税人信息!
  16. 北京招聘 | 京东广告质量部:算法实习生、算法工程师校招
  17. 南安普顿大学人工智能硕士课程
  18. CodeForces 1457C Bouncing Ball
  19. linux下开启、关闭、重启mysql服务
  20. USB -- BULK_ONLY和UFI协议

热门文章

  1. LeetCode——remove-duplicates-from-sorted-list
  2. python 根据字符串语句进行操作再造函数(evec和eval方法)
  3. MapReduce实战(三)分区的实现
  4. Spark系列(三)SparkContext分析
  5. 【转】 SQL 2005 try catch
  6. 区分Collection、Collector和collect Collectors类的静态工厂方法
  7. 【9933】单词的划分
  8. common.css
  9. 【2017-3-17】视图,事务,备份还原,分离附加
  10. JSP 中 pageEncoding 和 charset 区别以及中文乱码解决方案