amazon RSD 并未提供SSH直接访问db server。
不过提供了Amazon RDS Command Line Toolkit,但是调整mysql的一些系统参数不是那么方便了。
这里主要记录下查看slow_log的操作。
1、下载Amazon RDS Command Line Toolkit
http://aws.amazon.com/developertools/2928
本机解压,配置环境变量就可使用。具体可参看
http://docs.amazonwebservices.com/AmazonRDS/latest/CommandLineReference/StartCLI.html
2、创建一个DB Parameter group
$rds-create-db-parameter-group --db-parameter-group-name testgroup
3、修改db instance 的parameter group
$rds-modify-db-instance DBInstanceIdentifier --db-parameter-group-name testgroup
4、修改testgroup中的相关系统参数
//记录未使用索引的SQL语句
$rds-modify-db-parameter-group upondefault --parameters "name=log_queries_not_using_indexes,value=
ON,method=immediate"
//设置慢查询的时间阈值为1秒
$rds-modify-db-parameter-group upondefault --parameters "name=long_query_time,value=1,method=immediate"
//记录慢查询SQL语句
$rds-modify-db-parameter-group upondefault --parameters "name=slow_query_log,value=
ON,method=immediate"
因为上面的三个参数都是动态参数,所以不必重启DB instance了。
5、通过mysql客户端访问mysql server。
$ mysql -h hostname -uusername -ppassword
mysql>use mysql;
mysql>show tables;
+---------------------------+
| Tables_in_mysql |
+---------------------------+
| columns_priv |
| db |
| event |
| func |
| general_log |
| help_category |
| help_keyword |
| help_relation |
| help_topic |
| host |
| ndb_binlog_index |
| plugin |
| proc |
| procs_priv |
| rds_sysinfo |
| servers |
| slow_log |
| tables_priv |
| time_zone |
| time_zone_leap_second |
| time_zone_name |
| time_zone_transition |
| time_zone_transition_type |
| user |
+---------------------------+
上面的slow_log表就是需要查看的表。这个slow_log表里的记录不能删除。
因为slow_log实际映射到一个csv文件上的。不过有了这个我们就可以迅速
定位到拖慢系统性能的sql了。
mysql> select * from slow_log order by query_time desc limit 100;
记录slow_log会影响系统的性能,记录一段时间后可关闭。
$rds-modify-db-parameter-group upondefault --parameters "name=log_queries_not_using_indexes,value=
OFF,method=immediate"
$rds-modify-db-parameter-group upondefault --parameters "name=slow_query_log,value=
OFF,method=immediate"