实验楼:https://www.shiyanlou.com/


以下学习总结主要通过实验楼环境


memcached:高速运行的分布式缓存服务器

特点:
(1)协议简单
(2)基于libevent的事件处理
(3)内置内存存储方式
(4)不互相通信的分布式

适用场景:
(1)网站包含了访问量很大的动态网页,因而数据库的负载将会很高,且大部分数据库请求都是读操作。
(2)数据库服务器的负载比较低,CPU使用率较高;
(3)小型需要共享的数据,如session等临时数据;
(4)缓存一些很小但是被频繁访问的文件。

不适用场景:
(1)缓存对象的大小大于 1 MB, Memcached 本身就不是为了处理庞大的多媒体和巨大的二进制块而设计的,如果你任性,要存这么大的数据,可以自己修改源代码,它是开源的,不过请慎改;
(2)key 的长度大于 250 字符(硬性要求);
(3)环境不允许运行 memcached 服务,如虚拟主机;
(4)应用运行在不安全的环境中,Memcached 未提供任何安全策略,仅仅通过 telnet 就可以访问到 memcached。数据安全越来越重要了,so,请把它放在防火墙后;
(5)业务需要的是持久化数据时请使用数据库。

安装memcached

著名的 linux 系统基本上分为两大类:
(1)RedHat 系列:Redhat、Centos、Fedora 等 其常见的安装包格式 rpm, 安装 rpm 包的命令是“rpm -参数” ,包管理工具 yum。
(2)Debian 系列:Debian、Ubuntu 等 其常见的安装包格式 deb, 安装 deb 包的命令是“dpkg -参数”,包管理工具 apt-get。 本课程环境为 Ubuntu,所以可以下载对应的 deb 包或者直接通过 apt-get 工具安装。这里采用 apt-get 方式安装,最简单。

ubuntu下安装

1、包管理工具
安装:sudo apt-get install memcached
卸载:sudo apt-get --purge autoremove memcached (包括配置文件)

查看是否存在相关文件:sudo find / -name 'memcached'

2、源码安装
(1)查看软件是否安装
dpkg -l | grep 'libevent'
dpkg -l | grep 'memcached'

(2)下载源码
wget http://labfile.oss.aliyuncs.com/libevent-2.0.21-stable.tar.gz
wget http://labfile.oss.aliyuncs.com/memcached-1.4.22.tar.gz

(3)解压
tar -zxvf libevent-2.0.21-stable.tar.gz
tar -zxvf memcached-1.4.22.tar.gz

(4)安装(应用configure)
先安装libevent(因为memcached依赖libevent类)
./configure && make && sudo make install

"&&"符 即 and,顺序执行一系列指令,如果上一步成功,则执行下一步,反之停止之后的指令。
命令详解:
第一步:'./configure',一般源码目录中会有 configure文件,来确定机器是否安装了所需的依赖库,然后配置编译器,告诉系统安装目录等等。用户可以在这一步使用附加选项选择需要编译的模块;
第二步:make,编译源码,打包成“安装包”;
第三步:make install,编译“安装包”,形成可执行的二进制文件,完成安装;

判断libevent是否安装成功 ls -al /usr/lib | grep libevent

启动memcached
memcached -d -m 256 -u root -l localhost -p 11210 -c 256 -P /tmp/memcached.pid

/etc/init.d/memcached start|stop


CentOS 下的安装

安装
  yum -y install memcached

设置为开机启动
  chkconfig --level 2345 memcached on

启动和停止
  /etc/init.d/memcached start|stop

补充:如果安装缺少其他支持,可以:

yum groupinstall "Development Tools"