当前位置:  数据库>mysql

mysql DBA:mysqladmin常用命令总结

    来源: 互联网  发布时间:2014-10-13

    本文导语:  1. 使用-r/-i参数使用mysqladmin extended-status命令可以获得所有MySQL性能指标,即show global status的输出,不过,因为多数这些指标都是累计值,如果想了解当前的状态,则需要进行一次差值计算,这就是mysqladmin extended-status的一个额...

1. 使用-r/-i参数
使用mysqladmin extended-status命令可以获得所有MySQL性能指标,即show global status的输出,不过,因为多数这些指标都是累计值,如果想了解当前的状态,则需要进行一次差值计算,这就是mysqladmin extended-status的一个额外功能,非常实用。默认的,使用extended-status,看到也是累计值,但是,加上参数-r(--relative),就可以看到各个指标的差值,配合参数-i(--sleep)就可以指定刷新的频率,那么就有如下命令:

代码如下:
mysqladmin -uroot -r -i 1 -pxxx extended-status
+------------------------------------------+----------------------+
| Variable_name                            | Value                |
+------------------------------------------+----------------------+
| Aborted_clients                          | 0                    |
| Com_select                               | 336                  |
| Com_insert                               | 243                  |
......
| Threads_created                          | 0                    |
+------------------------------------------+----------------------+

2. 配合grep使用
配合grep使用,我们就有:
代码如下:
mysqladmin -uroot -r -i 1 -pxxx extended-status
|grep "Questions|Queries|Innodb_rows|Com_select |Com_insert |Com_update |Com_delete "
| Com_delete                               | 1                    |
| Com_delete_multi                         | 0                    |
| Com_insert                               | 321                  |
| Com_select                               | 286                  |
| Com_update                               | 63                   |
| Innodb_rows_deleted                      | 1                    |
| Innodb_rows_inserted                     | 207                  |
| Innodb_rows_read                         | 5211                 |
| Innodb_rows_updated                      | 65                   |
| Queries                                  | 2721                 |
| Questions                                | 2721                 |

3. 配合简单的awk使用
使用awk,同时输出时间信息:
代码如下:
mysqladmin -uroot -p -h127.0.0.1 -P3306 -r -i 1 ext |
awk -F"|" '{
  if($2 ~ /Variable_name/){
    print " ";
  }
  if($2 ~ /Questions|Queries|Innodb_rows|Com_select |Com_insert |Com_update |Com_delete |Innodb_buffer_pool_read_requests/)
    print $2 $3;
}'

 Com_delete                             0
 Com_insert                             0
 Com_select                             0
 Com_update                             0
 Innodb_buffer_pool_read_requests       589
 Innodb_rows_deleted                    0
 Innodb_rows_inserted                   2
 Innodb_rows_read                       50
 Innodb_rows_updated                    50
 Queries                                105
 Questions                              1
 
 Com_delete                             0
 Com_insert                             0
 Com_select                             0
 Com_update                             0
 Innodb_buffer_pool_read_requests       1814
 Innodb_rows_deleted                    0
 Innodb_rows_inserted                   0
 Innodb_rows_read                       8
 Innodb_rows_updated                    8
 Queries                                17
 Questions                              1

 4. 配合复杂一点的awk
反正也不简单了,那就更复杂一点,这样让输出结果更友好点,因为awk不支持动态变量,所以代码看起来比较复杂:
代码如下:
mysqladmin -P3306 -uroot -p -h127.0.0.1 -r -i 1 ext |
awk -F"|"
"BEGIN{ count=0; }"
'{ if($2 ~ /Variable_name/ && ++count == 1){
    print "----------|---------|--- MySQL Command Status --|----- Innodb row operation ----|-- Buffer Pool Read --";
    print "---Time---|---QPS---|select insert update delete|  read inserted updated deleted|   logical    physical";
}
else if ($2 ~ /Queries/){queries=$3;}
else if ($2 ~ /Com_select /){com_select=$3;}
else if ($2 ~ /Com_insert /){com_insert=$3;}
else if ($2 ~ /Com_update /){com_update=$3;}
else if ($2 ~ /Com_delete /){com_delete=$3;}
else if ($2 ~ /Innodb_rows_read/){innodb_rows_read=$3;}
else if ($2 ~ /Innodb_rows_deleted/){innodb_rows_deleted=$3;}
else if ($2 ~ /Innodb_rows_inserted/){innodb_rows_inserted=$3;}
else if ($2 ~ /Innodb_rows_updated/){innodb_rows_updated=$3;}
else if ($2 ~ /Innodb_buffer_pool_read_requests/){innodb_lor=$3;}
else if ($2 ~ /Innodb_buffer_pool_reads/){innodb_phr=$3;}
else if ($2 ~ /Uptime / && count >= 2){
  printf(" %s |%9d",strftime("%H:%M:%S"),queries);
  printf("|%6d %6d %6d %6d",com_select,com_insert,com_update,com_delete);
  printf("|%6d %8d %7d %7d",innodb_rows_read,innodb_rows_inserted,innodb_rows_updated,innodb_rows_deleted);
  printf("|%10d %11dn",innodb_lor,innodb_phr);
}}'

