业务迁移---redis
以前也没怎么搞过redis 只知道他是一个nosql数据库很强大,这次迁移用到了~ 正好熟练一下并记录过程,还挺繁琐。。
记录一下在学习中的几个问题,总结加深一下印象,有可能会漏掉或者有误差的地方~~~
#############################################
Redis 是一个Nosql数据库
redis.cn 中文官网
redis 编译安装依赖gcc C程序与原的编译器,redis是c语言编写的。
make 报错缺少gcc的话安装gcc, yum install gcc
make 报错jemalloc/jemalloc.h:没有那个文件或者目录,运行make distclean 之后在make
redis 5大数据类型 string字符串 HASH 哈希 LIST 列表 SET 集合 ZSET有序集合
##############################################
Redis持久化是什么?
是RDB和AOF的两种备份方式
Redis备份方法?区别在哪?
两种备份方法: 1.rdb文件备份 2.aof文件备份 区别: RDB文件是系统默认开启的, 优点:以文件的形式存储到硬盘,根据写入的次数和和时间策略来触发备份,适合大文件的备份迁移较快的恢复大量的数据;
缺点:紧急断电或故障时有丢少量数据风险,完整性要求较高的文件备份不建议使用rdb方式。
Aof文件备份默认不开启,
优点:时时备份,AOF持久化以日志的形式记录服务器所处理的每一个写、删除操作,查询操作不会记录,以文本的方式记录,可以打开文件看到详细的操作记录。
缺点:因为是时时备份,会对磁盘时时写入,影响磁盘IO性能。
几种工作模式?
1.单机 2.分片 3.集群
主从复制的几种模式: 4中模式 1.一主二从 2.薪火相连 3.反客为主 4.哨兵模式 (目前比较流行)
迁移流程:
拷贝备份文件到新的redis服务器上
我用的rdb备份模式,scp dump.rdb到新的redis的服务器
安装Redis服务
yum install redis php-pecl-redis.x86_64 php-phpiredis.x86_64 php-nrk-Predis.noarch #yum 安装
配置redis.conf
里面配置太多了,我只更改了几个地方:
1.Redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程 daemonize no #如果不想起服务的时候卡死在那最好先改为yes。。
2.rdb备份是系统默认开启的,但是他的备份文件的路径需要改一下找个大点的磁盘存储。。 dir /test/redis
3.访问权限,默认是127.0.0.1本机访问,我这边给他放开所有主机的权限,因为连的web有点多。。bind 0.0.0.0 ################################## NETWORK ##################################### # By default, if no "bind" configuration directive is specified, Redis listens # for connections from all the network interfaces available on the server. # It is possible to listen to just one or multiple selected interfaces using # the "bind" configuration directive, followed by one or more IP addresses. # # Examples: # # bind 192.168.1.100 10.0.0.1 # bind 127.0.0.1 ::1 bind 0.0.0.0
4.生产模式下需要配置redis密码,否则很危险,默认不配置 requirepass "myPasswOrd"
启动Redis
redis-server /etc/redis.conf
############
还有一个参数我目前没设置,因为可能性能要求还没那么高,但是非常重要,记录一下!
maxmemory 值的设置限制redis使用的内存大小一般都设置总内存的4/3,
maxmemory在64位操作系统中默认不限制,也就是=0,在32位系统默认是3G,这个根据自己情况更改吧。。
提这个的主要目的就是一旦开启了maxmemory的大小限制,就一定要给一个缓存策略,帮他来消化限制之外的set怎么处理,是抛弃?是腾空间?怎么腾?所以就有了这几个选项
noeviction就不建议选了,allkeys-lru可以在迷茫的时候选择试试~ 就理解这么多。。。
noeviction:当内存使用达到阈值的时候,所有引起申请内存的命令会报错 allkeys-lru:在主键空间中,优先移除最近未使用的key。 volatile-lru:在设置了过期时间的键空间中,优先移除最近未使用的key。 allkeys-random:在主键空间中,随机移除某个key。 volatile-random:在设置了过期时间的键空间中,随机移除某个key。 volatile-ttl:在设置了过期时间的键空间中,具有更早过期时间的key优先移除。
############
__NOLAYOUT__}
:(
Class 'Redis' not found
错误位置
FILE: /letv/www/hotel/Hoteltest/Think
错误摘记:
启动后页面打开报错,因为我使用的时SLB负载均衡,登陆网站时输入验证码时好时坏,因为时轮询的那肯定有一台有问题。
【排查思路】
1.tail -f /var/log/nginx/access.log 看一下Nginx日志,抓到了原来其中一台报错500.。。。
2.为什么会报错500呢,我测试了一下redis的连接性,没有问题应该不是权限问题。。
3.页面F12查看错误详情"Class 'Redis' not found",浏览器很友好的告诉我错误提示了。
4.通过博客查看结果时: 有的说没安装redis扩展导致的,还有一种可能就是你php和web 没有加载正确。。
【解决】
1.先将报错机器的php全部卸载。。
2.看一下正常机器安装的扩展包
[root@iz8vbilqy0q9v8tds55bqyz Hoteltest]# yum list installed|grep php|awk -F ' ' '{print $1}'|xargs php-channel-nrk.noarch php-cli.x86_64 php-common.x86_64 php-fpm.x86_64 php-gd.x86_64 php-mysql.x86_64 php-nrk-Predis.noarch \
php-pdo.x86_64 php-pear.noarch php-pecl-igbinary.x86_64 php-pecl-redis.x86_64 php-phpiredis.x86_64 php-process.x86_64 php-xml.x86_64
yum install php-channel-nrk.noarch php-cli.x86_64 php-common.x86_64 php-fpm.x86_64 php-gd.x86_64 php-mysql.x86_64 \
php-nrk-Predis.noarch php-pdo.x86_64 php-pear.noarch php-pecl-igbinary.x86_64 php-pecl-redis.x86_64 php-phpiredis.x86_64 php-process.x86_64 php-xml.x86_64
安装重启,解决。。
错误摘记:
在一次迁移中,更换了redis.conf 中的密码,导致了主战登录页面验证码无法通过验证,一直报错~~ 将密码改回即解决,目前还不知道什么原因!!!