一、Redis和Keepalived安装
1、 以下步骤在121和122上均要进行一遍
2、 以root用户登录,
cd /usr/local
2、命令:mkdir ms40 新建ms40目录
3、cd ms40
4、mkdir redis && cd redis && mkdir log && mkdir data 然后切回ms40目录
5、mkdir keepalived
6、上传文件redis-2.6.14.tar.gz至redis目录
上传文件keepalived-1.2.7.tar.gz至keepalived目录
7、安装redis
1)cd redis
2)tar zxvf redis-2.6.14.tar.gz
3)cd redis-2.6.14
4)make
5)cd src
6)cp redis-benchmark redis-cli redis-server /usr/bin/
7)切回至ms40目录
8、安装keepalived
1)cd keepalived
2)tar zxvf keepalived-1.2.7.tar.gz
3)yum install popt-devel
4)yum -y install openssl-devel
5)cd keepalived-1.2.7
6)./configure
7)make && make install
二、Keepalived配置
1、 转移keepalived的配置文件
1) cp /usr/local/etc/rc.d/init.d/keepalived /etc/rc.d/init.d/
2) cp /usr/local/etc/sysconfig/keepalived /etc/sysconfig/
3) mkdir /etc/keepalived
4) cp /usr/local/etc/keepalived/keepalived.conf /etc/keepalived/
5) cp /usr/local/sbin/keepalived /usr/sbin/
三、Mater配置(10.25.174.121)
1、 从附件的Master文件夹中获取scripts文件夹和keepalived.conf覆盖至目录
/etc/keepalived目录下
2、给脚本加上可执行权限:chmod +x /etc/keepalived/scripts/*.sh
3、备份/usr/local/ms40/redis/redis-2.6.14目录下的redis.conf文件
4、从附件的Master文件夹中获取redis.conf文件覆盖至上述目录中
四、Slave配置(10.25.174.122)
1、 从附件的Slave文件夹中获取scripts文件夹和keepalived.conf覆盖至目录
/etc/keepalived目录下
2、给脚本加上可执行权限:chmod +x /etc/keepalived/scripts/*.sh
3、备份/usr/local/ms40/redis/redis-2.6.14目录下的redis.conf文件
4、从附件的Master文件夹中获取redis.conf文件覆盖至上述目录中
五、启动
1、 启动121上的redis
1)cd /
2)cd /usr/local/ms40/redis/redis-2.6.14
3)src/redis-server
2、启动122上的redis
1)cd /
2)cd /usr/local/ms40/redis/redis-2.6.14
3)src/redis-server
3、启动121上的keepalived
1)cd /
2)service keepalived start
4、启动122上的keepalived
1)cd /
2)service keepalived start
六、验证
1、运行-cmd
Ping 10.25.174.200 看是否能够ping通
2、 运行-cmd
telnet 10.25.174.200 6379 是否能通
3、 使用sshclient连接至121或者122,使用root用户
cd /usr/local/ms40/redis/redis-2.6.14
src/redis-cli –h 10.25.174.200
set name “test”
get name
看看结果是否为test
如果是则 del test
六、安装Redis过程中涉及的一些问题
1、GCC的问题
make[2]: cc: Command not found
make[1]: *** [adlist.o] Error 127
make[1]: Leaving directory `/usr/local/redis-2.6.16/src'
make: *** [all] Error 2
原因:没安装gcc,执行命令安装:yum install gcc-c++
2、内存分配器的问题(重视)
make[1]: Entering directory `/usr/local/redis-2.6.16/src'
CC adlist.o
In file included from adlist.c:34:
zmalloc.h:50:31: error: jemalloc/jemalloc.h: No such file or directory
zmalloc.h:55:2: error: #error "Newer version of jemalloc required"
make[1]: *** [adlist.o] Error 1
make[1]: Leaving directory `/usr/local/redis-2.6.16/src'
make: *** [all] Error 2
原因:查看redis的源码 src/zmalloc.c可以看到如下代码:
#if defined(USE_TCMALLOC)
#define malloc(size) tc_malloc(size)
#define calloc(count,size) tc_calloc(count,size)
#define realloc(ptr,size) tc_realloc(ptr,size)
#define free(ptr) tc_free(ptr)
#elif defined(USE_JEMALLOC)
#define malloc(size) je_malloc(size)
#define calloc(count,size) je_calloc(count,size)
#define realloc(ptr,size) je_realloc(ptr,size)
#define free(ptr) je_free(ptr)
可以看到源码中首先会判断系统中是否存在tcmalloc内存分配器,如果没有,则使用jemalloc内存分配器,如果连jemalloc分配器也没有找到,就会报错了。
本次现网部署Redis后,因为没有jemalloc分配器,导致碎片率达到了1.59,redis的内存占用率也就是实际内存占用的1.59倍,这个数据量是非常恐怖的,对内存资源是个相当大的损耗。
在现网环境的linux系统中,可能没有预先安装Jemalloc分配器,需要手动安装。
1、wget http://www.canonware.com/download/jemalloc/jemalloc-3.2.0.tar.bz2
2、tar jxf jemalloc-3.2.0.tar.bz2 (tar.bz2的压缩格式使用 tar jxf 解压)
3、cd jemalloc-3.2.0
4、./configure
5、make && make install
6、ldconfig
过程完成后,在切回到redis-2.6.14目录中,重新执行make命令
当然如果不想使用jemalloc分配器,可以强制使用如下命令来安装redis:
make MALLOC=libc (libc是默认的内存分配器,不过经过验证,碎片率是最高的)
经现网验证:
1) 使用libc内存分配器的话,内存碎片率可以达到1.6左右
2) 但是使用jemalloc,碎片率一般在1.1以内
3) 对于tcmalloc,和jemalloc的结果差不多,但是因为redis暂时还没有集成tcmalloc,所以需要另外来安装,过程详见:
http://blog.nosqlfan.com/html/3490.html
七、安装Keepalived过程中涉及的一些问题
1、虚拟网卡sit0的问题
Keepalived安装完成后,在启动时报了如下的异常:
Oct 18 00:24:43 localhost Keepalived[6866]: Starting VRRP child process, pid=6868
Oct 18 00:24:43 localhost Keepalived_vrrp[6868]: No such interface, sit0
使用ip a命令查看网卡信息如下:
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 16436 qdisc noqueue
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 qlen 1000
link/ether 00:50:56:ba:67:6e brd ff:ff:ff:ff:ff:ff
inet 10.25.174.122/24 brd 10.25.174.255 scope global eth0
inet6 fe80::250:56ff:feba:676e/64 scope link
valid_lft forever preferred_lft forever
3: sit0: <NOARP> mtu 1480 qdisc noop
link/sit 0.0.0.0 brd 0.0.0.0
网上对于sit0的描述如下:
SIT是IPv6-in-IPv4 tunnel interfaces, 这个interfaces(界面或是接口)也称作sitx, sit是"Simple Internet Transition"的缩写. 它可以将IPv6的数据包塞进IPv4, 通过IPv4到达另一个地点.sit0 不能使用在专用的tunnels 上.
一般它没有什么用, 还会减慢上网的速度, 可以修改
在/etc/modprobe.conf文件增加如下两行配置:
alias ipv6 off
alias net-pf-10 off
然后reboot重启服务器
2、nc命令的问题
家里测试环境(79.78、79.79)没有nc命令(类似windows下的telnet)
1) wget http://sourceforge.net/projects/netcat/files/netcat/0.7.1/netcat-0.7.1.tar.gz/download
2) tar zxvf netcat-0.7.1.tar.gz
3) ./configure
4) make && make install
3、检测脚本的问题
因家里在压测的时候,服务器没有nc命令,所以在检测脚本redis_check.sh中使用的是ping命令来检测redis是否还活着。但是因为在大并发情况下,ping命令会被拥堵,由此可能导致redis主备进行切换
原redis_check.sh:
#!/bin/bash
ALIVE=`/usr/bin/redis-cli PING`
if [ "$ALIVE" == "PONG" ]; then
echo $ALIVE
exit 0
else
echo $ALIVE
exit 1
fi
现redis_check.sh:
#!/bin/bash
nc -w 0 127.0.0.1 6379 && exit 0 || exit 1
4、keepalived.conf问题
Keepalived.conf中有运行监测脚本redis_check.sh的配置:
vrrp_script chk_redis {
script "/etc/keepalived/scripts/redis_check.sh"
interval 1
}
变量interval 表示执行监测脚本的时间间隔:1秒执行一次确实没有必要。
5秒执行一次即可。
相关推荐
keepalived+redis 高可用方案 集群环境搭建. 部分来自网上,部分自己的总结. 详细的记录了如何搭建keepalived+redis的环境
keepalived+nginx+tomcat+redis+mysql所需的jdk包,之前csdn不让上传超过200m得只能分开上传。
Keepalived+redis高可用主从,本技术文档主要是Keepalived的配置,redis主从配置可以看我的文章https://blog.csdn.net/qq_41709494/article/details/116382183
NULL 博文链接:https://xticfc.iteye.com/blog/2181407
Linux下搭建Nginx+Keepalived+Redis+Tomcat实现session共享 、负载均衡、高可用
这里配置Keepalived + Nginx + Tomcat + Redis的架构,其中:keepalived用于管理Virtual IP,与nginx一起搭配实现高可用性的反向代理前端;后端使用Tomcat管理web服务,并利用Redis实现session共享。
keepalived+redis&mysql主备高可用配置文件和脚本
keepalived+redis高可用主备配置文件和脚本
keepalived + redis + nginx部署示例 操作系统:Centos7.5 主IP:10.211.55.5 从IP:10.211.55.6 VIP:10.211.55.10 保持安装 yum -y install libnl libnl-devel libnfnetlink-devel openssl-devel net-tools ...
keepalived-1.3.2(126为主,128为从),nginx-1.11.8(126和128),apache-tomcat-8.0.39(126和128),redis-3.2.6(128)
keepalived+nginx+tomcat+redis+mysql所需的包,里面包含了三个tomcat与Redis做session共享的jar,编译安装Mysql所需要Boost库和Cmake的包。
Keepalived+redis+nginx+tomcat7 实现的集群所需要的包、配置、脚本等。 .......................................................................................................................................
亲测,这两个安装包可以完美的结合在一起使用
lvs+Keepalived+nginx高可用负载均衡搭建部署方案
Nginx+KeepAlived+Tomcat负载架构 这个可以实现tomcat集群,并且可以使服务器主备机进行切换。如果其中一台机器当机,会自动切换到另一台机器。客服端感受不到服务器当掉。非常实用。
LVS+Keepalived+MySQL半同步主主复制高可用方案
线上一键部署keepalived+nginx,选择keepalived 版本非常稳定可靠,脚本非常详细!
redis+Keepalived实现Redis高可用性 主要包含两个文件: 1、安装文档 2、各种脚本文件
HAProxy+Keepalived+LVS实现负载平衡高可用集群最佳实践
lvs+keepalived+mha+mysql架构最佳部署手册