一、事务(相对mysql来说简单)

1. 比较

 ①:mysql   ----->start trantation ---->普通sql ------->回滚rollback------>commit

 ②:redis -------> multi-(放入queue队列)-->普通命令----->discard (取消,不是真正的回滚感觉) ---->exec

2. 注

rollback与discard的区别

   如果已经成功执行2条语句,第3条语句出错RollBack后,

      ①:前两条语句影响会消失
      ②:Discard只是结束本次事务(第三条失败,其他两条不影响),前两条语句造成的影响仍然存在 在mutil后面的语句中,语句出错可能有两种情况
1. 语法就有问题,这种exec时,报错,所有语句得不到执行
2. 语法本身没错,但使用对象有问题,比如zadd操作list对象,exec之后,会执行正确的语句,并跳过有不适当的语句 watch key1 key2 ....keyn 监视key有没有变化,如果有变,则事务取消 unwatch 取消所有watch监视

二、 发布订阅

①:publish aa ‘aa’  发布消息 (publish aa ‘aa’)

②:subscribe aa  订阅消息
③:psubscribe aa   订阅消息,模糊匹配(aabb也可以接收到)

三、集群搭建

1. 主从备份,防止主机宕机

2. 读写分离,分担master的任务

3. 任务分离,如从服务分别分担备份工作与计算工作

4.

①:cp redis.conf redis210.conf
②:cp redis.conf redis211.conf

③:pkill -9 redis

④:vim redis.conf   修改配置文件
--slave1配置
pidfile /var/run/redis211.pid
    port 8031
    dbfilename dump211.rdb //快照(很浪费io,所以一台有rdb)
    slaveof localhost 8030 //作为8030的slave,也就是8030端口为master slaveof <masterip> <masterport>
    slave-read-only yes //只读
     --slave2配置
    pidfile /var/run/redis212.pid
    port 8032
    #save 900 1 //注释三个save是为了取消使用rdb
    #save 300 10
    #save 60 3000
    appendonly no //关闭aof(日志持久化)
    slaveof localhost 8030
    --master配置
    #save 900 1 //注释三个save是为了取消使用rdb
    #save 300 10
    #save 60 3000 ⑤:
  ./bin/redis-server redis.conf
  ./bin/redis-server redis211.conf
  ./bin/redis-server redis212.conf ⑥:测试
  ./bin/redis-cli //先链接主服务器
    set title an
  ./bin/redis-cli -p 8031 //链接8031 redis服务器
    get title
    --set pic //因为只读所以报错 ⑦:master设置连接密码:requirepass passwd
  slave设置连接master的密码:masterauth passwd ⑧:auth passwd ⑨:pkill -9 redis 杀掉redis进程 ⑩:bind:可以绑定允许访问数据库的地址,只能绑定一个地址 ⑪ ⑬⑫

5. 主从复制缺陷

  每次slave断开后(无论是主动断开,还是网络故障等)再连接master,都要master全部dump出来rdb,再aof,即同步的过程都要重新执行1遍,所以要记住,多台slave不要一下启动起来,否则master可能IO剧增。

    

