redis支持的asgi通道层实现
channels-redis的Python项目详细描述
用法
在django设置文件中设置频道层,如下所示:
CHANNEL_LAYERS = { "default": { "BACKEND": "channels_redis.core.RedisChannelLayer", "CONFIG": { "hosts": [("localhost", 6379)], }, }, }
下面列出了 配置的可能选项。
主机
要连接到的服务器,作为uri, (主机,端口) 元组,或符合 create_connection的dict。 默认为 ['localhost',6379] 。传递多个主机以启用分片, 但请注意,更改主机列表将丢失一些分片数据。
如果您的服务器正在unix域套接字上侦听,您还可以使用它连接: ["unix:///path/to/redis.sock"] 。 这应该比环回TCP连接稍微快一点。
前缀
要添加到所有redis键的前缀。默认为 asgi: 。如果你在跑步 两个或多个完全独立的通道层通过同一个redis实例, 确保它们有不同的前缀。所有与同一层对话的服务器 不过,应该有相同的前缀。
到期
消息在秒内过期。默认为 60 。你一般不需要 要改变这个,但如果你有高峰流量,你可能想把它关小一点 如果你有高峰流量,你想停下来,或者停下来 开始吧。
组有效期
组在秒内过期。默认为 86400 。频道将被删除 在这段时间后从组中删除;建议您减少 为了一个更健康的系统,鼓励断开连接。这个值应该 不低于接口服务器中的相关超时(例如 --websocket_timeout 到 daphne )。
容量
默认信道容量。默认为 100 。一旦一个频道有容量, 它会拒绝更多的信息。这如何影响系统的不同部分 变化;例如,http服务器将拒绝连接,而django 发送响应将一直等到有空为止。
信道容量
每通道容量配置。这样可以调整频道容量 基于频道名称,并支持全局和正则表达式。
它应该是将通道名称模式映射到所需容量的dict;如果 dict key是一个字符串,它被称为glob,而如果它是编译的 re 对象,它被视为正则表达式。
这个例子将http.request设置为200,all http.response! 查尼尔斯 到10,全部 websocket.send! 20个频道:
CHANNEL_LAYERS={"default":{"BACKEND":"channels_redis.core.RedisChannelLayer","CONFIG":{"hosts":[("localhost",6379)],"channel_capacity":{"http.request":200,"http.response!*":10,re.compile(r"^websocket.send\!.+"):20,},},},}
如果要强制执行匹配的顺序,请使用 ordereddict 作为 参数;然后将按照dict提供的顺序匹配频道。
对称加密密钥
传递此消息以启用后端的可选对称加密模式。到 使用它,确保安装了 加密软件包,或者指定 当您安装channels\u redis时, 加密 额外功能:
pip install channels_redis[cryptography]
对称加密密钥应该是一个字符串列表,每个字符串 作为加密密钥。第一个密钥总是用于加密;所有的都是 考虑解密,这样就可以在不停机的情况下旋转密钥-只需添加 一把新钥匙,把旧钥匙移下来,然后把旧钥匙移走 消息过期后。
数据在redis中是加密的,但我们建议 为了更高的安全性,您还可以通过tls路由redis连接;redis 协议仍然未加密,通道和组密钥名可以 可能包含攻击者使用的元数据模式。
键的熵至少应为32字节 在用作加密密钥之前使用的SHA256哈希函数。任何字符串 可以工作,但字符串越短,加密就越容易中断。
如果您使用的是django,您也可以将其设置为 密钥 通过 通道层设置 设置:
CHANNEL_LAYERS={"default":{"BACKEND":"channels_redis.core.RedisChannelLayer","CONFIG":{"hosts":["redis://:password@127.0.0.1:6379/0"],"symmetric_encryption_keys":[SECRET_KEY],},},}