redis StackExchange 主备 实现 demo

本文介绍了一种简单实现Redis主备切换的方法,通过StackExchange.Redis库进行操作。当主Redis实例失效时,程序能自动将从库设置为主,并继续提供服务。作者在实验中遇到问题并逐步解决,最后封装成方法,确保特定命令在主库执行,其余可在从库执行。
摘要由CSDN通过智能技术生成

网上关于redis高可用基本都是用redis-sentinel 哨兵 或者 redis cluster 集群来实现, 但是有没有更简单的方式,比如我现在就只有2个redis实例。我试验的结果是我们可用采用主备的方式来实现(我们的实际需求很简单,有2个redis实例分布在不同的计算机,在一个实例down掉后我们的应用程序有继续读写redis,主从配置可用手动修改)。需求很简单, 实现也就很简单。首先下载 https://github.com/StackExchange/StackExchange.Redis 源码。启动StackExchange.Redis-master\Redis Configs里面的主从2个实例,我最终demo的code如下:

 class Program
    {
        static IDatabase database;
        static ConnectionMultiplexer conn;
        static void Main(string[] args)
        {
            ConfigurationOptions option = new ConfigurationOptions() {
                EndPoints =
                            {
                                { "127.0.0.1", 6379 },
                                { "127.0.0.1", 6380 }
                            },
                AllowAdmin =true,                
            };

             conn = ConnectionMultiplexer.Connect(option);
            database = conn.GetDatabase();

            Random rand = new Random();
           

            while (true)
            {
                string val = "gavin_" + rand.Next(1, 999999).ToString();
                TestWriteRead(val);
                Thread.Sleep(100);
            }

        }

        static void TestWriteRead(string value) {
            string key = "gavinteststring";
            try
            {
                database.StringSet(key, value);
                Console.WriteLine($"写入{key}={value}成功");
            }
            catch (Exception ex)
            {
                var points = conn.GetEndPoints();
                foreach (var item in points)
                {
                    var server = conn.GetServer(item);
                    if (server.IsConnected)
                    {
                        server.MakeMaster(ReplicationChangeOptions.All);
                    }
                    else
                    {
                        server.SlaveOf(points[1],CommandFlags.FireAndForget);
                    }
                    
                }
                database.StringSet(key, value);
                Console.WriteLine($"写入{key}={value}成功");
                //Console.WriteLine($"写入{key}={value}失败:"+ex.ToString());
               // Console.ReadKey();
            }
            string temp = string.Empty;
            try
            {
                temp=database.StringGet(key);
                Console.WriteLine($"读取{key}={temp}成功");
            }
            catch (Exception ex)
            {
                Console.WriteLine($"读取{key}失败:" + ex.ToString());
            }
        }
    }

大家请先忽略我catch里面的code,当我把redis的master关闭后,程序报错:

No connection is available to service this operation: SET gavinteststring

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值