ubuntu – 在EC2大型实例上为MySQL配置好/更好

前端之家收集整理的这篇文章主要介绍了ubuntu – 在EC2大型实例上为MySQL配置好/更好前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个专门用于 MySQL的EC2 Large实例.

它将提供Joomla / Magento组合,因此它融合了InnoDB和MyISAM表.我过去只与MyISAM合作,因此不熟悉InnoDB使用的设置.迄今为止的实验并不富有成效,因为我一直在禁用InnoDB引擎.

我的实例运行的是Ubuntu 10.04 64位服务器版,并且有~7.5G的内存. MysqL目前使用约0.6%,性能稍差.我想将它配置为尽可能多地使用系统RAM.

测试一些设置我了解到InnoDB日志不能大于4G.

是否有人能够提供一些基本的InnoDB和MyISAM设置来启动我的.

谢谢
蒂姆

我在EC2上运行相同类型的MysqL服务器.不要触摸/etc/MysqL/my.cnf,而是将配置文件放入/etc/MysqL/conf.d/这将允许您管理特定引擎的更改,并在您提供有关配置方式的其他线索后给管理员.此外,它还可以轻松备份您所做的任何更改以及跟踪它们.

/etc/MysqL/conf.d/innodb_MysqL.cnf

[MysqLd]    
# innodb settings 
innodb_additional_mem_pool_size = 12M
innodb_buffer_pool_size         = 2G
innodb_file_per_table           = 1
innodb_flush_log_at_trx_commit  = 2
innodb_lock_wait_timeout        = 180
innodb_log_buffer_size          = 16M
innodb_open_files               = 512
innodb_thread_concurrency       = 0

大多数这些设置都是非常标准的,你一定要看看Percona’s recommendations.你的系统可能会高达6G,但我从小开始.还有myisam表,我可能会停在4G.我不会触及innodb日志文件大小,那里有很少的收获.在初始碰撞后,增加log_buffer_size和addition_mem_pool也几乎没有回报.

此外,上述设置是为了获得更好的性能而不是为了事务一致性.假设您只运行一个Web应用程序,上述情况很好,但不适用于银行系统.

/etc/MysqL/conf.d/general_MysqL.cnf

[MysqLd]
# general settings
key_buffer = 384M

key_buffer对myisam和MysqL最有用一般默认它只有16M,在8GB机器上非常小.我再次以良好的跳跃开始,看看你是否有所改善.请记住,myisam缓冲区和innodb缓冲区不是共享的,所以它们需要总共少于你拥有的RAM量.稍后您可能会查看排序和读取缓冲区.

猜你在找的Ubuntu相关文章