- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在运行 MySql 5.6,当我对服务器进行基准测试(在一段时间内并行执行数百个查询)时,我注意到 m1.large aws 实例的 CPU 使用率从未超过 50%。
我已将 thread_cache 变量设置为 50,将 max_connections 设置为 500。当我从 shell 执行以下命令时,
mysqladmin -u root -ppassword -r -i 1 ext | grep Threads_created
我注意到创建的线程永远不会超过 3
mysqladmin -u root -ppassword -r -i 1 ext | grep Threads_running
我注意到 Threads running 永远不会超过 3,有时会变成 -1。
显示状态; (从 MySql 控制台运行)
我注意到 Threads_Cached 为 0,尽管 thread_cache_size 为 50。
我正在运行一个前端服务器来连接以将请求转发到 mysql。我正在使用大小为 50 的连接池。不应该在这里将 threads_created 更改为 50 吗?我的理解对吗?
更新:
我将前端服务器从 undertow 更新为 Jetty。我现在使用 c3p0 来做连接池。我已配置为打开 50 个连接,现在我可以注意到 threads_running 和 threads_running 上升到 50。
但是,我的 mysql 进程的 CPU 使用率仍然没有超过 60%。
机器详细信息:AWS m1.large 实例,2 个内核(4 个 vCPU),7.5GB RAMMySQL版本:5.6引擎:MyISAM行数:8500 万查询类型:只读查询:SELECT a,b,c FROM table WHERE text = ?和日期>=? AND 日期 <= ?;我在文本、日期字段上有一个复合索引,当我对此查询运行 EXPLAIN 时,我能够看到正在使用该索引。
谢谢,V
最佳答案
多少个核心?当您看到 50% 时,有多少连接正在积极做事?我猜你有 2 个核心,并且有一个连接处于事件状态。由于 MySQL 每个连接使用的核心不超过一个,因此为 50%。
您提到的“Thread”值是可以的。详情...
“Thread_cache”是一个容易混淆的概念。事情是这样的:当一个新的客户端尝试连接时,mysqld(服务器)在它的“线程缓存”中查找是否有线程缓存。如果不是,它将为该连接创建一个新的操作系统“进程”。这是一项中等耗时的任务,因此需要缓存。
当连接断开时(并且没有“连接池”),进程被放入线程缓存中。但线程缓存的上限为 thread_cache_size
。此 VARIABLE
的值对于 Windows 应为 0,对于 unix 通常为 10。但值(value)并不重要。
max_connections
控制可以同时连接的客户端数量。通常他们正忙于做其他事情,所以 SHOW PROCESSLIST
说“Sleep”。 wait_timeout
将强制断开 sleep 时间超过该设置的用户(如果他们尚未自愿断开连接)。
STATUS
值 Threads_created
表示自 MySQL 启动以来发生了多少新连接。 Threads_running
表示当前连接了多少线程,但不是“ sleep ”。 (-1 似乎是“错误的”。)Threads_cached
= 0 可能意味着,例如,3 个客户端已连接并且它们仍然连接,而且您从未连接过超过 3 个。
因为你有一个“连接池”,连接将永远不会消失。
您没有达到 50,因为您没有足够的客户需要 50。
连接池和 Thread_cache 服务于相同的缓存目的,但方式不同。两者兼有是可以的,但两者都不会让你获益太多。
关于MySQL 服务器未充分利用; threads_running 小于 2,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29587322/
问题:如果联接表的属性大于/小于值,是否可以在散列条件下进行测试 例如:测试 Actor 年龄是否大于年龄变量: 是否可以写而不是 ARRAY CONDITION 的: ageVariable = 3
这个问题已经有答案了: How to check if a number is between two values? (12 个回答) 已关闭 6 年前。 我目前正在 Codecademy 上学习
我想知道是否有一种方法可以比较 arrayList 中的连续元素。我有这个 for (int j=0; j< Index.size(); j++) { if(Index.get(j) < Ind
我正在压缩一些代码,现在我有 4 种方法,它们几乎都做同样的事情,除了 for 循环的建模有点不同。我正在传递 int 的 up , down , right ,和left作为这个紧凑方法的参数,这与
SELECT DISTINCT s.sname, s.sid FROM student s, class c WHERE s.programme = 'CS' AND s.level = '2' AN
我正在尝试通过命令行读取文件名, 这是教授要我们输入的命令: java MultiBinaryClient xxxxxx.edu 6001 < files.txt 我正在尝试使用 args[3]获取文
在 C# 中,您可能会看到以下内容: [] 或类似的行(但没有大于/小于符号): [assembly: AssemblyTitle("MyProject")] 我知道第一个称为属性(它有 gt 和 l
我只是想知道大于/小于的结果是如何计算并返回给高级语言的。 我在这里寻找硬件门模型。 让我们用一个统一的例子来解释,比如说5 > 3。 最佳答案 它通常通过带有进位检测的减法来实现。 从门控的角度来看
这个问题在这里已经有了答案: strange output in comparison of float with float literal (8 个答案) 关闭 8 年前。 案例一 float
你到底如何检查一个数字属性是否小于 Apache Ant? 从我所看到的(我是 Ant 的新手)你只能做 ? 最佳答案 您可以使用 (见 http://ant.apa
在 C 中使用 float.h 我想知道如何找到最大的数字,如果我加到 1,答案将保持为 1。 即 1 + x = 1 如何找到 x? 最佳答案 如果你想要“小于 FLT_EPSILON 的最大数字”
我正在尝试查询节点统计信息端点(_nodes / stats)并收到此错误: {"error":{"root_cause":[{"type":"illegal_argument_exception",
有没有更快的方法来检查列表中的项目是否大于、小于或等于某个数字? 或者你只需要循环它?我只是好奇是否有为此预先构建的函数。 示例: 列表包含 5、5、10、15、15、20。 我想检查是否有多少个
因此,我必须编写一个代码,从用户那里获取 2 个日期(月/日/年),如果第一个日期小于第二个日期,则返回“true”。在任何其他情况下,日期将为“假”或“它们是相同的”。我被告知我不能要求用户执行指定
我有两个变量,如果它们的值彼此相差在 5 个数字以内,我想触发一些代码。不知道哪个变量具有更高的值,我可以这样做: if (var1 > var2) { if ((var1 - var2) < 5
我有一个函数,它接受一个对象并将其转换为字节数组: public static byte[] serialize(Object obj) throws IOException { try(By
下载大小已经低于 4MB 的应用程序是否也可以作为免安装应用程序未经修改地分发? 最佳答案 要将该应用程序作为免安装应用程序提供,仍需采取一些步骤。参见 http://g.co/instantapps
我有以下 SELECT 但无法正常工作: SELECT COUNT(userid) FROM login WHERE 17 YEAR(DATE_SUB(NOW(), INTERVAL TO_DAYS
我制作了一个脚本,其中 #hsz-wrap2 附加到最后一个可见的 div,当 div 数量低于或等于 16 在 #snapshot_vertical div 内。 但是,if 条件的工作方式我不明白
我在外部的一排内放置了一个 Logo 、一个搜索框和一个语言栏,并位于 Bootstrap 导航栏上方。这一行当然仍在主容器中,但它包含我提到的 3 个元素——我和我的客户认为这 3 个元素独立于导航
我是一名优秀的程序员,十分优秀!