- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我的未命中数/秒已填充,但没有命中数。
数据包含的key范围为1到300K,存储的数据为字符串类型
memtier_benchmark -s xx.xxx.xxx.xxx -p xxxxx -P redis -t 1 -n 1 --ratio 0:1 -c 1 -x 2 --key-pattern S:S --authenticate=xxxxxxx --key-prefix=
最佳答案
memtier_benchmark 在这方面的记录很差。如果您在首次运行时开箱即用,它不会模拟任何缓存命中,这对于旨在测试缓存性能的工具而言是非常无用的。
这里的 2 个关键参数是:
--key-pattern=[SET:GET]
--ratio=[SET:GET]
--key-pattern
定义为设置的键指定的名称和请求的键的名称。例如,如果您使用S:S
,则意味着软件会将第一个 key 设置为memtier-0
,然后立即请求memtier-1
,然后设置memtier-1
,然后请求memtier-2
(看图...)。这就是您得到 100% 未命中结果的原因。
如果您设置R:R
,这意味着软件将在Set 和Get 中随机设置keyname 中的数字。这通常会导致大于 90% 的未命中率,具体取决于您设置的客户端和线程数。如果您运行的缓存未命中率 > 90%,那么您是否应该运行缓存是值得怀疑的,所以再说一遍,这是非常无用的。
要模拟真实世界的缓存应该做什么,您希望未命中率 < 50%。为此,您需要扩大 Gets over Sets 的数量。 memtier_benchmark 的默认值是 1:10
,但同样,在第一次运行时(或者如果你一直在冷缓存中运行它)使用 --key-pattern=S:S
默认情况下,您仍然会获得非常高的未命中率。如果您不断对不断填充的同一个缓存重复测试,您应该会看到您的未命中率正在下降,但同样,如果您在短暂的环境中进行测试,这可能不是您可以依赖的东西。
为了在第一次运行时获得较低的未命中率,我使用:
--key-pattern=S:R --ratio=1:20
这应该会导致失误率 < 50%。这和我能够模拟的一样好。我的实际缓存的未命中率 < 5%。我仍在尝试找出一种方法来使用 memtier_benchmark 对其进行测试。
此外,使用 --hide-histogram
摆脱烦人的测试结果转储。
编辑:
要获得完整的 100% 命中率/0% 未命中率,请执行以下操作:
从冷的、空的缓存开始
运行一个使用 -ratio=
参数的测试,这样只有 Sets
包含在测试中,在一个非常窄的键范围内:
--hide-histogram --key-pattern=S:S --key-minimum=1 --key-maximum=50 --ratio=1:0
现在,再次运行测试,这一次,翻转比率,以便只包含 Gets
:
--hide-histogram --key-pattern=S:S --key-minimum=1 --key-maximum=50 --ratio=0:1
然后您可以通过重新运行这两个部分并扩展 --key-maximum=
值来调整命中率/未命中率
关于redis - 使用 memtier_benchmark;错过了每一个关键,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35219535/
我已经运行 nagios 大约两年了,但最近这个问题开始出现在我的一项服务中。 我越来越 CRITICAL - Socket timeout after 10 seconds 对于 check_htt
我用 CSS 做到了这一点: 但我希望我的客户更改图像框架。在我的图像中,当前帧只是一种颜色 (#000)。但框架可以是装饰性的。因此,客户应使用装饰图像进行取景。我看过 W3Schools' bor
我编写了一个脚本来检查对象中是否有任何缺失的字段,然后返回具有缺失字段的项目的 ID。 它正在返回: [ '222', '333' ] 我期望返回: ['333'] 为什么它也返回222 id? fu
我正在读 Ramakrishnan 的书数据库管理系统,在模式细化和范式相关的章节中,我看到一句话说: K is a candidate key for R means that K ----> R
我正在编写一个 Java 应用程序,以在一夜之间自动化在线游戏中的角色 Action (特别是,它在《最终幻想 XI》中捕鱼)。该应用程序大量使用 java 的 Robot 类来模拟用户键盘输入和检测
我有这个 react 代码,我在某些输入组件上使用 new Date().getTime() 作为 react 键 Prop 。这可能是一种反模式,因为键需要稳定。但我想了解为什么这如此有问题。为什么
我正在尝试将我的简单查询优化为更复杂的查询。 我有三个表 Table 1 a_id info 1 talk 2 talk 3 sleep 4 sit Table 2
Google PageSpeed 审核建议将首屏内容的关键 CSS 添加到 中的标签,并将其余部分推迟到内容加载完成之后。 虽然我不同意这种做法,但正确的实现方式是什么? 我对使用它有一些保留意见
我已经使用 Pika 将 Websocket 集成到 Tornado 和 RabbitMQ 中。它成功地在各种队列上运行直到一段时间。然后引发以下错误: 严重:pika.connection:关闭时尝
我在本地使用 Gulp 和 SASS 进行开发,为动态站点(即 CMS 驱动)编译 CSS。我正在尝试配置一个解决方案来编译全局与关键路径 CSS。到目前为止最好的想法是将我的主要 scss 文件拆分
关于为 gtkmm 运行以下 simple.cc 示例 #include int main(int argc, char * argv[]){ Glib::RefPtr app = Gt
我正在生成一个 TSX 元素列表: this.productsModel = this.state.products.map(o => ( 但是,react 警告我:
我正在使用 Addy Osmani 的“Critical” https://github.com/addyosmani/critical 下面的 package.json 工作正常,但构建仅复制关键
我有一个 Multimap multimap = ArrayListMultimap.create(); 来自 Guava 。我想知道如何对多图中的 Date 键进行排序。 目前,我正在这样做:
我有一个基于 Jekyll 的网站,我想尽快完成它。我的目标是构建 Jekyll 站点、生成关键 CSS 并缩小 HTML 的 gulp 任务。 我的 gulpfile 的一部分看起来像这样: gul
考虑以下串行函数。当我并行化我的代码时,每个线程都会从并行区域(未显示)内调用此函数。我正在努力使这个线程安全和高效(快速)。 float get_stored_value__or__calculat
我正尝试在 tensorflow 中为我自己的自定义类别重新训练 Inception v3 模型。我已经下载了一些数据并将其格式化为目录。当我运行时,python 脚本为图像创建了瓶颈,然后当它运行时
我该如何追查此错误消息的根本原因? (test:1090): GStreamer-CRITICAL **: gst_debug_log_valist: assertion `category != N
我想为要托管在 Pivotal CloudFoundry 上的 Spring Boot 应用程序强制执行 HTTPS,我想现在大多数应用程序都需要这样做。据我所知,常用的方法是使用 http.requ
在 Travis CI 上运行 Pytest 时,我收到 Key -Error。请在下面找到我的程序: import sys import os sys.path.append(os.path.dir
我是一名优秀的程序员,十分优秀!