2.1 问题
本案例要求先快速搭建好一台memcached服务器,并对memcached进行简单的增、删、改、查操作:
安装memcached软件,并启动服务
使用telnet测试memcached服务
对memcached进行增、删、改、查等操作
2.2 方案
使用1台RHEL7虚拟机作为memcached服务器(192.168.4.5)。
在RHEL7系统光盘中包含有memcached,因此需要提前配置yum源,即可直接使用yum安装,客户端测试时需要提前安装telnet远程工具。
验证时需要客户端主机安装telnet,远程memcached来验证服务器的功能:
add name 0 180 10 //变量不存在则添加
set name 0 180 10 //添加或替换变量
replace name 0 180 10 //替换
get name //读取变量
delete name //删除变量
flush_all //清空所有
提示:0表示不压缩,180为数据缓存时间,10为需要存储的数据字节数量。
2.3 步骤
实现此案例需要按照如下步骤进行。
步骤一:构建memcached服务
1)使用yum安装软件包memcached
[[email protected] ~]# yum -y install memcached telnet
[[email protected] ~]# rpm -qa memcached
memcached-1.4.15-10.el7_3.1.x86_64
2) memcached配置文件(查看即可,不需要修改)
[[email protected] ~]# vim /usr/lib/systemd/system/memcached.service
ExecStart=/usr/bin/memcached -u $USER -p $PORT -m $CACHESIZE -c $MAXCONN $OPTIONS
[[email protected] ~]# vim /etc/sysconfig/memcached
PORT=“11211”
USER=“memcached”
MAXCONN=“1024”
CACHESIZE=“64”
OPTIONS=""
3)启动服务并查看网络连接状态验证是否开启成功:
ss命令可以查看系统中启动的端口信息,该命令常用选项如下:
-a显示所有端口的信息
-n以数字格式显示端口号
-t显示TCP连接的端口
-u显示UDP连接的端口
-l显示服务正在监听的端口信息,如httpd启动后,会一直监听80端口
-p显示监听端口的服务名称是什么(也就是程序名称)
注意:在RHEL7系统中,使用ss命令可以替代netstat,功能与选项一样。
[[email protected] ~]# systemctl start memcached
[[email protected] ~]# systemctl status memcached
[[email protected] ~]# ss -anptu | grep Memcached
udp UNCONN 0 0 :11211 : users:((“memcached”,pid=12068,fd=28))
udp UNCONN 0 0 :::11211 ::: users:((“memcached”,pid=12068,fd=29))
tcp LISTEN 0 128 :11211 : users:((“memcached”,pid=12068,fd=26))
tcp LISTEN 0 128 :::11211 ::: users:((“memcached”,pid=12068,fd=27))
步骤二:使用telnet访问memcached服务器
1)使用telnet连接服务器测试memcached服务器功能,包括增、删、改、查等操作。
[[email protected] ~]# telnet 192.168.4.5 11211
Trying 192.168.4.5…
……
##提示:0表示不压缩,180为数据缓存时间,3为需要存储的数据字节数量。
set name 0 180 3 //定义变量,变量名称为name
plj //输入变量的值,值为plj
STORED
get name //获取变量的值
VALUE name 0 3 //输出结果
plj
END
##提示:0表示不压缩,180为数据缓存时间,3为需要存储的数据字节数量。
add myname 0 180 10 //新建,myname不存在则添加,存在则报错
set myname 0 180 10 //添加或替换变量
replace myname 0 180 10 //替换,如果myname不存在则报错
get myname //读取变量
delete myname //删除变量
flush_all //清空所有
quit //退出登录
3 案例3:PHP实现session共享
3.1 问题
沿用练习三,通过修改PHP-FPM配置文件,实现session会话共享:
配置PHP使用memcached服务器共享Session信息
客户端访问两台不同的后端Web服务器时,Session 信息一致
3.2 方案
在练习三拓扑的基础上,Nginx服务器除了承担调度器外,还需要担任memcached数据库的角色,并在两台后端LNMP服务器上实现PHP的session会话共享。拓扑结构如图-4所示。
图-4
3.3 步骤
实现此案例需要按照如下步骤进行。
步骤一:为Web服务器安装PHP扩展
1)为web1主机的PHP添加memcache扩展
[[email protected] ~]# yum -y install php-pecl-memcache
[[email protected] ~]# systemctl restart php-fpm
2)为web2主机的PHP添加memcache扩展
[[email protected] ~]# yum -y install php-pecl-memcache
[[email protected] ~]# systemctl restart php-fpm
步骤二:在后端LNMP服务器上部署Session共享
注意:这些操作在两台后端Web服务器上均需要执行,以下操作以Web1(192.168.2.100)服务器为例。
1)修改PHP-FPM配置文件,并重启服务
注意,因为后端两台web服务器(web1,web2)都需要修改配置文件(下面也web1为例)。
[[email protected] ~]# vim /etc/php-fpm.d/www.conf //修改该配置文件的两个参数
//文件的最后2行
修改前效果如下:
php_value[session.save_handler] = files
php_value[session.save_path] = /var/lib/php/session
//原始文件,默认定义Sessoin会话信息本地计算机(默认在/var/lib/php/session)
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
修改后效果如下:
php_value[session.save_handler] = memcache
php_value[session.save_path] = “tcp://192.168.2.5:11211”
//定义Session信息存储在公共的memcached服务器上,主机参数中为memcache(没有d)
//通过path参数定义公共的memcached服务器在哪(服务器的IP和端口)
[[email protected] ~]# systemctl restart php-fpm
步骤三:客户端测试
客户端使用浏览器访问两台不同的Web服务器。
操作步骤参考练习一,最终可以获得相关的Session ID信息。