redis主从 以及认证配置
以前用redis用的很多,各种数据类型用的飞起,算是用得很溜了。不过那都是封装好的方法,自己直接调用。以前的公司比较规范,开发只是开发,很少去做跟运维相关的事情。
换了一份工作,不过这边项目刚开始起步,各种东西还不是很全,需要从头做起。运维什么的都是自己来。这下要考虑的东西就多了。比如说redis主从同步配置,redis认证等等。一路摸索过来,踩了各种坑。这篇文章主要记录redis主从配置,认证机制,以及php操作redis的几个脚本。
1 主从同步
个人认为,redis比mysql简单多了。redis的主从配置真的很简单,配置一句slaveof即可。唯一的坑就在于配置之前,确保主从服务器之间的联通,主从服务器之间redis服务器的联通。ping主从,redis-cli -h 连接测试。如果有不通的地方,配置一下conf文件即可。redis.conf文件也是相当的容易理解的
下面简单的以一主一从进行讲解主从配置。
主 192.168.211.129 从 192.168.211.130
首先确保 主能连自己,主机能连到从机
root@ubuntu:~/ceshi# ping 192.168.211.130
PING 192.168.211.130 (192.168.211.130) 56(84) bytes of data.
64 bytes from 192.168.211.130: icmp_req=1 ttl=64 time=1.87 ms
64 bytes from 192.168.211.130: icmp_req=2 ttl=64 time=0.334 ms
64 bytes from 192.168.211.130: icmp_req=3 ttl=64 time=0.982 ms
^C
--- 192.168.211.130 ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 2002ms
rtt min/avg/max/mdev = 0.334/1.062/1.872/0.631 ms
root@ubuntu:~/ceshi# redis-cli
redis 127.0.0.1:6379>
root@ubuntu:~/ceshi# redis-cli -h 192.168.211.130
redis 192.168.211.130:6379>
也要确保从机能连到主机
一半自己连自己是没有问题的,但是自己一半不允许其他机器连接。
修改redis.conf 的 bind_ip.一般注释掉
#bind 127.0.0.1
这样其他机器也能通过ip+端口访问了
其实配置主从同步真的很简单,redis.conf文件讲解的很清楚,slaveof master即可
我们在从机上配置这句话
slaveof 192.168.211.129 6379
这样在主机上插入数据,从机上也会有数据。
2 连接认证
在redis.conf中,有一个bind项,默认为 127.0.0.1,如果不注释掉这句话,只允许本机连接。注释掉之后,任何机器 通过ip+端口就能连接。这存在安全问题,在这里加上验证机制即可。
redis的验证机制也是相当的简单。在redis.conf中,有一句:
# requirepass foobared
去掉注释,把foobared改成自己的认证密码即可。
这样连接的时候, redis-cli -h x.x..x.x -a passwd 即可,加上 -a 参数认证
如果主机配置了认证机制,在从机的 配置上,也加上认证密码即可。修改从机的配置redis.conf
#masterauth passwd
去掉注释,修改成主机的认证密码即可
3 常见的linux下操作 (修改redis.conf之后重启)
root@ubuntu:~# ps -ef|grep redis
root 1536 1 0 Jun16 ? 00:00:03 /usr/bin/redis-server /etc/redis/redis.conf
root 1724 1623 0 00:28 pts/0 00:00:00 grep --color=auto redis
root@ubuntu:~# kill 1536
root@ubuntu:~# /usr/bin/redis-server /etc/redis/redis.conf
root@ubuntu:~# ps -ef|grep redis
root 1726 1 1 00:29 ? 00:00:00 /usr/bin/redis-server /etc/redis/redis.conf
root 1728 1623 0 00:29 pts/0 00:00:00 grep --color=auto redis
加了认证之后的连接
root@ubuntu:~# redis-cli -h 192.168.211.130 -p 6379 -a foobared
redis 192.168.211.130:6379> keys *
1) "a"
redis 192.168.211.130:6379>
3 php操作redis连接脚本
$redis = new Redis();
$redis->connect(¥redisHost, $redisPort);
$redis->auth('foobared');
$id = $redis->rpop($this->mailList); //右边弹出一个
$redis->close();
这只是一个示例。为了说明redis连接之后的认证方法auth如何使用
redis主从 以及认证配置的更多相关文章
- Redis主从和HA配置
1同步原理 摘自:http://www.cnblogs.com/stephen-liu74/archive/2012/03/30/2364717.html "下面的列表清楚的解释了Redis ...
- Redis主从 部署和配置
目录 一.主从简介 主从介绍 主从原理 二.主从部署 环境介绍 主从配置 临时主从 三.主从测试 一.主从简介 主从介绍 Redis都是主节点.每个从节点只能有一个主节点,而主节点可以同时具有多个从节 ...
- Redis 主从 Replication 的配置,主从复制原理
概述 Redis的replication机制允许slave从master那里通过网络传输拷贝到完整的数据备份.具有以下特点: 异步复制.从2.8版本开始,slave能不时地从master那里获取到数据 ...
- redis主从+哨兵 安装配置二
实验环境: 192.168.2.201 centos7 master sentinel 192.168.2.202 centos7 slave sentinel 192.168.2.203 cen ...
- redis主从+哨兵 安装配置一
一.目的 实现redis的高可用. 二.同步过程 注意:当Master在后台把数据保存到快照文件完成之后,Master会把这个快照文件传送给Slave,而Slave则把内存清空后,加载该文件到内存中: ...
- nopCommerce 3.9 大波浪系列 之 使用Redis主从高可用缓存
一.概述 nop支持Redis作为缓存,Redis出众的性能在企业中得到了广泛的应用.Redis支持主从复制,HA,集群. 一般来说,只有一台Redis是不可行的,原因如下: 单台Redis服务器会发 ...
- Redis主从高可用缓存
nopCommerce 3.9 大波浪系列 之 使用Redis主从高可用缓存 一.概述 nop支持Redis作为缓存,Redis出众的性能在企业中得到了广泛的应用.Redis支持主从复制,HA,集 ...
- Redis哨兵 部署和配置
目录 一.哨兵简介 哨兵介绍 哨兵原理 二.哨兵部署 环境介绍 哨兵配置 三.使用验证 一.哨兵简介 哨兵介绍 Sentinel(哨兵)是用于监控redis集群中Master状态的工具,其已经被集成在 ...
- REDIS主从配置及切换
最近公司项目也用上了.但有个点没有弄很明白. requirepass只是给CLIENT认证用的,还是同时给从REDIS认证用的?(masterauth) 一般的思路是主服务器不开AOF,从服务器打开A ...
随机推荐
- Linux下chkconfig命令详解 这个简单明了啊
chkconfig命令主要用来更新(启动或停止)和查询系统服务的运行级信息.谨记chkconfig不是立即自动禁止或激活一个服务,它只是简单的改变了符号连接. 使用语法:chkconfig [--ad ...
- FIR.im Weekly - 劳动节我们也没有停下来
五一到五四的节假日对勤劳的开发者们似乎是零存在,各种干货好资源也并未因假期的到来而减少,所以这周的 Weekly 依然多产. Swift 样式指南:2015年4月更新 这是 @开发技术前线 收录的由 ...
- Java面试(2)-- Java算数表达式
class Demo02{ public static void main(String[] args){ //算数运算符 +,-,*,/,%,++,-- //例1 int a = 1; int b ...
- NET中Application,Session,Cookie,ViewState,Cache,Hidden 缓存机制 .
Application 1. Application用来保存所有用户共用的信息 2. 在Asp时代,如果要保存的数据在应用程序生存期内不会或者很少发生改变,那么使用Ap ...
- JVM快速学习
最近开始了全面的JAVA生态环境学习,因此,JVM的学习是必不可少的一个环节.和.NET的CLR一样,一起的JAVA应用均跑在JVM虚拟机上,不过相对我们只能干看看的CLR,JVM有很大的灵活性,可以 ...
- Docker 有什么优势?
1.什么是容器? 依托与linux 内核功能的虚拟化技术 2. docker 是什么? 能够把应用程序自动部署到容器的开源引擎 3. docker 跟原有的工具有何区别? 传统的部署模式是:安装(包管 ...
- Linux的学习--crontab
之前了解过一点crontab,前段时间比较闲,就熟悉了一下,今天总结记录一下. crontab命令常见于Unix和类Unix的操作系统之中,用于设置周期性被执行的指令.该命令从标准输入设备读取指令,并 ...
- 帮助文档的制作javadoc
将自己写的工具类Tool的Tool.class文件发送给其他人,其他人只要将该文件设置到classpath路径下,就可以使用该工具类. 但是很遗憾,该类中到底定义了多少个方法,对方却不清楚,因为该类并 ...
- 发表在 Science 上的一种新聚类算法
今年 6 月份,Alex Rodriguez 和 Alessandro Laio 在 Science 上发表了一篇名为<Clustering by fast search and find of ...
- Concise - 面向对象的,一致的前端开发框架
在当今世界,有许多前端开发的框架.那么,为什么还要再造一个框架呢?Concise 建立的目的是使你有很多的开箱即用的选项,让你能够方便的搭建移动友好的网站和 Web 应用程序.另外还包括一个简单的网格 ...