zoukankan      html  css  js  c++  java
  • Linux下搭建Memcached缓存系统

    首先说下抱歉,博主近期单位经常加班。博客更新有点慢。希望大家理解,草稿箱里存了不少内容,等不忙时候一点点填坑~

    在一般的站点开发学习时候。都会把数据存放在RDBMS(关系型数据库系统(Relational Database Management System)中,server程序通过读取RDBMS来取得数据显示在页面上。

    这在我们以往编写练习项目时候,是没有不论什么问题的。依据木桶理论,一仅仅水桶能装多少水取决于它最短的那块木板,在实际的站点开发中,随着数据量的增大。訪问的集中,就会出现RDBMS的负担加重、数据库响应恶化、 站点显示延迟等重大影响。

    这时候就轮到Memcached大显身手了。顾名思义,Memcached是一套通过内存实现的缓存系统。并且它实现了分布式存储。一般我们使用Memcached的目的,是通过缓存数据库的一部分内容,降低对数据库的訪问,从而提高站点性能。

    2008092816494460.png

    试想一下这么个情况,我们寻常上的淘宝网,首页里面有商品分类、商品品牌、热销商品、各种活动的展示。在不使用缓存的情况下,我们訪问首页,须要到RDBMS中查询分类、品牌、热销、活动等数十张表,会导致站点响应缓慢。

    事实上这些首页的数据,每天的变化不是非常频繁。对实时性的要求不是非常高。我们能够让每次訪问首页的时候,程序从缓存中读取首页须要展示的数据。从而降低对RDBMS的压力。假设原本每秒訪问一次。如今直接訪问缓存。缓存每5分钟刷新,那么对RDBMS的訪问仅仅有原来的1/300。更何况实际使用中,站点的訪问,远远不止每秒一次,即使每秒10次、100次。对于RDBMS的訪问都是固定的。

    Memcached尽管称为“分布式”缓存server,但server端并没有“分布式”功能。Memcached的分布式全然是在client实现的,client会依据保存的key来决定保存数据的Memcachedserver。

    相同。取得数据的时候,也会依据key来从不同server上取得数据。

    这样,将不同的键保存到不同的server上,就实现了Memcached的分布式。 Memcachedserver增多后,键就会分散。即使一台Memcachedserver发生问题无法连接。也不会影响其它的缓存。系统依旧能继续执行。

    Memcached缓存系统的搭建事实上十分简单,在这里以Linux以下的搭建为例: 
    系统环境ubuntu15.04 64位

    安装Memcachedserver端仅仅须要一句命令

    sudo apt-get install memcached 
    安装完毕后通过以下命令启动Memcached

    memcached -d -m 128 -p 11211 -u root 
    顺便说下memcached的启动參数 
    -d 选项是启动一个守护进程。 
    -m 是分配给Memcache使用的内存数量,单位是MB。这里是128MB,默认是64MB 
    -u 是执行Memcache的用户。这里是root 
    -l 是监听的serverIP地址,默认应该是本机 
    -p 是设置Memcache监听的port。默认是11211,最好是1024以上的port 
    -c 选项是最大执行的并发连接数,默认是1024,这里设置了10240,依照你server的负载量来设定 
    -P 是设置保存Memcache的pid文件位置 
    -h 打印帮助信息 
    -v 输出警告和错误信息 
    -vv 打印client的请求和返回信息

    开发时候建议加上-vv。此时会显示client的请求信息,比較方便我们进行调试。并且显示的效果比較cool。

    QQ图片20150528161807.png

    Memcached安装完毕后,能够通过telnet ip port进行连接。如telnet 127.0.0.1 11211。

    连接上Memcachedserver之后。能够通过命令行对缓存进行操作。

    经常使用的Memcached命令有5种。 
    set 
    add 
    replace 
    get 
    delete

    前三个命令是用于操作存储在 Memcached中的键值对的标准改动命令。它们都非常easy易用,且都使用例如以下所看到的的语法:

    command 

    參数 使用方法 
    key key 用于查找缓存值 
    flags 能够包含键值对的整型參数,客户机使用它存储关于键值对的额外信息 
    expiration time 在缓存中保存键值对的时间长度(以秒为单位,0 表示永远) 
    bytes 在缓存中存储的字节点 
    value 存储的值(始终位于第二行)

    如今。我们来看看这些命令的实际使用。

     
    不管怎样都存储的set 
    set 命令用于向缓存加入新的键值对。

    假设键已经存在,则之前的值将被替换。

    set.PNG

    仅仅有数据不存在时进行加入的add 
    仅当缓存中不存在键时,add 命令才会向缓存中加入一个键值对。假设缓存中已经存在键。则之前的值将仍然保持相同,将获得响应NOT_STORED。

    add.PNG

    仅仅有数据存在时进行替换的replace 
    仅当键已经存在时。replace 命令才会替换缓存中的键。

    假设缓存中不存在键,将获得响应NOT_STORED。

    replace.PNG

    get 
    get 命令用于取得之前加入的键值对相关的值,get命令的key能够表示一个或者多个键。键之间以空格隔开。

    get.PNG

    gets 
    不能顾名思义的觉得get是返回单个key,gets能够查询多个key,gets命令的功能相似于主要的get命令。

    两个命令之间的差异在于,gets返回的信息略微多一些。

    gets.PNG

    能够看到。gets命令比普通的get命令多返回了一个数字(上图中为3和2)。这个数字能够检查数据是否发生改变。当key相应的数据改变时。这个多返回的数字也会改变。

    delete 
    delete 用来删除Memcached中的不论什么现有值,删除已存在的键值和不存在的记录会返回不同的结果。

    delete.PNG

    flush_all 
    这个命令的用处非常easy。它总是执行成功。server会发送OK回应。

    它的效果是使已经存在的缓存项目马上失效(缺省)。flush_all 实际上没有马上释放项目所占用的内存,而是在随后陆续有新的项目被储存时执行(这是由Memcached的懒惰检測和删除机制决定的)。

    flush.PNG

    stats 
    stats 命令的功能正如其名:输出所连接的 Memcached实例的当前统计数据。 
    stats1.PNG 
    stats2.PNG 
    stats3.PNG

    转载自我的技术博客: 
    http://www.cc-lab.cn/memcachedonlinux/ 
    (完)

  • 相关阅读:
    关于iOS开发property with 'retain(or strong)' attribute must be of object type
    机器学习之神经网络
    一些知名的开源社区
    机器学习之正则化
    机器学习之逻辑回归(logistic回归)
    机器学习之正规方程法
    机器学习之线性回归、多项式回归
    机器学习之梯度下降法
    64位windows7下安装python,配置numpy和matplotlib库
    mysql分区查询
  • 原文地址:https://www.cnblogs.com/zhchoutai/p/8308395.html
Copyright © 2011-2022 走看看