redis事务和redis集群的更多相关文章

  1. 分布式缓存技术redis学习系列(四)——redis高级应用(集群搭建、集群分区原理、集群操作)

    本文是redis学习系列的第四篇,前面我们学习了redis的数据结构和一些高级特性,点击下面链接可回看 <详细讲解redis数据结构(内存模型)以及常用命令> <redis高级应用( ...

  2. redis + 主从 + 持久化 + 分片 + 集群 + spring集成

    Redis是一个基于内存的数据库,其不仅读写速度快,每秒可以执行大约110000的写操作,81000的读取操作,而且其支持存储字符串,哈希结构,链表,集合丰富的数据类型.所以得到很多开发者的青睐.加之 ...

  3. 分布式缓存技术redis学习(四)——redis高级应用(集群搭建、集群分区原理、集群操作)

    本文是redis学习系列的第四篇,前面我们学习了redis的数据结构和一些高级特性,点击下面链接可回看 <详细讲解redis数据结构(内存模型)以及常用命令> <redis高级应用( ...

  4. 分布式缓存技术redis系列(四)——redis高级应用(集群搭建、集群分区原理、集群操作)

    本文是redis学习系列的第四篇,前面我们学习了redis的数据结构和一些高级特性,点击下面链接可回看 <详细讲解redis数据结构(内存模型)以及常用命令> <redis高级应用( ...

  5. redis高级应用(集群搭建、集群分区原理、集群操作)

    文章主目录 Redis集群简介 Redis集群搭建 Redis集群分区原理 集群操作 参考文档 本文是redis学习系列的第四篇,前面我们学习了redis的数据结构和一些高级特性,点击下面链接可回看 ...

  6. Shiro经过Redis管理会话实现集群(转载)

    原文:http://www.myexception.cn/software-architecture-design/1815507.html Shiro通过Redis管理会话实现集群 写在前面 1.在 ...

  7. Redis(十)集群:Redis Cluster

    一.数据分布 1.数据分布理论 2.Redis数据分区 Redis Cluser采用虚拟槽分区,所有的键根据哈希函数映射到0~16383整数槽内,计算公式:slot=CRC16(key)&16 ...

  8. 一文掌握Redis的三种集群方案

    在开发测试环境中,我们一般搭建Redis的单实例来应对开发测试需求,但是在生产环境,如果对可用性.可靠性要求较高,则需要引入Redis的集群方案.虽然现在各大云平台有提供缓存服务可以直接使用,但了解一 ...

  9. Redis 3.0 Cluster集群配置

    Redis 3.0 Cluster集群配置 安装环境依赖 安装gcc:yum install gcc 安装zlib:yum install zib 安装ruby:yum install ruby 安装 ...

  10. Redis 3.0.2集群搭建以及相关问题汇总

    Redis3 正式支持了 cluster,是为了解决构建redis集群时的诸多不便 (1)像操作单个redis一样操作key,不用操心key在哪个节点上(2)在线动态添加.删除redis节点,不用停止 ...

随机推荐

  1. 重装window 7系统,从做一个u盘启动盘,到装系统,很不错

    老毛桃U盘启动盘制作工具是现在最流行的U盘装系统和维护电脑的专用工具,一是制作简单,几乎100%支持所有U盘一键制作为启动盘,不必顾虑以前量产U盘考虑专用工具的问题.二是制作后工具功能强大,支持GHO ...

  2. Oracle索引以及索引碎片

    索引,可以增加查询速度,若没有索引,每次查询都必须是全表查询.例如,搜索某个记录时(如name="gdpuzxs")时,需要全表扫描一下,因为不知道有多少个name="g ...

  3. SSO 证书配置

    ssodev.crt为开发环境证书ssotest.crt为测试环境证书 将证书拷贝到目录:{JDK}\jre\lib\security 其中 {JDK} 是实际安装JDK的位置.然后cmd进入命令窗口 ...

  4. JavaWeb -- Struts1 使用示例: 表单校验 防表单重复提交 表单数据封装到实体

    1. struts 工作流程图 超链接 2. 入门案例 struts入门案例: 1.写一个注册页面,把请求交给 struts处理 <form action="${pageContext ...

  5. RabbitMQ初体验

    这里官方使用的Pom是4.0.2版本 <dependencies> <dependency> <groupId>com.rabbitmq</groupId&g ...

  6. NFV及vIMS的部署实施

    随着5G和物联网等领域的快速发展,移动数据业务飞速增长,而传统电信网络基于专用硬件的架构和封闭式的网元,已经成为运营商拓展新业务的严重障碍.NFV能够根据用户和业务需求灵活动态地进行网络资源配置,实现 ...

  7. ImageView显示图像控件

    ImageView显示图像控件 一.简介 1. 2. ImageView,图像视图,直接继承自View类,它的主要功能是用于显示图片,实际上它不仅仅可以用来显示图片,任何Drawable对象都可以使用 ...

  8. android开发环境:使用Android Studio搭建Android集成开发环境(图文教程)

    开发环境情况: 物理机版本:Win 7旗舰版(64位) Java SDK版本:jdk1.8.0_25(64位) Android SDK版本:Android 7.1(API 25) Android St ...

  9. [转]linux将一个服务器上的文件或者文件夹复制到另一台服务器上

    本文转载自<linux 将一个服务器上的文件或者文件夹复制到另一台服务器上>,有时间实践一把 使用scp将一个Linux系统中的文件或文件夹复制到另一台Linux服务器上 复制文件或文件夹 ...

  10. HYSBZ - 2818莫比乌斯反演

    链接 题意很简洁不说了 题解:一开始我想直接暴力,复杂度是O(log(1e7)*sqrt(1e7))算出来是2e9,可能会复杂度爆炸,但是我看时限是10s,直接大力莽了一发暴力,没想到就过了= = 就 ...