Redis的安全性

因为redis速度很快,所以在一台比较好的服务器下,一个外部用户在一秒内可以进行15W次的密码尝试,这意味着你需要设定非常强大的密码来防止暴力破解。

vim编辑redis.conf文件,找到下面进行保存修改

  #requirepass foobared

  requirepass    ****

重启服务器 pkill redis-server

下次登录需要输入密码。

  输入 auth [密码]

  还有一种直接登录的授权方式,   redis-cli -abhz

主从复制

主从复制

  1 Master可以拥有多个slave

  2多个slave可以连接同一个master外,还可以连接其他的salve

  3主从复制不会阻塞master在同步数据时,master可以继续处理client请求

  4提供系统的伸缩性

主从复制过程:

  1slave与master建立连接,发送sync同步命令

  2master会开启一个后台进程,将数据库快照保存到文件中,同时master主进程会开始收集新的写命令并缓存

  3后台完成保存后,就将文件发送给slave

  4slave将此文件保存到硬盘上

主从复制配置

  clone服务器之后修改slave的IP地址

  修改配置文件:/usr/local/redis/etc/redis.conf

  第一步:slaveof<masterip><mastport>

  第二步:masterauth<master-password>

使用info查看role角色即可知道是主服务或从服务

哨兵

有了主从复制的实现以后,我们如果相对主从服务器进行监控,那么在redis2.6以后提供了一个“哨兵”的机制,在2.8之后,哨兵功能开始稳定。

哨兵的含义就是监控redis系统的运行状况。其主要功能有两点:

1 监控主数据库和从数据库是否正常运行。

2 主数据库出现故障时,可以自动将从数据库转换为主数据库,实现自动切换。

实现步骤:在其中一台从服务器配置sentinel.conf

  (1)copy文件sentinel.conf到/usr/local/redis/etc中

  (2)修改sentinel.conf

  sentinel monitor mymaster 192.168.1.174 6379 1#名称、ip、端口、投票选举次数

  sentinel down-after-milliseconds mymaster 5000 #默认1s检测一次,这里配置超时5000毫秒为宕机

  sentinel failover-timeout mymaster 9000000

  sentinel parallel-syncs mymaster 2

  (3)启动sentinel哨兵

  /us/local/redis/bin.redis-server /usr/local/redis/etc/sentinel.conf --sentinel &

  (4)查看哨兵相关信息命令

  /usr/local/redis/bin/redis-cli -h 192.168.1.175 -p 26379 info Sentinel

  (5)关闭主服务器查看集群信息

  /usr/local/redis/bin/redis-cli -h 192.168.1.175 -p 6379 shutdown

持久化机制

redis是一个支持持久化的内存数据库,也就是说redis需要经常将内存中的数据同步到硬盘来保证持久化。

redis持久化的两种方式。

1 snapshotting(快照)默认方式,将内存中以快照的方式写入到二进制文件中,默认为dump.rdb。可以通过配置设置自动做快照持久化的方式。配置redis在n秒内如果超过m个key则修改就自动做快照。

snapshotting 设置:

  save 900 1 #900秒内,如果超过1个key被修改,则发起快照保存

  save 300 10 #300秒内,如果超过10个key被修改,则发起快照保存

2 append-only file(缩写aof) 的方式,(类似于oracle日志)由于快照方式是在一定时间间隔做一次,所以可能发生redis意外down的情况就会丢失最后一次快照后的所有修改的数据,aof比快照方式有更好的持久化,是因为在使用aof时,redis会将每一个收到的写命令都通过write函数追加到命令中,当redis重新启动时,会重新执行文件中保存的写命令来在内存中重建这个数据库的内容。这个文件在bin目录下:

appendonly.aof. aof不是立即写到硬盘上,可以通过配置文件修改强制写到硬盘中。

aof设置:

  appendonly yes //启动aof持久化方式有三种修改方式

  #appengfsync always //收到写命令就立即写入到磁盘,效率最慢,但是保证完全的持久化

  #appengfsync everysec //每秒钟写入磁盘一次,在性能和持久化方面做了折中

  #appengfsync no //完全依赖os 性能最好,持久化没保证

发布与订阅消息

redis提供了简单的发布订阅功能

使用subscribe[频道] 进行订阅监听

使用publish[频道][发布内存] 进行发布消息广播

登录redis客户端,就能发布相应信息。

