【Redis】集群NetCore实战

【Redis】集群NetCore实战介绍NetCore如何使用Redis集群

【Redis】集群NetCore实战

环境准备

1. Redis集群(Windows集群搭建

启动Redis集群,给每个节点加上Title

start "Redis - 6379" /min redis-server.exe redis.6379.conf
start "Redis - 6380" /min redis-server.exe redis.6380.conf
start "Redis - 6381" /min redis-server.exe redis.6381.conf
start "Redis - 6382" /min redis-server.exe redis.6382.conf
start "Redis - 6383" /min redis-server.exe redis.6383.conf
start "Redis - 6384" /min redis-server.exe redis.6384.conf

代码100分

2. 安装StackExchange.Redis包

代码100分dotnet add package StackExchange.Redis

 

连接Redis

var configString = "127.0.0.1:6379";
var options = ConfigurationOptions.Parse(configString);
options.ReconnectRetryPolicy = new ExponentialRetry(5000);
var client = ConnectionMultiplexer.Connect(options);

这里只需要提供一个节点就能访问整个集群

ConnectionMultiplexer 连接Redis可以使用ConfigurationOptions,或者直接字符串初始化(里面实现也是调用ConfigurationOptions.Parse转换)

这里要说一下是他的重连重试机制,在第一次创建连接的时候,StackExchange.Redis会创建一个心跳检测

代码100分internal static IDisposable Create(ConnectionMultiplexer connection)
{
    var token = new TimerToken(connection);
    var timer = new Timer(Heartbeat, token, MillisecondsPerHeartbeat, MillisecondsPerHeartbeat);
    token.SetTimer(timer);
    return timer;
}

使用System.Threading.Timer每秒钟检查一次。

StackExchange.Redis 实现两种重试策略,当然我们也可以实现自己的重现策略,实现IReconnectRetryPolicy接口

  •  ExponentialRetry(指数)

   根据指定时间,根据重试次数不断增大随机数范围

  • LinearRetry(线性)

   根据指定时间固定时间间隔重试

常用数据结构操作

字符串(String)操作

 

static void RedisStringOperation(ConnectionMultiplexer client)
{
    var db = client.GetDatabase();

    //单个Key操作
    db.StringSet("Key", "Wilson");
    Console.WriteLine($"Get Key : {db.StringGet("Key")}");

    db.StringSet("Nums", 1);
    db.StringIncrement("Nums");
    Console.WriteLine($"Get Nums : {db.StringGet("Nums")}");

    db.StringDecrement("Nums");
    Console.WriteLine($"Get Nums : {db.StringGet("Nums")}");

    //多个Key操作
    db.StringSet(new KeyValuePair<RedisKey, RedisValue>[]
    {
        new KeyValuePair<RedisKey, RedisValue>("{user}Name","Wilson"),
        new KeyValuePair<RedisKey, RedisValue>("{user}Age",30)
    });

    foreach (var value in db.StringGet(new RedisKey[] { "{user}Name", "{user}Age" }))
    {
        Console.WriteLine($"{value}");
    }
}

 

哈希(Hash)操作

 

static void RedisHashOperation(ConnectionMultiplexer client)
{
    var db = client.GetDatabase();

    db.HashSet("person", "name", "Wilson");
    Console.WriteLine(db.HashGet("person", "name"));

    db.HashSet("person", new HashEntry[]
    {
        new HashEntry("name","Wilson"),
        new HashEntry("sex",1)
    });
    Console.WriteLine(string.Join("
", db.HashGet("person", new RedisValue[] { "name", "sex" })));

    Console.WriteLine(string.Join("
", db.HashGetAll("person")));
}

 

列表(List) 操作

 

static void RedisListOperation(ConnectionMultiplexer client)
{
    var db = client.GetDatabase();

    db.ListLeftPush("list", 100);
    db.ListLeftPush("list", 200);
    db.ListLeftPush("list", 300);
    db.ListRightPush("list", 400);
    db.ListRightPush("list", 500);

    Console.WriteLine(db.ListLeftPop("list"));
    Console.WriteLine(db.ListRightPop("list"));
    Console.WriteLine(string.Join("	", db.ListRange("list", 0, 2)));
    Console.WriteLine(db.ListLength("list"));
}

 

集合(Set)

 

static void RedisSetOperation(ConnectionMultiplexer client)
{
    var db = client.GetDatabase();

    db.SetAdd("user", "Wilson");
    db.SetAdd("user", "Wilson");
    db.SetAdd("user", "Alice");

    Console.WriteLine(db.SetLength("user"));
    Console.WriteLine(db.SetPop("user"));
    Console.WriteLine(string.Join("
", db.SetMembers("user")));
}

 

有序集合(Sorted Set)

 

static void RedisSortedSetOperation(ConnectionMultiplexer client)
{
    var db = client.GetDatabase();

    db.KeyDelete("user");

    db.SortedSetAdd("user", "Wilson", 90);
    db.SortedSetAdd("user", "Alice", 85);
    db.SortedSetAdd("user", "Trenary", 12);
    db.SortedSetAdd("user", "Nixon", 30);

    Console.WriteLine(db.SortedSetLength("user"));
    Console.WriteLine(db.SortedSetRemove("user", "Wilson"));
    Console.WriteLine(string.Join("
", db.SortedSetRangeByRank("user", 0, 2)));
}

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
转载请注明出处: https://daima100.com/9078.html

(0)
上一篇 2023-02-16
下一篇 2023-02-16

相关推荐

  • 什么是脏读,不可重复读,幻读_什么是脏读,不可重复读,幻读

    什么是脏读,不可重复读,幻读_什么是脏读,不可重复读,幻读在了解脏读,不可重复度,幻读之前,首先要明白这三种情况的出现都是和数据库并发事务有关联的,如果所有的读写都按照队列的形式进行,就不会出现问题。 名词解析和解决方案 脏读 脏读又称无效数据读出(读出了脏

    2023-02-10
    95
  • TiDB 金融级备份及多中心容灾「终于解决」

    TiDB 金融级备份及多中心容灾「终于解决」作者简介:余军,PingCAP 解决方案事业部总经理。 对于金融企业来说,尤其是银行、证券、保险这些行业,在一个 IT 系统运行支撑业务的过程当中,考虑到硬件的故障、网络的故障,等一切可能会对业务产…

    2023-03-13
    104
  • python读取cifar(python读取cif)

    python读取cifar(python读取cif)直接用open打开后read读取 A =open(‘test.bmp’,’rb’)B=open(‘test2.bmp’,’w’)c = A.read()B.write(c)A.close()B.close()

    2023-11-02
    86
  • 加速Python代码的几个技巧

    加速Python代码的几个技巧Python是一门灵活且易于学习的编程语言,但某些情况下,Python代码可能会运行缓慢。为了克服这个问题,本文将介绍几个加速Python代码的技巧,包括使用列表推导式、使用生成器、使用装饰器等。

    2023-12-23
    65
  • cbbe3bbb安装_B&O软件

    cbbe3bbb安装_B&O软件在目前我接触过的轻量级BI工具中,我最喜欢的是MS Power BI。 如果只是个人使用,我觉得这简直是一个完美的工具了。但是,凡事就怕但是,在企业级应用中,当前版本的Power BI有几个不太方便的地方。对我而言,最不能忍的一点就是数据需要完全导入到PBI文件之后才能使用(官…

    2023-03-02
    95
  • 各模拟器adb连接端口[亲测有效]

    各模拟器adb连接端口[亲测有效]模拟器名称 连接默认端口 夜神安卓模拟器 62001 逍遥安卓模拟器 21503 BlueStacks(蓝叠安卓模拟器) 5555 雷电安卓模拟器 5555 天天安卓模拟器 5037 网易MuMu(…

    2023-04-08
    98
  • flink datasource_chatgpt python

    flink datasource_chatgpt pythonApache Flink Apache Flink 是一个兼顾高吞吐、低延迟、高性能的分布式处理框架。在实时计算崛起的今天,Flink正在飞速发展。由于性能的优势和兼顾批处理,流处理的特性,Flink

    2022-12-30
    105
  • mongodb connector_计算机网络传输介质性能最好

    mongodb connector_计算机网络传输介质性能最好关于作者 OPPO数据库团队负责人,一直专注于分布式缓存、高性能服务器、数据库、中间件等相关研发,后续会持续分享《MongoDB内核源码设计及性能调优实践》。Github账号地址: https://…

    2023-03-06
    88

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注