docker 保存 环境持久化_Docker最全教程——Redis容器化以及排行榜实战(十四)...

前言

容器教程的路还很长,笔者尽量根据实践来不断地完善。由于在编写的过程中还会有完善和补充,后续可能会以番外来补充。

接下来会分享TeamCity、树莓派等内容,节奏可能会有点跳脱。

另外,长沙.NET 社区已经初步成立,有兴趣的朋友可以加群参与互动和交流,具体见公众号菜单,如无法加入,请联系客服。

72cb18fe04da50f56df78144e828ea5b.png 04e2da817a3a11f7b6e38605c4e9881c.png

Redis容器化

Redis是一个开源的、支持网络、可基于内存亦可持久化的日志型、高性能的Key-Value数据库,并提供多种语言的API。其支持存储的value类型相对很多,包括string(字符串)、list(链表)、set(集合)、zset(sorted set ——有序集合)和hash(哈希类型)。这些数据类型都支持push/pop、add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的。

官网地址:https://redis.io/

Redis 与其他 key - value 缓存产品有以下三个特点:

· Redis支持数据的持久化,可以将内存中的数据保存在磁盘中,重启的时候可以再次加载进行使用。

· Redis不仅仅支持简单的key-value类型的数据,同时还提供list,set,zset,hash等数据结构的存储。

· Redis支持数据的备份,即master-slave模式的数据备份。

优势

· 性能极高 – Redis能读的速度是110000次/s,写的速度是81000次/s 。

· 丰富的数据类型 – Redis支持二进制案例的 Strings, Lists, Hashes, Sets 及 Ordered Sets 数据类型操作。

· 原子 – Redis的所有操作都是原子性的,意思就是要么成功执行要么失败完全不执行。单个操作是原子性的。多个操作也支持事务,即原子性,通过MULTI和EXEC指令包起来。

· 丰富的特性 – Redis还支持 publish/subscribe, 通知, key过期等等特性。

镜像说明

官方镜像:https://hub.docker.com/_/redis

运行Redis镜像

Powershell:

docker run --name myRedis `

  -p 6379:6379 `

  -v d:/temp/data/redis:/data `

  -d redis

c1ebc5104775369a3b7650061a09f7d4.png

使用redis-cli

进入redis-cli:

docker exec -it myRedis redis-cli

 2be6501b1d75067be3cd4e551c4794ee.png

设置一个key-value,比如key为name,value为test:

95f45624c55b7788290348b216aac78c.png

查看value:

5591f9c4ddc6502fff12f6512d5e8e0a.png

提供智能提示:

b771313eb7ca4eceff00965f4e008d55.png

652ff1bb0b9ce3a2281f4efabfbe9996.png

使用Redis Desktop Manager管理Redis

Redis Desktop Manager是一个开源的跨平台的redis桌面管理工具。

官网地址:https://redisdesktop.com/

使用起来比较简单,首先我们需要添加连接:

493362af48915333877350d5084883a9.png

接下来,就可以访问我们刚创建的Redis数据库了:

00a4edcbe5f8256cdd7d029baee7956b.png

又好又快地实现排行榜

Redis的应用场景很多,键值对大家经常用,这个我们就不多讲了,这里我们做一个排行榜实践来分享给大家。

使用redis ci

排行榜我们需要使用到Redis的有序集合。使用这种数据类型,可以又快又好的来实现我们的排行榜,比如玩家分数排行。这里我们使用Redis-ci来实现一个简单的排行测试。

这里,我们需要熟悉一个命令——ZINCRBY。Redis Zincrby 命令可以对有序集合中指定成员的分数加上增量值,增量值可以为负数(即让分数减去相应的值),如下所示:

ZINCRBY rank_test 1 "aa"

其中,rank_test为key,1为增量值,“aa”为值。如果key不存在则会自动创建。全部命令如下所示:

2b7ba98d8f0be2a097a72162cf7a9046.png

通过以上命令,我们创建了有序集合rank_test以及多个值和分数。接下来,我们可以通过ZRANGE命令来查看所有数据:

ZRANGE rank_test 0 -1 withscores

Redis Zrange 返回有序集中,指定区间内的成员。其中成员的位置按分数值递增(从小到大)来排序,如果我们需要按照分数从大到小排序,则需添加WITHSCORES。如下图所示:

70479d579dfeb792f87302e080ad8374.png

如果我们需要获取前3条数据,根据分数排名,则可以执行以下命令:

ZREVRANGE rank_test 0 2 withscores

c78a235c8a8e21133158c53c23ac5095.png

我们可以使用Redis Desktop Manager工具查看我们刚才添加的数据:

f6f9e4377bc4225891a38228df9347d4.png

整个排行榜实现非常简单,是否Get到了呢?

利用容器来做实践,省心不费力哈!

.NET Core实践

在.NET Core中,使用Redis非常便捷,我们可以使用以下Nuget包:

StackExchange.Redis

162d496aff580528fc27f0a93e2b9145.png

官方Github地址:https://github.com/StackExchange/StackExchange.Redis

也可以使用Microsoft.Extensions.Caching.Redis:

dfac805e7684441f68e6c5641d2352ad.png

以下是相关关键代码:

1. 获取数据库连接

ConnectionMultiplexer.Connect(configuration["RedisCache:ConnectionString"]);

2. 获取数据库对象

RedisConnection.GetDatabase();  //通过ConnectionMultiplexer对象获取

3. 添加有序集合

RedisDb.SortedSetIncrementAsync("Rank_Test", " Test", 1); //参数依次为key、value和分数

4. 根据分数从大到小获取前10

RedisDb.SortedSetRangeByRankWithScoresAsync("Rank_Test", 0, 9, StackExchange.Redis.Order.Descending);

如上所示,我们可以非常简单地应用于我们的.NET Core项目。又好又快地实现排行榜!

Docker最全教程——从理论到实战(一)

Docker最全教程——从理论到实战(二)

Docker最全教程——从理论到实战(三)

Docker最全教程——从理论到实战(四)

Docker最全教程——从理论到实战(五)

Docker最全教程——从理论到实战(六)

Docker最全教程——从理论到实战(七)

Docker最全教程——从理论到实战(八)    

Docker最全教程——从理论到实战(九)

Docker最全教程之使用TencentHub来完成CI(十)

Docker最全教程——数据库容器化(十一)

Docker最全教程——数据库容器化之持久保存数据(十二)

Docker最全教程——MongoDB容器化(十三)

.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com

75f04ace04081633aa12a26aab2ce10c.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值