- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
在此先感谢您的帮助。
我的服务器的 CPU 使用率突然达到 100%。在关闭所有脚本并逐渐恢复它们之后,我将问题追溯到在两个地方使用的一种特定类型的查询。查询是:
select * from zzproductdata
where amazonproductid <> '' and amazoncategory1 ='' and disabled = 0
and productid in (select productid from zzdropshipstock where quantity >= 10)
并且:
select 'ZZ Product Data With Image' as 'Statistic', count(zzproductdataid) as
'Number' from zzproductdata
where imagescollecteddate <> '0000-00-00' and zzproductdata.productid in
(select productid from zzdropshipstock where quantity >= 80)
两个查询都包含一个子查询,并且都处理一个名为 zzproductdata 的表。
检查了几件事:1.其他包含子查询的查询继续工作。2. 其他包含 zzproductdata 的查询继续工作,只要它们不包含子查询。
当上述两个查询运行时,CPU 在大约 90 秒内逐渐增加到 100%。它保持在 100%,似乎没有恢复——我让它这样运行了 3 个小时,但它没有停止或完成查询。
表 zzproductdata 逐渐收集数据,最近 12 天增加到 1,500,000 条记录。我监控每个查询在数据库中运行所花费的时间,这两个查询逐渐变长但并不过分——它们已经从 2.5 秒增加到 5.6 秒。
突然之间,他们在没有任何警告的情况下开始使用 100% CPU。在终端的 mysqladmin processlist 中,我看到两条记录 - 一条显示进程处于“ sleep ”状态,另一条显示“正在发送数据”状态。
我怀疑查询刚刚达到某种 sql 缓存限制,但我无法确定 mysql 使用哪个缓存限制来使用子查询。我试过更改 mysql 中的一些设置,但它们似乎都没有效果。有什么建议么?
编辑
CREATE TABLE `zzproductdata` (
`zzproductdataid` int(11) NOT NULL AUTO_INCREMENT,
`zzproductdataname` text NOT NULL,
`disabled` int(11) NOT NULL,
`datecreated` date NOT NULL,
`masteronly` int(11) NOT NULL,
`productid` int(11) NOT NULL,
`isbn` text NOT NULL,
`ean` text NOT NULL,
`publishername` text NOT NULL,
`imagethumbnail` text NOT NULL,
`imagefull` text NOT NULL,
`amazonproductid` text NOT NULL,
`productdatasource` text NOT NULL,
`datelastupdatedamazon` date NOT NULL,
`datelastupdatedgoogle` date NOT NULL,
`googleproductid` text NOT NULL,
`publicationdate` date NOT NULL,
`binding` text NOT NULL,
`imagescollecteddate` date NOT NULL,
`amazoncategory1` text NOT NULL,
`amazoncategory2` text NOT NULL,
`amazoncategory3` text NOT NULL,
`datelastcheckedamazoncategory` date NOT NULL,
`datelastupdatedopenlibrary` date NOT NULL,
PRIMARY KEY (`zzproductdataid`)
)
ENGINE=InnoDB
AUTO_INCREMENT=1674296
DEFAULT CHARSET=utf
CREATE TABLE `zzdropshipstock` (
`zzdropshipstockid` int(11) NOT NULL AUTO_INCREMENT,
`zzdropshipstockname` text NOT NULL,
`disabled` int(11) NOT NULL,
`datecreated` date NOT NULL,
`masteronly` int(11) NOT NULL,
`zzdropshipsupplierid` int(11) NOT NULL,
`isbn` varchar(13) NOT NULL,
`quantity` double NOT NULL,
`suppliercode` text NOT NULL,
`supplierprice` double NOT NULL,
`standardshipcost` double NOT NULL,
`weightgram` double NOT NULL,
`rrp` double NOT NULL,
`productid` int(11) NOT NULL,
`initialimportdate` date NOT NULL,
`lastupdateddate` date NOT NULL,
`changed` int(11) NOT NULL,
`lastcheckedproductiddate` date NOT NULL,
`lastcheckedproductinamazondate` date NOT NULL,
`lastcheckedrawstockdata` date NOT NULL,
`lastcheckedproductstockitemlive` date NOT NULL,
`changedquantity` int(11) NOT NULL,
PRIMARY KEY (`zzdropshipstockid`),
KEY `isbn` (`isbn`)
)
ENGINE=InnoDB
AUTO_INCREMENT=7037817
DEFAULT CHARSET=latin1
我尝试添加 DISTINCT 但没有效果。它减缓了 CPU 使用率的上升,因此几乎用了 200 秒才达到 100% 的 CPU 使用率,但它没有运行查询。
查询的第一部分在 0.23 秒内返回 1,300,000 条记录。子查询在 2.3 秒内返回 118,000 条记录。这是您分别运行这两个部分的时候。将两者合并为一个查询,目前应该返回大约 15,000 条记录。
最佳答案
首先,您可以尝试添加这些索引:
ALTER TABLE zzdropshipstock ADD INDEX IX_zzdropshipstock_key (quantity, productid);
ALTER TABLE zzproductdata ADD INDEX IX_zzproductdata_productid (productid);
然后执行ANALYZE TABLE zzdropshipstock
、ANALYZE TABLE zzproductdata
并显示新的EXPLAIN计划。
关于当在查询中包含子查询时,MySQL 将 CPU 推至 100%,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53771923/
当我推/拉存储库时,是否可以详细输出到底发生了什么?目前,我有一个大型存储库,正在将其推送到服务器,大约 15 分钟后。或者这样,它给了我一个错误,但没有告诉我它在这 15 分钟内做了什么。 最佳答案
我不知道我的方法是否有意义,但是,我需要实现如下图的布局: 现在,我只写一个 并用其中的一列表示每个区域,例如 . 没有黄色区域,这工作正常: green red blue
当我查看许多 CSS 网格系统和框架时,它们通常具有标准的列和行设置以及百分比宽度。例如这样的事情: 标准网格列: .col-10 { width: 83.33333%; width: cal
我想使用 git 子模块。 我需要采取的步骤将我的更改推送到我的项目是 add/commit/push from submodule directory add/commit/push from pa
以下为百度站长平台的公告全文: 结合站长对于关键词数据分析的需求,站长平台对流量与关键词工具进行了升级,推出(“关键词影响力”)这一全新概念。关键词影响力算法复杂,涵盖该关键词下百度搜索可以为
我需要一个具有普通按钮和下拉按钮的控件。 例如 类似的控件在 wxRibbonButtonBar 中可用,我无法在简单的 wxPanel 中使用它。 最佳答案 我实现了 SplitButton,它看起
我一直在做一个项目,使用 Bazaar 作为版本控制系统。现在我必须和离岸人员一起工作,而他们只想使用 SVN。 我有什么: 我的 bazaar 分支及其文件和修订版。 一个全新的 subversio
我一直在开发数据流/图表风格的内部 DSP 应用程序(Java 带有 Groovy/Jython/JRuby 的钩子(Hook),通过 OSGi 的插件,大量的 JNI),类似于纯数据和 simuli
我正在尝试使用 THUMB 指令创建一个阶乘方法,我基本上做到了。 我只有一个关于 PUSH/POP 操作码的问题:如果我使用 push 将 r0 的值存储在堆栈中(所以 push {r0} ),我可
在尝试 ZeroMQ Push/Pull (他们称之为 Pipeline)套接字类型时,我很难理解这个图案。它被称为“负载均衡器”。 假设单个服务器将任务发送给多个工作人员,推/拉将在所有客户端之间平
有什么方法可以使用 push() 方法找出我的数据何时保存在数据库中?我写了下面的代码,但它多次保存数据...... db.ref('news').push(opts).then(() => {
我有这个问题,每次推或拉时我都必须把它放进去。我认为这是新的。有什么想法吗? 最佳答案 您可能正在使用 https 网址。切换到 ssh 并确保您的 key 设置正确(如果您的密码短语为空),则不必输
为什么当您将一个值压入堆栈时,ESP 寄存器会减少(而不是增加),而当您弹出一个值时,ESP 寄存器会增加(而不是减少)?在这一点上,这对我来说是违反直觉的。 最佳答案 那是因为堆栈是从上到下“增长”
有什么方法可以使用 push() 方法找出我的数据何时保存在数据库中?我写了下面的代码,但它多次保存数据...... db.ref('news').push(opts).then(() => {
我决定编写一个测试代码来查看 pusher - many pullers bundle 是如何工作的,我的怀疑成真了。 拉取器按照连接的顺序接收消息,例如第一个消息由第一个连接的拉取器接收,第二个由第
我在 CSV 文件中存储了一长串日期。我已经成功地使用 d3.js 加载了这个数据集。现在我想向此数据集添加另一列,其中包含列表中每个日期的随机数。 我相信此数据集已作为对象数组加载。所以我正在使用下
我一直在寻找解决方案。不使用 c++11。 for(int a = 1; a < team1.chan; a++) { team1.nums.push_back(ppb.back())
我打算在布局中构建带有滑动 subview 的 UI。 +--------------+ +--------------+ +--------------+ | view1
Title 在小屏幕上,我首先需要标题,然后是文本字段,但在中等以上的屏幕上,我需要相反的方式 - 我已经尝试过推和拉,但它们无法工作 - 有什么想法吗? 最佳答案 根据 Swa
zmq 的某些部分未以可预测的方式运行。 我正在使用 VS2013 和 zmq 3.2.4。为了不在我的 pubsub 框架中“丢失”消息 [旁白:我认为这是一个设计缺陷。我应该能够首先启动我的订阅者
我是一名优秀的程序员,十分优秀!