代码如下:
----------|---------|--- MySQL Command Status --|----- Innodb row operation ----|-- Buffer Pool Read --
---Time---|---QPS---|select insert update delete|  read inserted updated deleted|   logical    physical
 10:37:13 |     2231|   274    214     70      0|  4811      160      71       0|      4146           0
 10:37:14 |     2972|   403    256     84     23|  2509      173      85      23|      4545           0
 10:37:15 |     2334|   282    232     66      1|  1266      154      67       1|      3543           0
 10:37:15 |     2241|   271    217     66      0|  1160      129      66       0|      2935           0
 10:37:17 |     2497|   299    224     97      0|  1141      149      95       0|      3831           0
 10:37:18 |     2871|   352    304     74     23|  8202      226      73      23|      6167           0
 10:37:19 |     2441|   284    233     82      0|  1099      121      78       0|      3292           0
 10:37:20 |     2342|   279    242     61      0|  1083      224      61       0|      3366       

就这样了,这几个命令自己用的比较多,随手分享出来。


    
 
 

您可能感兴趣的文章:

  • Linux中使用mysqladmin extended-status配合Linux命令查看MySQL运行状态
  • 通过mysqladmin远程管理mysql的方法
  • Mysql服务器登陆,启动,停止等基本操作命令介绍(Linux/Centos环境)
  • 在 linux下输入"mysql"命令,进入mysql命令行,但出现“Can't connetc to local MySQL server thuough socket /var/lib/mysql/mysql.sock
  • mysql 命令大全及导入导出表结构或数据
  • php连接不上mysql但mysql命令行操作正常的解决方法
  • 装了两个mysql,如何设置登录命令。
  • 如何用命令行进入mysql具体操作步骤
  • 命令行下怎样操作MySQL
  • mysql在linux redhate 4 下,命令行模式下服务不能自动运行
  • mysql 编码设置命令
  • linux下如何重起mysql呀,急,在线等,命令是什么呀?
  • 命令行输入mysql -uroot ,提示:command not found
  • DOS命令行窗口mysql中文显示乱码问题解决方法
  • mysql常用命令大全 mysql常用命令总结
  • Fedora环境下装MySQL命令方法介绍
  • MYSQL 修改root密码命令小结
  • 关于MYSQL 远程登录的授权方法 命令
  • MySql是不是只能用命令行才能建数据表?
  • MySQL防止delete命令删除数据的两种方法
  • 请问linux下重启mysql的命令?
  • 一句命令完成MySQL的数据迁移(轻量级数据)
  • Mysql命令行导入sql数据
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • mysql截取函数常用方法使用说明
  • 5个常用的MySQL数据库管理工具详细介绍
  • Php按时间查询 Mysql常用语句
  • mysql cmd常用命令
  • MySQL数据库管理常用命令小结
  • mysql建表常用sql语句个人经验分享
  • mysql 常用设置 字符集编码、自动完成(自动提示)、监听外网ip
  • MySQL数据库维护中监控所用到的常用命令
  • Php连接及读取和写入mysql数据库的常用代码
  • MySQL数据库备份和还原的常用命令小结
  • 深入了解mysql的4种常用、重要的数据类型
  • 修改MYSQL密码的几种常用方法总结
  • MySQL 数据库常用命令 简单超级实用版
  • MySQL导入导出.sql文件及常用命令小结
  • 工作中常用的mysql语句分享 不用php也可以实现的效果
  • mysql 常用数据库语句 小练习
  • mysql常用监控脚本命令整理
  • mysql 维护常用命令
  • MYSQL中常用的强制性操作(例如强制索引)
  • MYSQL常用命令与实用技巧
  • mysql中如何查看最大连接数(max_connections)和修改最大连接数
  • MySQL 重装MySQL后, mysql服务无法启动
  • Mysql查询错误:ERROR:no query specified原因
  • 为什么用linux安装盘安装了mysql后,启动mysql,提示找不到mysql.sock文件?
  • php安装完成后如何添加mysql扩展
  • 請教,在redhat linux7.2+mysql 中,系統提示mysql已啟動,網頁卻不能訪問mysql?
  • mysql中查询当前正在运行的SQL语句并找出mysql中运行慢的sql语句
  • 求解释: useradd -g mysql mysql -d /home/mysql -s /sbin/nologin
  • Myeclipse中自带Tomcat的JDBC连接池配置(mysql和mssql)
  • 在Linux内安装了Mysql,无法进入Mysql.
  • MySQL Workbench的下载安装与使用教程


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3