Linux 中监控 MySQL性能的调优工具

news/2024/7/5 6:09:20
MySQL是最常见的一种轻量型数据库,也是目前在市面上应用最广泛的一种数据库,所以懂得几个MySQL的调优工具非常必要,我个人比较推荐mytop和innotop

监控mysql性能的工具有很多,好的工具是诊断myql性能瓶颈和排除服务器的利器。日常工作我们常常用到工具如zabbix(借助脚本或插件),Prometheus(本人工作中常用)、MONyog等。但在一些特殊情况下,这它们并不总是完美满足mysql开发人员或管理员的常见需求,或者在某些情况一下可能无法正常工作。令人兴奋的是mysql社区创建了各种开源工具来填补这些空白。今天分享4个命令行工具来监控Linux中mysql数据库正常运行时间、负载和性能。

一 、Mytop

Mytop是开源和免费的基于命令行的MySQL数据库监控工具之一,由Jereme Zawodny使用Perl语言编写。Mytop 在终端中运行,显示有关线程、查询、慢查询、正常运行时间、负载等的统计信息,与 Linux监控命令top非常相似。这间接帮助管理员优化和提高 MySQl 的性能以处理大量请求并减少服务器负载。

mytop提供了多种系统的安装包,如centos、arch linux、opensuse等。

1、 安装方法

$ sudo apt install mytop    #Debian/Ubuntu
# yum install mytop         #RHEL/CentOS
# dnf install mytop         #Fedora 22+
# pacman -S mytop           #Arch Linux 
# zypper in mytop           #openSUSE

2、如何使用 Mytop 监控 MySQL/MariaDB

Mytop需要MySQL/MariaDB登录凭据来监控数据库并默认使用 root 用户名连接到服务器。您可以在运行时在命令行上或在文件中指定连接到数据库服务器的必要选项~/.mytop。

只需运行以下命令即可启动mytop并在出现提示时提供您的MySQL/MariaDB root 用户密码。这将默认连接到测试数据库。

# mytop --prompt
密码:

输入 MySQL root 密码后,您将看到Mytop监控,如下所示。

如果您想监视特定数据库,只需要加选项-d即可,如下图所示:

# mytop --prompt -d xuanyuan
密码:

如果你的每个数据库都有特定的管理员,只需要指定连接数据的用户名和密码即可。

mytop -u admin -p password_here -d tdb

在命令行界面指定明文密码还是有一定的安全隐患,为了避免这样的安全风险,*我们可以使用配置文件~/.mytop来指定连接到数据库的选项。

# vi ~/.mytop
添加以下选项:
user=root 
pass=password_here 
host=localhost 
db=test 
delay=4 
port=3306 
socket=

二、mtop

mtop (MySQL top) 是另一个类似的开源、基于命令行的实时 MYSQL Server 监控工具,它是用Perl语言编写的,它显示的结果与mytop类似。mtop 监控花费最多时间完成的 MySQL 查询,并在特定指定时间后终止那些长时间运行的查询。

此外,mtop正在运行的查询和终止查询的查询优化器信息,它还显示服务器的统计信息、配置信息和一些有用的调优技巧,以优化和提高MySQL 性能但不幸的是mtop没有得到积极维护,可能无法在新安装的 MySQL 版本上运行。

功能:

  • 显示实时 MySQL 服务器查询。
  • 提供 MySQL 配置信息。
  • 显示过程查询的缩放功能。
  • 为查询和“杀死”查询提供查询优化器信息。
  • 提供 MySQL 调优技巧。
  • 能够将输出保存在.mtoprc配置文件中。
  • 提供系统管理员推荐页面 (' T ')。
  • 向主标题添加查询/秒。
  • 将每秒信息添加到统计屏幕。

三、Innotop

Innotop另一个不错的基于命令行的mysql监控工具,它用于监控在InnoDB引擎下运行的本地和远程 MySQL 服务器。Innotop 包含许多功能并带有不同类型的模式/选项,这有助于我们监控 MySQL 性能的各个方面,以找出 MySQL 服务器出了什么问题。

1、 安装 Innotop(MySQL 监控)

默认情况下, innotop包不包含在 Linux 发行版中,例如RHEL、CentOS、Fedora和Scientific Linux。您需要通过启用第三方epel 存储库并使用 yum 命令来安装它,如下图所示:

# yum install innotop

要启动innotop,只需在命令行中键入“ innotop ”并分别指定选项-u(用户名)和-p(密码),然后按 Enter。

# innotop -u root -p 'tcm1nt'

