我在Amazon RDS db.m4.xlarge(16Gb RAM,4vCPU)多可用区部署上运行MariaDB 10.0.17。我们使用预设IOPS存储,最大设置为10000 IOPS。 users
表中包含17M记录; user_properties
表包含350M记录。MySQL不充分利用服务器
user_properties
表格描述了附属于用户的道具的“地图”。 upkey
是关键,string_value
,integer_value
等是每种类型的值; STRING,DATE,INTEGER,DOUBLE。索引也是按类型的。
我们尝试更多的数据插入插入到user_properties
表:应用程序将数据插入到INNODB临时表TEMP1
,然后数据被复制,从TEMP1
到user_properties
表。
问题是我们只能达到2500个写入IOPS和500-1000个读取IOPS。队列深度平均保持在〜7。 MySQL服务器CPU使用率保持在20-30%,永远不会达到60%。 应用程序似乎向MySQL提供足够的数据:我们将类似的数据文件提供给数据库,并查看处理时间随着表大小的增加而增加。 大部分时间应用程序都等待MySQL查询完成。在这个过程中,插入到TEMP1
表中占用了总时间的很小部分,大多数时间正在等待从TEMP1
表插入到user_properties
。
有人可以帮助我使MySQL更快吗?我应该增加/改变什么?
CREATE TABLE IF NOT EXISTS `users` (
`id` bigint(20), // Column is not used now. Filled with NULL
`version` bigint(20) NOT NULL,
`email` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
`uuid` varchar(80) COLLATE utf8_unicode_ci DEFAULT NULL,
`partner_id` bigint(20) NOT NULL,
`password` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
`date_created` datetime DEFAULT NULL,
`last_updated` datetime DEFAULT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `unique-email` (`partner_id`,`email`),
UNIQUE KEY `users_Uuid` (`uuid`),
KEY `idx_013_partner_id_uuid` (`partner_id`,`uuid`),
KEY `idx_014_uuid` (`uuid`),
CONSTRAINT `FKB2D9FEBE725C505E` FOREIGN KEY (`partner_id`) REFERENCES `partner` (`id`),
CONSTRAINT `fk_046_partner` FOREIGN KEY (`partner_id`) REFERENCES `partner` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
CREATE TABLE IF NOT EXISTS `user_properties` (
`id` bigint(20) NOT NULL AUTO_INCREMENT,
`version` bigint(20) NOT NULL,
`date_created` datetime DEFAULT NULL,
`last_updated` datetime DEFAULT NULL,
`upkey` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
`user_id` bigint(20) DEFAULT NULL,
`security_level` int(11) NOT NULL,
`_content` longtext COLLATE utf8_unicode_ci NOT NULL,
`class` varchar(255) COLLATE utf8_unicode_ci NOT NULL,
`date_value` datetime DEFAULT NULL,
`integer_value` bigint(20) DEFAULT NULL,
`double_value` double DEFAULT NULL,
`string_value` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,
`uuid` varchar(80) COLLATE utf8_unicode_ci DEFAULT NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `idx_004_uuid` (`uuid`),
KEY `idx_005_string_value` (`upkey`,`string_value`),
KEY `idx_006_integer_value` (`upkey`,`integer_value`),
KEY `idx_007_double_value` (`upkey`,`double_value`),
KEY `idx_008_date_value` (`upkey`,`date_value`),
KEY `idx_key_value_user_upkey_string` (`user_id`,`upkey`,`string_value`),
CONSTRAINT `FK_users` FOREIGN KEY (`user_id`) REFERENCES `users` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
我认为速度是重中之重,而不是交易如何消耗IOPS! – Shadow
@Shadow我只是想知道我的速度情况有什么瓶颈 - 我应该增加/更改哪一个以使速度更快?IOPS没有得到充分利用,CPU使用不足,RAM没问题 - 所以没有明确的候选人,我很困惑接下来要做什么.. – snowindy
@Shadow从select * from ...'插入到user_properties中几乎是纯粹的。我在每个事务中按3个应用程序线程批量插入〜10-50K条记录。我不会做COPY,它是来自Java的常规SQL语句。除此插入之外,没有其他活动处于数据库中。 – snowindy