LVS+KeepAlived:配置高可用集群
说明:
上周使用keepalived实现了mysql主主同步的高可用,借着刚研究了keepalived,顺便把lvs集群搞一下
本文LVS集群采用DR负载调度方式
DR调度方式是性能最好的,但是要求LB负载机与real sever必须在同一物理网段上
参考文档:
lvs集群简介:http://732233048.blog.51cto.com/9323668/1617201
LVS、Nginx和HAProxy负载均衡区别:http://732233048.blog.51cto.com/9323668/1623375
环境:
前段LB | 后端web | 底端共享存储 | vip |
(主)192.168.186.134 | (R1)192.168.186.128 | 192.168.186.131 | 192.168.186.150 |
(备)192.168.186.135 | (R2)192.168.186.129 |
配置步骤:
1、安装依赖包:
yum -y install gcc gcc-c++ make pcre pcre-devel kernel-devel openssl-devel
2、安装keepalived:
在(主)192.168.186.134和(备)192.168.186.135分别进行如下操作:
安装keepalived:
cd /usr/local/src/
wget http://www.keepalived.org/software/keepalived-1.2.15.tar.gz
tar -zxf keepalived-1.2.15.tar.gz
cd keepalived-1.2.15
./configure --prefix=/usr/local/keepalived --with-kernel-dir=/usr/src/kernels/2.6.32-504.16.2.el6.i686/
make
make install
注意:--with-kernel-dir=/usr/src/kernels/2.6.32-504.16.2.el6.i686/ 这个选项一定要加;这个选项并不是把keepalived编译进内核,而是指定使用内核源码中的头文件,即include目录(只有在配置lvs时才用此选项,其他时候不需要)
拷贝文件:
cp -a /usr/local/keepalived/etc/rc.d/init.d/keepalived /etc/init.d/
cp -a /usr/local/keepalived/etc/sysconfig/keepalived /etc/sysconfig/
mkdir /etc/keepalived/
cp -a /usr/local/keepalived/etc/keepalived/keepalived.conf /etc/keepalived/
cp -a /usr/local/keepalived/sbin/keepalived /usr/sbin/
注意:/etc/sysconfig/keepalived 和 /etc/keepalived/keepalived.conf 的路径一定要正确,因为在执行/etc/init.d/keepalived这个启动脚本时,会读取/etc/sysconfig/keepalived 和 /etc/keepalived/keepalived.conf 这两个文件
配置keepalived:
mv /etc/keepalived/keepalived.conf /etc/keepalived/keepalived.conf.old
vi /etc/keepalived/keepalived.conf #主LB
! Configuration File for keepalived global_defs { notification_email { 732233048@qq.com } notification_email_from root@localhost smtp_server 127.0.0.1 smtp_connect_timeout 30 router_id lvs } vrrp_instance VI_1 { state MASTER interface eth0 virtual_router_id 51 priority 150 advert_int 1 #nopreempt authentication { auth_type PASS auth_pass 1111 } virtual_ipaddress { 192.168.186.150 } } virtual_server 192.168.186.150 80 { delay_loop 6 lb_algo wrr lb_kind DR persistence_timeout 300 protocol TCP real_server 192.168.186.128 80 { weight 3 TCP_CHECK { connect_timeout 10 nb_get_retry 3 delay_before_retry 3 } } real_server 192.168.186.129 80 { weight 2 TCP_CHECK { connect_timeout 10 nb_get_retry 3 delay_before_retry 3 } } }
在(备)192.168.186.135,对配置文件做如下修改:
将state MASTER改为state BACKUP
将priority 150改为priority 100
注意:在配置keepalived.conf时,要特别注意配置文件的语法格式,因为keepalived在启动的时候不会去检测配置文件的正确性,即使没有配置文件,keepalived也可以正常启动
注意:persistence_timeout:会话保持时间,单位是秒;
这个选项对动态网页是非常有用的,为集群系统中的session共享提供了一个很好的解决方案;
有了这个会话保持功能,用户的请求会被一直分发到某个服务节点,直到超过这个会话的保持时间;
需要注意的是,这个会话保持时间是最大无响应超时时间,也就是说,用户在操作动态页面时,如果在300秒内没有执行任何操作,那么接下来的操作会被分发到另外的节点,但是如果用户一直在操作动态页面,则不受300秒时间的限制
启动服务:
chkconfig keepalived on
/etc/init.d/keepalived start
查看是否启动:
tail -n 30 /var/log/messages
May 12 06:13:16 scj Keepalived[2986]: Starting VRRP child process, pid=2989
May 12 06:13:16 scj Keepalived_vrrp[2989]: Netlink reflector reports IP 192.168.186.134 added
May 12 06:13:16 scj Keepalived_vrrp[2989]: Netlink reflector reports IP fe80::20c:29ff:fead:145 added
May 12 06:13:16 scj Keepalived_vrrp[2989]: Registering Kernel netlink reflector
May 12 06:13:16 scj Keepalived_vrrp[2989]: Registering Kernel netlink command channel
May 12 06:13:16 scj Keepalived_vrrp[2989]: Registering gratuitous ARP shared channel
May 12 06:13:16 scj Keepalived_vrrp[2989]: Opening file '/etc/keepalived/keepalived.conf'.
May 12 06:13:16 scj Keepalived_vrrp[2989]: Configuration is using : 37233 Bytes
May 12 06:13:16 scj Keepalived_vrrp[2989]: Using LinkWatch kernel netlink reflector...
May 12 06:13:16 scj Keepalived_vrrp[2989]: VRRP_Instance(VI_1) Entering BACKUP STATE
May 12 06:13:16 scj Keepalived_vrrp[2989]: VRRP sockpool: [ifindex(2), proto(112), unicast(0), fd(10,11)]
May 12 06:13:16 scj Keepalived_healthcheckers[2988]: Netlink reflector reports IP 192.168.186.134 added
May 12 06:13:16 scj Keepalived_healthcheckers[2988]: Netlink reflector reports IP fe80::20c:29ff:fead:145 added
May 12 06:13:16 scj Keepalived_healthcheckers[2988]: Registering Kernel netlink reflector
May 12 06:13:16 scj Keepalived_healthcheckers[2988]: Registering Kernel netlink command channel
May 12 06:13:16 scj kernel: IPVS: Registered protocols (TCP, UDP, SCTP, AH, ESP)
May 12 06:13:16 scj kernel: IPVS: Connection hash table configured (size=4096, memory=32Kbytes)
May 12 06:13:16 scj kernel: IPVS: ipvs loaded.
May 12 06:13:16 scj Keepalived_healthcheckers[2988]: Opening file '/etc/keepalived/keepalived.conf'.
May 12 06:13:16 scj Keepalived_healthcheckers[2988]: Configuration is using : 13636 Bytes
May 12 06:13:17 scj Keepalived_healthcheckers[2988]: Using LinkWatch kernel netlink reflector...
May 12 06:13:17 scj Keepalived_healthcheckers[2988]: Activating healthchecker for service [192.168.186.128]:80
May 12 06:13:17 scj Keepalived_healthcheckers[2988]: Activating healthchecker for service [192.168.186.129]:80
May 12 06:13:17 scj kernel: IPVS: [wrr] scheduler registered.
May 12 06:13:20 scj Keepalived_vrrp[2989]: VRRP_Instance(VI_1) Transition to MASTER STATE
May 12 06:13:21 scj Keepalived_vrrp[2989]: VRRP_Instance(VI_1) Entering MASTER STATE
May 12 06:13:21 scj Keepalived_vrrp[2989]: VRRP_Instance(VI_1) setting protocol VIPs.
May 12 06:13:21 scj Keepalived_vrrp[2989]: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth0 for 192.168.186.150
May 12 06:13:21 scj Keepalived_healthcheckers[2988]: Netlink reflector reports IP 192.168.186.150 added
May 12 06:13:26 scj Keepalived_vrrp[2989]: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth0 for 192.168.186.150
3、安装IPVS:
在(主)192.168.186.134和(备)192.168.186.135分别进行以下操作:
安装依赖包:
yum -y install popt popt-devel libnl libnl-devel popt-static
安装IPVS:
cd /usr/local/src/
wget http://www.linuxvirtualserver.org/software/kernel-2.6/ipvsadm-1.26.tar.gz
tar -zxf ipvsadm-1.26.tar.gz
cd ipvsadm-1.26
make
make install
ipvsadm --help #若有帮助提示则表示安装成功
4、 Real Server配置:
注意:每台real server都要进行以下操作:
本文采用的是DR负载方式,用户的请求到达real server后,real server处理完数据后是直接返回给用户的,不再经过LB负载机,因此,需要在每台real server上都绑定一个vip
vip绑定在lo接口
vi /etc/init.d/rscreatevip.sh
#!/bin/bash #real server create vip VIP=192.168.186.150 #./etc/rc.d/init.d/functions case $1 in start) echo "real server create vip" /sbin/ifconfig lo:0 $VIP broadcast $VIP netmask 255.255.255.255 up echo 1 > /proc/sys/net/ipv4/conf/lo/arp_ignore echo 2 > /proc/sys/net/ipv4/conf/lo/arp_announce echo 1 > /proc/sys/net/ipv4/conf/all/arp_ignore echo 2 > /proc/sys/net/ipv4/conf/all/arp_announce ;; stop) /sbin/ifconfig lo:0 down echo "real server remove vip" echo 0 > /proc/sys/net/ipv4/conf/lo/arp_ignore echo 0 > /proc/sys/net/ipv4/conf/lo/arp_announce echo 0 > /proc/sys/net/ipv4/conf/all/arp_ignore echo 0 > /proc/sys/net/ipv4/conf/all/arp_announce ;; *) echo "usage: (start|stop)" exit 1 esac
chmod 755 /etc/init.d/rscreatevip.sh #加执行权限
/etc/init.d/rscreatevip.sh start
echo "/etc/init.d/rscreatevip.sh start" >> /etc/rc.d/rc.local #设置开机自动启动
5、常用命令:
在LB负载机上执行以下命令:
ipvsadm -ln #查看监控的real server 有哪些
IP Virtual Server version 1.2.1 (size=4096)
Prot LocalAddress:Port Scheduler Flags
-> RemoteAddress:Port Forward Weight ActiveConn InActConn
TCP 192.168.186.150:80 rr persistent 5
-> 192.168.186.128:80 Route 2 0 0
-> 192.168.186.129:80 Route 3 0 0
ip addr #查看vip绑定在哪台LB机
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue state UNKNOWN
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
2: eth0: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UNKNOWN qlen 1000
link/ether 00:0c:29:ad:01:45 brd ff:ff:ff:ff:ff:ff
inet 192.168.186.134/24 brd 192.168.186.255 scope global eth0
inet 192.168.186.150/32 scope global eth0
inet6 fe80::20c:29ff:fead:145/64 scope link
valid_lft forever preferred_lft forever
6、测试:
keepalived主备之间的切换:
在(主)192.168.186.134 执行 stop:
/etc/init.d/keepalived stop
查看(主)192.168.186.134 日志:
tail -f /var/log/messages
May 12 09:51:01 scj Keepalived[2986]: Stopping Keepalived v1.2.15 (05/12,2015)
May 12 09:51:01 scj Keepalived_vrrp[2989]: VRRP_Instance(VI_1) sending 0 priority
May 12 09:51:01 scj Keepalived_vrrp[2989]: VRRP_Instance(VI_1) removing protocol VIPs.
May 12 09:51:01 scj Keepalived_healthcheckers[2988]: Netlink reflector reports IP 192.168.186.150 removed
May 12 09:51:01 scj Keepalived_healthcheckers[2988]: Removing service [192.168.186.128]:80 from VS [192.168.186.150]:80
May 12 09:51:01 scj Keepalived_healthcheckers[2988]: Removing service [192.168.186.129]:80 from VS [192.168.186.150]:80
查看(备)192.168.186.135 日志:
tail -f /var/log/messages
May 12 09:51:01 scj Keepalived_vrrp[2854]: VRRP_Instance(VI_1) Transition to MASTER STATE
May 12 09:51:02 scj Keepalived_vrrp[2854]: VRRP_Instance(VI_1) Entering MASTER STATE
May 12 09:51:02 scj Keepalived_vrrp[2854]: VRRP_Instance(VI_1) setting protocol VIPs.
May 12 09:51:02 scj Keepalived_healthcheckers[2853]: Netlink reflector reports IP 192.168.186.150 added
May 12 09:51:02 scj Keepalived_vrrp[2854]: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth0 for 192.168.186.150
May 12 09:51:07 scj Keepalived_vrrp[2854]: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth0 for 192.168.186.150
在(主)192.168.186.134 执行 start:
查看(主)192.168.186.134 日志:
tail -f /var/log/messages
May 12 09:51:46 scj Keepalived[3588]: Starting Keepalived v1.2.15 (05/12,2015)
May 12 09:51:46 scj Keepalived[3589]: Starting Healthcheck child process, pid=3591
May 12 09:51:46 scj Keepalived[3589]: Starting VRRP child process, pid=3592
May 12 09:51:46 scj Keepalived_vrrp[3592]: Netlink reflector reports IP 192.168.186.134 added
May 12 09:51:46 scj Keepalived_vrrp[3592]: Netlink reflector reports IP fe80::20c:29ff:fead:145 added
May 12 09:51:46 scj Keepalived_vrrp[3592]: Registering Kernel netlink reflector
May 12 09:51:46 scj Keepalived_vrrp[3592]: Registering Kernel netlink command channel
May 12 09:51:46 scj Keepalived_vrrp[3592]: Registering gratuitous ARP shared channel
May 12 09:51:46 scj Keepalived_healthcheckers[3591]: Netlink reflector reports IP 192.168.186.134 added
May 12 09:51:46 scj Keepalived_healthcheckers[3591]: Netlink reflector reports IP fe80::20c:29ff:fead:145 added
May 12 09:51:46 scj Keepalived_healthcheckers[3591]: Registering Kernel netlink reflector
May 12 09:51:46 scj Keepalived_healthcheckers[3591]: Registering Kernel netlink command channel
May 12 09:51:46 scj Keepalived_vrrp[3592]: Opening file '/etc/keepalived/keepalived.conf'.
May 12 09:51:46 scj Keepalived_vrrp[3592]: Configuration is using : 37233 Bytes
May 12 09:51:46 scj Keepalived_vrrp[3592]: Using LinkWatch kernel netlink reflector...
May 12 09:51:46 scj Keepalived_vrrp[3592]: VRRP_Instance(VI_1) Entering BACKUP STATE
May 12 09:51:46 scj Keepalived_vrrp[3592]: VRRP sockpool: [ifindex(2), proto(112), unicast(0), fd(10,11)]
May 12 09:51:47 scj Keepalived_vrrp[3592]: VRRP_Instance(VI_1) forcing a new MASTER election
May 12 09:51:47 scj Keepalived_vrrp[3592]: VRRP_Instance(VI_1) forcing a new MASTER election
May 12 09:51:48 scj Keepalived_vrrp[3592]: VRRP_Instance(VI_1) Transition to MASTER STATE
May 12 09:51:48 scj Keepalived_healthcheckers[3591]: Opening file '/etc/keepalived/keepalived.conf'.
May 12 09:51:48 scj Keepalived_healthcheckers[3591]: Configuration is using : 13636 Bytes
May 12 09:51:48 scj Keepalived_healthcheckers[3591]: Using LinkWatch kernel netlink reflector...
May 12 09:51:48 scj Keepalived_healthcheckers[3591]: Activating healthchecker for service [192.168.186.128]:80
May 12 09:51:48 scj Keepalived_healthcheckers[3591]: Activating healthchecker for service [192.168.186.129]:80
May 12 09:51:49 scj Keepalived_vrrp[3592]: VRRP_Instance(VI_1) Entering MASTER STATE
May 12 09:51:49 scj Keepalived_vrrp[3592]: VRRP_Instance(VI_1) setting protocol VIPs.
May 12 09:51:49 scj Keepalived_vrrp[3592]: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth0 for 192.168.186.150
May 12 09:51:49 scj Keepalived_healthcheckers[3591]: Netlink reflector reports IP 192.168.186.150 added
May 12 09:51:54 scj Keepalived_vrrp[3592]: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth0 for 192.168.186.150
May 12 09:52:22 scj dhclient[1002]: DHCPREQUEST on eth0 to 192.168.186.254 port 67 (xid=0x5c3132b)
May 12 09:52:22 scj dhclient[1002]: DHCPACK from 192.168.186.254 (xid=0x5c3132b)
May 12 09:52:24 scj dhclient[1002]: bound to 192.168.186.134 -- renewal in 770 seconds.
查看(备)192.168.186.135 日志:
tail -f /var/log/messages
May 12 09:51:46 scj Keepalived_vrrp[2854]: VRRP_Instance(VI_1) Received higher prio advert
May 12 09:51:46 scj Keepalived_vrrp[2854]: VRRP_Instance(VI_1) Entering BACKUP STATE
May 12 09:51:46 scj Keepalived_vrrp[2854]: VRRP_Instance(VI_1) removing protocol VIPs.
May 12 09:51:46 scj Keepalived_healthcheckers[2853]: Netlink reflector reports IP 192.168.186.150 removed
May 12 09:54:00 scj dhclient[1009]: DHCPREQUEST on eth0 to 192.168.186.254 port 67 (xid=0x1e01f7ac)
May 12 09:54:00 scj dhclient[1009]: DHCPACK from 192.168.186.254 (xid=0x1e01f7ac)
May 12 09:54:02 scj dhclient[1009]: bound to 192.168.186.135 -- renewal in 785 seconds.
负载均衡测试:
(R1)192.168.186.128:
在网站根目录,如:/opt/nginx/www/www.scj.com/ 下,创建一个index.html文件
echo "server 128" > index.html
(R2)192.168.186.129:
在网站根目录,如:/opt/nginx/www/www.scj.com/ 下,创建一个index.html文件
echo "server 129" > index.html
访问192.168.186.150,多次刷新,看是否轮询出现"server 128"和"server 129"
注意:在测试的时候,每次要等300秒再刷新,才会出现轮询,由persistence_timeout这个参数控制,可能需要多等一会,只要是出现轮询就是正常的
real server故障检测:
将(R1)192.168.186.128的httpd服务停掉:
/usr/local/nginx/sbin/nginx -s stop
查看(主)192.168.186.134的日志:
tail -f /var/log/messages
May 12 12:12:23 scj Keepalived_healthcheckers[3803]: TCP connection to [192.168.186.128]:80 failed !!!
May 12 12:12:23 scj Keepalived_healthcheckers[3803]: Removing service [192.168.186.128]:80 from VS [192.168.186.150]:80
May 12 12:12:23 scj Keepalived_healthcheckers[3803]: Remote SMTP server [127.0.0.1]:25 connected.
May 12 12:12:23 scj Keepalived_healthcheckers[3803]: SMTP alert successfully sent.
将(R1)192.168.186.128的httpd服务重新起来:
/usr/local/nginx/sbin/nginx
查看(主)192.168.186.134的日志:
tail -f /var/log/messages
May 12 12:14:59 scj Keepalived_healthcheckers[3803]: TCP connection to [192.168.186.128]:80 success.
May 12 12:14:59 scj Keepalived_healthcheckers[3803]: Adding service [192.168.186.128]:80 to VS [192.168.186.150]:80
May 12 12:14:59 scj Keepalived_healthcheckers[3803]: Remote SMTP server [127.0.0.1]:25 connected.
May 12 12:14:59 scj Keepalived_healthcheckers[3803]: SMTP alert successfully sent.
7、共享存储配置:
在192.168.186.131进行以下下操作:
yum -y install nfs-utils rpcbind
mkdir -p /data/www/ #创建存储目录
cd /data/www/
vi /etc/exports
/data/www/ 192.168.186.0/24(rw,async,no_root_squash)
chkconfig nfs on
chkconfig rpcbind on
/etc/init.d/rpcbind start #一定要先启动rpcbind
/etc/init.d/nfs start
在每台real server进行以下操作:
yum -y install nfs-utils
showmount -e 192.168.186.131 #查看共享的目录有哪些
vi /etc/fstab #设置开机自动挂载
添加以下行:
192.168.186.131:/data/www /opt/nginx/www/www.scj.com nfs defaults 0 0
mount -a #这个命令很重要,测试是否成功挂载
df -h #查看挂载情况
Filesystem Size Used Avail Use% Mounted on
/dev/mapper/VolGroup-lv_root
19G 6.1G 12G 36% /
tmpfs 58M 0 58M 0% /dev/shm
/dev/sda1 485M 30M 430M 7% /boot
192.168.186.131:/data/www
19G 3.0G 15G 18% /opt/nginx/www/www.scj.com
8、memcached实现session共享:
由于机器数量有限,先临时使用192.168.186.131作为memcached服务器
在192.168.186.131安装配置memcached:
安装依赖包libevent:
cd /usr/local/src/
wget http://downloads.sourceforge.net/levent/libevent-2.0.22-stable.tar.gz
tar -zxf libevent-2.0.22-stable.tar.gz
cd libevent-2.0.22-stable
./configure --prefix=/usr
make
make install
安装memcached:
cd /usr/local/src/
wget http://www.memcached.org/files/memcached-1.4.22.tar.gz
tar -zxf memcached-1.4.22.tar.gz
cd memcached-1.4.22
./configure --prefix=/usr/local/memcached --with-libevent=/usr
make
make install
注意:默认memcached单个进程只支持到2G内存,需要更大内存支持的话,需要打开64位支持,编译的时候加参数:--enable-64bit
groupadd memcached
useradd -g memcached memcached #创建memcached账号
mkdir -p /var/run/memcached/
chown -R memcached.memcached /var/run/memcached/
/usr/local/memcached/bin/memcached -u memcached -m 1024 -c 100 -l 192.168.186.131 -p 11211 -P /var/run/memcached/memcached.pid -d #启动memcached
注意:
-p 监听tcp协议的监听端口
-T 监听UDP协议id监听端口默认都是11211
-s 如果只在本地通信那么可以将其监听在某个套接字上,比如mysql.scok 能够利用共享内存方式进行通信的
-c 最大并发连接数
-l 监听的地址,如果服务器有多块网卡,那么用-l来指定监听的某个网卡上
-d 放在后台运行
-r 设定最大内核大小限制
-u 以某个用户身份运行
-m 以兆为单位指定memcached最大内存可用空间
-t 用于处理入站请求最大的线程数,仅在memcached编译时开启了支持线程才有效,而linux对线程支持是非常有限的,所以不用关心了
-f 设定slab定义预先分配内存空间大小固定的块时使用的增长因子
-n 最小的存储单位是多大,默认是48字节,单位是字节
-P 指定pid文件
-L 视图使用最多的内存空间
-S 启用SSL认证功能
echo "/usr/local/memcached/bin/memcached -u memcached -m 1024 -c 100 -l 192.168.186.131 -p 11211 -P /var/run/memcached/memcached.pid -d" >> /etc/rc.d/rc.local #设置开机自动启动
[root@scj run]# cat /var/run/memcached/memcached.pid #查看进程号
# killall memcached 关闭memcached服务
在每台real server安装php的memcache扩展:
注意:php的扩展包括memcache扩展和memcached扩展
memcached扩展需要先安装依赖包:libmemcached
这里采用的是memcache扩展,不需要安装依赖包
只有安装php的memcache扩展,php才可以去访问131的memcached服务
cd /usr/local/src/
wget http://pecl.php.net/get/memcache-2.2.7.tgz
tar -zxf memcache-2.2.7.tgz
cd memcache-2.2.7
/usr/local/php/bin/phpize #可以用find / -name phpize 查找路径
./configure --enable-memcache --with-php-config=/usr/local/php/bin/php-config
make
make install
注意:在执行make install时,若没有出错,则会输出:
Installing shared extensions: /usr/local/php/lib/php/extensions/no-debug-non-zts-20121212/
把这个路径记录下来,待会还会用到
vi /usr/local/php/etc/php.ini #修改配置文件
找到 extension_dir ,在相应的位置添加以下行:
extension_dir = "/usr/local/php/lib/php/extensions/no-debug-non-zts-20121212/" extension = memcache.so session.cookie_lifetime = 86400 session.gc_maxlifetime = 86400 session.save_handler = memcache session.save_path = "tcp://192.168.186.131:11211" ; session.save_path = "tcp://192.168.186.131:11211,tcp://192.168.xxx.xxx:11211"
[root@scj ~]# ps -ef | grep php #找到php的主进程号
root 12139 1 0 05:46 ? 00:00:00 php-fpm: master process (/usr/local/php/etc/php-fpm.conf)
nobody 12140 12139 0 05:46 ? 00:00:00 php-fpm: pool www
nobody 12141 12139 0 05:46 ? 00:00:00 php-fpm: pool www
nobody 12142 12139 0 05:46 ? 00:00:00 php-fpm: pool www
nobody 12143 12139 0 05:46 ? 00:00:00 php-fpm: pool www
nobody 12144 12139 0 05:46 ? 00:00:00 php-fpm: pool www
nobody 12145 12139 0 05:46 ? 00:00:00 php-fpm: pool www
nobody 12146 12139 0 05:46 ? 00:00:00 php-fpm: pool www
nobody 12147 12139 0 05:46 ? 00:00:00 php-fpm: pool www
nobody 12148 12139 0 05:46 ? 00:00:00 php-fpm: pool www
nobody 12149 12139 0 05:46 ? 00:00:00 php-fpm: pool www
root 12160 1869 0 05:47 pts/0 00:00:00 grep php
kill -SIGUSR2 12139 #重新启动php(类似reload)
访问phpinfo();可以看到如下图:
对192.168.186.131的memcached服务进行测试:
telnet 192.168.186.131 11211 #连接memcacehd的11211端口
Trying 192.168.186.131...
Connected to 192.168.186.131.
Escape character is '^]'.
set test 0 0 10 #设置test变量,变量的值为10个字节
test_value #存入test变量的值,10个字节
STORED
get test #获取test的值
VALUE test 0 10
test_value
END
quit #退出
Connection closed by foreign host.
对real server的php的memcache扩展进行测试:
在随便一台real server进行以下操作:
vi test.php #创建一个php文件
<?php $mem = new Memcache; $mem->connect('192.168.186.131',11211); $mem->set('test','hello world!',0,12); $val = $mem->get('test'); echo $val; ?>
访问192.168.186.150/test.php,出现如下: