【译】StackExchange.Redis中文使用文档--配置

配置

因为有很多不同配置 redis 的方式,StackExchange.Redis 提供了一个丰富的配置模型,当调用 Connect (或 ConnectAsync )时调用它。

var conn = ConnectionMultiplexer.Connect(configuration);

这里的 configuration 可以是下面的任意一个:

  • 一个 ConfigurationOptions 实例
  • 一个代表配置的 string

后者是 基本上 是前者的标记化形式。

基本配置字符串

最简单的 配置示例只需要一个主机名:

var conn = ConnectionMultiplexer.Connect("localhost");

这将使用默认的redis端口(6379)连接到本地计算机上的单个服务器。
附加选项只是简单地附加(逗号分隔)。 端口通常用冒号(:)表示。 配置选项在名称后面包含一个=。 例如:

var conn = ConnectionMultiplexer.Connect("redis0:6380,redis1:6380,allowAdmin=true");

下面显示了 stringConfigurationOptions 表示之间的映射概述,但您可以轻松地在它们之间切换:

ConfigurationOptions options = ConfigurationOptions.Parse(configString);

或者:

string configString = options.ToString();

常见的用法是将 基础配置 细节存储在一个字符串中,然后在运行时应用特定的详细信息:

string configString = GetRedisConfiguration();
var options = ConfigurationOptions.Parse(configString);
options.ClientName = GetAppName(); // only known at runtime
options.AllowAdmin = true;
conn = ConnectionMultiplexer.Connect(options);

带密码的 Microsoft Azure Redis 示例

var conn = ConnectionMultiplexer.Connect("contoso5.redis.cache.windows.net,ssl=true,password=...");

配置选项

ConfigurationOptions对象具有许多的属性,所有这些都在智能提示中都有。

一些更常用的选项包括:

配置字符串 ConfigurationOptions 含义
abortConnect={bool} AbortOnConnectFail 如果为true,Connect 没有服务器可用时将不会创建连接
allowAdmin={bool} AllowAdmin 启用被认为具有风险的一系列命令
channelPrefix={string} ChannelPrefix 所有发布/订阅操作的可选频道前缀
connectRetry={int} ConnectRetry 在初始 Connect 期间重复连接尝试的次数
connectTimeout={int} ConnectTimeout 连接操作的超时时间(ms)
configChannel={string} ConfigurationChannel 用于传达配置更改的广播通道名称
defaultDatabase={int} DefaultDatabase 默认数据库索引, 从 0databases - 1(0 到 Databases.Count -1)
keepAlive={int} KeepAlive 发送消息以帮助保持套接字活动的时间(秒)
name={string} ClientName 标识 redis 中的连接
password={string} Password redis 服务器的密码
proxy={proxy type} Proxy 正在使用的代理类型(如果有); 例如“twemproxy”
resolveDns={bool} ResolveDns 指定DNS解析应该是显式和热切,而不是隐式
serviceName={string} ServiceName 目前尚未实施(预期与sentinel一起使用)
ssl={bool} Ssl 指定应使用SSL加密
sslHost={string} SslHost 在服务器证书上强制执行特定的SSL主机标识
syncTimeout={int} SyncTimeout 允许同步操作的时间(ms)
tiebreaker={string} TieBreaker 用于在不明确的主场景中选择服务器的键
version={string} DefaultVersion Redis版本级别(当服务器要使用的版本默认不可用时使用)
writeBuffer={int} WriteBuffer 输出缓冲区的大小
ReconnectRetryPolicy={IReconnectRetryPolicy} ReconnectRetryPolicy 重新连接重试策略

配置字符串中的令牌是逗号分隔的;任何没有=符号的都假定为redis服务器端点。
没有显式端口的端点将在未启用ssl的情况下使用6379,如果启用了ssl则使用6380。

$开头的令牌被用来表示命令映射,例如:$ config = cfg

自动和手动配置

在许多常见的情况下,StackExchange.Redis将自动配置很多设置,包括服务器类型和版本,连接超时和主/从关系。
有时,在redis服务器上禁用了这些命令。 在这种情况下,可以提供更多的信息:

ConfigurationOptions config = new ConfigurationOptions
{
    EndPoints =
    {
        { "redis0", 6379 },
        { "redis1", 6380 }
    },
    CommandMap = CommandMap.Create(new HashSet<string>
    { // EXCLUDE a few commands
        "INFO", "CONFIG", "CLUSTER",
        "PING", "ECHO", "CLIENT"
    }, available: false),
    KeepAlive = 180,
    DefaultVersion = new Version(2, 8, 8),
    Password = "changeme"
};

它相当于命令字符串:

redis0:6379,redis1:6380,keepAlive=180,version=2.8.8,$CLIENT=,$CLUSTER=,$CONFIG=,$ECHO=,$INFO=,$PING=

重命名命令

redis的一个很不寻常的功能是可以禁用或重命名或禁用并重命名单个命令。

根据前面的例子,这是通过CommandMap来实现的,但不是传递一个HashSet <string>Create()(表示可用或不可用的命令),而是传递一个Dictionary < string>
字典中未提及的所有命令都默认已启用且未重命名。

“null”或空白值记录命令被禁用。 例如:

var commands = new Dictionary<string,string> {
        { "info", null }, // disabled
        { "select", "use" }, // renamed to SQL equivalent for some reason
};
var options = new ConfigurationOptions {
    // ...
    CommandMap = CommandMap.Create(commands),
    // ...
}

以上代码等同于(在连接字符串中):

$INFO=,$SELECT=use

Twemproxy

Twemproxy 是允许使用多个 redis 实例就像它是一个单个服务器,具有内置分片和容错(很像 redis 集群,但单独实现)的工具。
Twemproxy可用的功能集减少。
为了避免手动配置,可以使用 Proxy 选项:

var options = new ConfigurationOptions
{
    EndPoints = { "my-server" },
    Proxy = Proxy.Twemproxy
};

Tiebreakers 和配置更改公告

通常 StackExchange.Redis 都会自动解析 主/从节点。然而,如果你不使用诸如 redis-sentinel 或 redis 集群之类的管理工具,有时你会有多个主节点(例如,在重置节点以进行维护时,它可能会作为主节点重新显示在网络上)。
为了帮助解决这个问题,StackExchange.Redis 可以使用 tie-breaker 的概念 - 这仅在检测到多个主节点时使用(不包括需要多个主节点的redis集群)。
为了与 BookSleeve 兼容,tiebreaker 使用默认的key为 "__Booksleeve_TieBreak" (总是在数据库0中)。
这用作粗略的投票机制,以帮助确定首选 主机,以便能够按正确的路由工作。

同样,当配置改变时(特别是主/从配置),连接的实例使得他们意识到新的情况(在可用的地方通过 INFOCONFIG 等进行通知 )是很重要的。
StackExchange.Redis 通过自动订阅可以在其上发送这样的通知的发布/订阅通道来实现。
由于类似的原因,这默认为"__Booksleeve_MasterChanged"

这两个选项都可以通过 .ConfigurationChannel.TieBreaker 配置属性来定制或禁用(设置为"")。

These settings are also used by the IServer.MakeMaster() method, which can set the tie-breaker in the database and broadcast the configuration change message.
The configuration message can also be used separately to master/slave changes simply to request all nodes to refresh their configurations, via the ConnectionMultiplexer.PublishReconfigure method.

这些设置也由 IServer.MakeMaster() 方法使用,它可以设置数据库中的 tie-breaker 并广播配置更改消息。
配置消息也可以单独用于主/从变化,只需通过调用 ConnectionMultiplexer.PublishReconfigure 方法请求所有节点刷新其配置。

重新连接重试策略

当连接由于任何原因丢失时,StackExchange.Redis会自动尝试在后台重新连接。
它将继续重试,直到连接恢复。 它将使用 ReconnectRetryPolicy 来决定在重试之间应该等待多长时间。
ReconnectRetryPolicy可以是线性的(默认),指数的或者是一个自定义的重试策略。

举个例子:

config.ReconnectRetryPolicy = new ExponentialRetry(5000); // defaults maxDeltaBackoff to 10000 ms
//retry#    retry to re-connect after time in milliseconds
//1         a random value between 5000 and 5500       
//2         a random value between 5000 and 6050       
//3         a random value between 5000 and 6655       
//4         a random value between 5000 and 8053
//5         a random value between 5000 and 10000, since maxDeltaBackoff was 10000 ms
//6         a random value between 5000 and 10000

config.ReconnectRetryPolicy = new LinearRetry(5000); 
//retry#    retry to re-connect after time in milliseconds
//1         5000 
//2         5000       
//3         5000       
//4         5000 
//5         5000 
//6         5000 

查看原文

More

作者水平有限,若有疏漏或错误还望提醒,十分感谢。

您可以在这里 提出问题

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,001评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,210评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,874评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,001评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,022评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,005评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,929评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,742评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,193评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,427评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,583评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,305评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,911评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,564评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,731评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,581评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,478评论 2 352

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,650评论 18 139
  • 转载地址:http://gnucto.blog.51cto.com/3391516/998509 Redis与Me...
    Ddaidai阅读 21,449评论 0 82
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,802评论 6 342
  • 对专业的认识 关于财务管理这个专业,我了解甚少,通过对这个表格的查找,我对我的专业了解了不少。 财务管理是在一...
    财一田园阅读 223评论 0 0
  • 匆忙入梦 又辗转惊醒 梦里门外是海 我是海上浓烈的风 渔人是你,在船颠簸 荒芜寰宇 纵洒下一网柔情 是云是雾是苍白...
    西尽阅读 238评论 3 6