2、Innotop 帮助

按“ ?” 获取命令行选项和用法的摘要。

切换到不同的模式:A Dashboard I InnoDB I/O Info Q Query List B InnoDB Buffers K InnoDB Lock Waits R InnoDB Row Ops C 命令摘要 L Locks S Variables & Status D InnoDB Deadlocks M Replication Status T InnoDB Txns F InnoDB FK Err O 打开表 U 用户统计
操作:d 更改刷新间隔 p 暂停 innotop k 终止查询连接 q 退出 innotop n 切换到下一个连接 x 终止查询
其他:TAB 切换到下一个服务器组/快速过滤您看到的内容!显示许可证和保修 = 切换聚合# 选择/创建服务器组 @ 选择/创建服务器连接$ 编辑配置设置 \ 清除快速过滤器
按任意键继续

四、 mysqladmin

mysqladmin是一个默认的命令行 MySQL 客户端,预装在 MySQL 软件包,用于执行管理操作,例如监控进程、检查服务器配置、重新加载权限、当前状态、设置 root 密码、更改 root 密码、创建/删除数据库等。

要检查 mysql 状态以及正常运行时间,请从终端运行以下命令,请确保你有root的权限。

[root@localhost ~]# mysqladmin -u root -p version

小结

mysql是最常见的一种轻量型数据库,也是目前在市面上应用最广泛的一种数据库,所以懂得几个mysql的调优工具非常必要,我个人比较推荐mytop和innotop。


http://lihuaxi.xjx100.cn/news/281397.html

相关文章

【转】Flex4:利用HttpService与ASP.NET传输JSON数据(登录为例)

开发环境:Flash Builder4,Vs2005 1、首先打开FlashBuilde4,创建一个名为HttpService_Net_Json的flex项目 (图1) 然后下一步,应用程序类型选择web,应用程序服务器类型选择ASP.NET(如图2) (图2) 下一步,出现配…

zoom:1是什么意思

当一个容器内元素都浮动后,它将高度将不会随着内部元素高度的增加而增加,所以造成内容元素的显示超出了容器。 overflow:auto;是让高度自适应, zoom:1;是为了兼容IE6,也可以用height:1%;的方式来解决1、浮动 浮动是CSS中用到的最多…

JavaScript初学者编程题(13)

JavaScript初学者编程题(13) 题目&#xff1a;输入一行字符&#xff0c;分别统计出其中英文字母、空格、数字和其它字符的个数。 HTMl部分 <input type"text" id"str"><button onclick"getTheNum()">get</button>JavaScript…

SpringBoot第九篇: springboot整合Redis

这篇文章主要介绍springboot整合redis&#xff0c;至于没有接触过redis的同学可以看下这篇文章&#xff1a;5分钟带你入门Redis。引入依赖&#xff1a;在pom文件中添加redis依赖&#xff1a;<dependency><groupId>org.springframework.boot</groupId><art…

Google 确认 Chrome 存在严重漏洞,向 20 亿用户发出警告:你们需立即更新浏览器...

作者&#xff1a;okay来源&#xff1a;扩展迷EXTFANS近日&#xff0c;Google面向二十亿Chrome浏览器用户推出至关重要的补丁程序&#xff0c;并再次强调大家需要立即更新其浏览器。如果你在Mac&#xff0c;Windows 10或Linux计算机上使用的是Google Chrome浏览器&#xff0c;则…

一文让你明白 Git 分支是如何工作的

分支是 Git 版本跟踪的核心功能&#xff0c;并且经常被使用相同软件代码库的团队使用。我们将深入研究它们如何在幕后工作&#xff0c;以及如何使用它们来改进 Git 工作流程。什么是分支&#xff1f; 分支用于拆分 Git 历史记录。您可以将 Git 提交想象成一系列可以追溯到过去…

CRF学习笔记

HMM&#xff0c;CRF等真的是很难很难啊 本科看不懂 研究生还是看不懂 然而为了找工作&#xff0c;拼了↖(^ω^)↗ https://www.zhihu.com/question/35866596 知乎上简单易懂的(&#xff89;*&#xff65;ω&#xff65;)&#xff89;推导&#xff0c;但是还是没有看懂 &#…

JavaScript初学者编程题(14)

JavaScript初学者编程题(14) 题目&#xff1a;求saaaaaaaaaaaa…a的值&#xff0c;其中a是一个数字。例如222222222222222(此时共有5个数相加)&#xff0c;几个数相加有键盘控制。 HTMl部分 <input type"text" id"what" placeholder"哪个数"…