- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
有一个新的 Redis 集群设置,我认识的一个团队正在我公司工作,以改进基于 Redis 的应用程序数据缓存。设置如下,一个 Redis 集群,有一个 Redis 主服务器和许多从服务器,比如 40-50(但当应用程序扩展时可以增加更多),每个虚拟机一个 Redis 实例。有人告诉我,此设置有助于部署在每个虚拟机上的服务器中的应用程序查询本地 Redis 实例中存在的数据,而不是查询网络中的实例,以避免网络延迟。定期地,Redis master 只更新任何修改或新创建或删除的数据(由关系数据库支持的数据),比如每 5 秒左右。这将启动与所有 Redis 从实例的数据同步操作。 Redis(从)的数据消费者(部署在所有虚拟机上的应用程序)读取更新的值进行处理。对于应用程序从数据中心网络内的 Redis 实例查询时所面临的网络延迟问题,这种方法是否正确?当 Redis 主节点与其所有从节点同步数据时,此设置是否会产生大量网络流量?
我无法从互联网上找到很多关于此的答案。非常感谢您对此提出意见。
最佳答案
这种架构的相关性在很大程度上取决于工作量。以下是重要标准:
写入和读取操作之间的比率。显然,读取操作越多,架构就越相关。 IMO 的主要好处不一定是延迟 yield ,而是可扩展性、它带来的额外可靠性以及网络资源消耗。
本地 Redis 访问成本与远程 Redis 访问成本之间的比率。不要假设远程 Redis 访问的唯一成本是网络延迟。它不是。在我的系统上,本地 Redis 访问成本约为 50 us(平均,工作量非常低),而远程访问成本为 120 us(平均,工作量非常低)。网络延迟约为 60 us。使用您自己的数据在您自己的系统/网络上测量同类数字。
这里有一些建议:
不要对多个从实例使用单个 Redis 主实例。它将限制系统的可扩展性。如果你想扩展,你需要建立一个奴隶的层次结构。例如,让 master 复制到 8 个 slave。每个从站复制到在您的 64 个应用程序服务器上本地运行的 8 个其他从站。如果您需要添加更多节点,您可以在主节点或从节点级别调整复制因子,或者在此树中再添加一层以获得极高的可扩展性。它为您带来了灵 active 。
考虑在应用程序和本地从站之间使用 unix 套接字,而不是 TCP 套接字。如果它对延迟和吞吐量都有好处。
关于您的最后一个问题,您确实需要评估本地和远程的平均延迟时间来决定这样做是否值得。请注意,Redis 用于同步主从的协议(protocol)接近于正常的客户端服务器流量。应用于主站的每个 SET 命令也将应用于从站。因此网络带宽消耗是相似的。所以最后,这实际上是您期望的读取次数和写入次数的问题。
关于caching - Redis集群-网络延迟,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32306013/
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 8 年前。 Improve t
我卡在了一个点上,我无法进步,很抱歉这个愚蠢的问题。我为此进行了很多搜索,但我不知道我错过了什么。请帮助我。 我研究了 python 中的模块和类。现在我想使用 python 和 apt 进行一些操作
我在 Kong 有服务,我已经为该服务设置了代理缓存插件。 curl -X POST http://localhost:8001/plugins --data "name=proxy-cache"--
ASP.NET Core 提供内存缓存和响应缓存。 假设该应用程序是 ASP.NET Core WebAPI,它通过配置的响应缓存中间件将 SQL 数据库中的数据传送给用户。 在什么情况下也使用内存缓
我最近遇到了以下面试问题: You need to design a system to provide answers to factorials for between 1 and 100. Yo
我的 Javascript (JS) 代码遇到了一些麻烦,因为我有时需要在同一个函数中多次访问相同的 DOM 元素。还提供了一些推理here . 从性能的角度来看,是一次性创建一个 jQuery 对象
仅使用 Cache 终端,我使用或查看什么实用程序函数或 Global 来查找存在于 Cache 数据库中的所有 Globals 的列表? 再次仅在缓存终端中使用,我使用或查看什么实用程序功能或全局以
我的 Javascript (JS) 代码遇到了一些麻烦,因为有时我需要在同一个函数中多次访问同一个 DOM 元素。还提供了一些推理here . 从性能的角度来看,是先创建一个jQuery对象然后缓存
来自 RFC 2616 http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.9.1 no-cache If the no-cach
大多数 CDN 服务器对经常访问的内容使用缓存。 场景:假设有人上传了一张非常热门的图片,并且来自同一位置的许多用户 (1000) 试图访问该图片。 问题:假设网络服务器收到一个请求,首先检查它的缓存
我的 Javascript (JS) 代码遇到了一些麻烦,因为有时我需要在同一个函数中多次访问同一个 DOM 元素。还提供了一些推理here . 从性能的角度来看,是先创建一个jQuery对象然后缓存
如果我将服务器响应设置为:Cache-Control: private,no-cache,max-age=900 ? 如果标题是这样的,会发生什么:Cache-Control: public,no-c
我有一个类需要在缓存中存储数据。最初我在 ASP.NET 应用程序中使用它,所以我使用了 System.Web.Caching.Cache。 现在我需要在 Windows 服务中使用它。现在,据我了解
我遇到了和这个人一样的问题:X-Drupal-Cache for Drupal 7 website always hits MISS ,并且找不到出路。 我正在运行 Drupal 7 - 新闻流 和
我已将 Laravel 设置为使用 Redis 作为缓存。当我使用 Cache::('my_var', 'my_val'); 然后通过 CLI 检查 Redis 以查看 key 是否已创建时,我可以验
我在 Windows Azure 云上有一个应用程序,并且正在使用 Windows Azure 共置缓存。 有时,当我发布网站/web服务时,调用DataCacheFactory.GetCache方法
我正在阅读 documentation for Apollo server-side caching ,但看不到任何关于缓存通常如何加密的内容。 我需要的是一个以响应中包含的对象 ID 为键的缓存,而
Hibernate\Grails 中最好的缓存策略是什么?是否缓存所有实体和查询以及如何找到最佳解决方案? 这是我的 hibernate 配置。 hibernate { cache.use_sec
我收到错误 'Nuget.Proxy Cache' 的类型初始化器抛出异常 尝试连接到 Nuget 官方包源时。我在公司网络后面,但是我怀疑问题是连接性。 有任何想法吗? 最佳答案 我有同样的问题。我
我是一名优秀的程序员,十分优秀!