redis其他相关知识的更多相关文章

  1. redis的相关知识

    1. 依赖包安装 pom.xml 加入: <!-- redis cache related.....start --> <dependency> <groupId> ...

  2. Redis相关知识整理

    Redis相关知识整理 1. Redis和MySQL的区别?a).mysql是关系型数据库,而redis是NOSQL,非关系型数据库.mysql将数据持久化到硬盘,读取数据慢,而redis数据先存储在 ...

  3. Redis的好处知识

    参考文章 http://www.cnblogs.com/wupeiqi/articles/5132791.html 使用Redis有哪些好处? () 速度快,因为数据存在内存中,类似于HashMap, ...

  4. 【Python五篇慢慢弹(5)】类的继承案例解析,python相关知识延伸

    类的继承案例解析,python相关知识延伸 作者:白宁超 2016年10月10日22:36:57 摘要:继<快速上手学python>一文之后,笔者又将python官方文档认真学习下.官方给 ...

  5. 移动WEB像素相关知识

    了解移动web像素的知识,主要是为了切图时心中有数.本文主要围绕一个问题:怎样根据设备厂商提供的屏幕尺寸和物理像素得到我们切图需要的逻辑像素?围绕这个问题以iphone5为例讲解涉及到的web像素相关 ...

  6. listener监听器的相关知识

    从别人的博客上我学习了listener的相关知识现在分享给大家 1.概念: 监听器就是一个实现特定接口的普通java程序,这个程序专门用于监听另一个java对象的方法调用或属性改变,当被监听对象发生上 ...

  7. UIViewController相关知识

    title: UIViewController 相关知识date: 2015-12-13 11:50categories: IOS tags: UIViewController 小小程序猿我的博客:h ...

  8. 【转】java NIO 相关知识

    原文地址:http://www.iteye.com/magazines/132-Java-NIO Java NIO(New IO)是从Java 1.4版本开始引入的一个新的IO API,可以替代标准的 ...

  9. NSString使用stringWithFormat拼接的相关知识

    NSString使用stringWithFormat拼接的相关知识 保留2位小数点 1 2 3 4 //.2代表小数点后面保留2位(2代表保留的数量) NSString *string = [NSSt ...

随机推荐

  1. java中线程池的使用

    public static ExecutorSevice newSingleThreadExecutor() public static ExecutorSevice newFixedThreadPo ...

  2. js 只允许输入数字

    <input id="credit" type="text" class="nummber" onkeyup="value= ...

  3. 机器学习进阶-边缘检测-Canny边缘检测 1.cv2.Canny(进行Canny边缘检测)

    1. cv2.Canny(src, thresh1, thresh2) 进行canny边缘检测 参数说明: src表示输入的图片, thresh1表示最小阈值,thresh2表示最大阈值,用于进一步删 ...

  4. THE BOX MODEL

    Review In this lesson, we covered the four properties of the box model: height and width, padding, b ...

  5. spark Kryo serialization failed: Buffer overflow 错误

    今天在写spark任务的时候遇到这么一个错误,我的spark版本是1.5.1. Exception in thread "main" com.esotericsoftware.kr ...

  6. Servlet基本_Httpリクエスト、レスポンス

    1.リクエスト リクエストは.リクエストライン.メッセージヘッダ.改行.メッセージボディで組まれる. 主なリクエストヘッダは. Accept クライアントが利用可能なデータメディアタイプを指定. Ac ...

  7. Servlet基本_セッション属性

    1.概念セッション: ユーザーごとの状態を保存する仕組みです.セッションID: アプリケーションサーバから一意の識別子が割り当てられ.これをセッションIDと言う. 2.サーブレットAPIサーブレットA ...

  8. python 深拷贝、浅拷贝、引用

    (1)直接赋值,传递对象的引用而已,原始列表改变,被赋值的b也会做相同的改变(2)copy浅拷贝,没有拷贝子对象,所以原始数据改变,子对象会改变(3)深拷贝,包含对象里面的子对象的拷贝,所以原始对象的 ...

  9. mysql 的REPLAYCE语句

      MySQL数据库insert和update语句引:用于操作数据库的SQL一般分为两种,一种是查询语句,也就是我们所说的SELECT语句,另外一种就是更新语句,也叫做数据操作语句.言外之意,就是对数 ...

  10. 14.连接池.md

    目录 连接池定义 常用开源连接池: DBCP: C3P0 连接池定义 使用统一的规范:javax.sql.DataSource实现统一编程 常用开源连接池: DBCP:tomcat C3P0:hibe ...