Ubuntu24.04安装好Mysql8后,检查mysql占用的内存和磁盘

检查磁盘使用情况

1. 查看MySQL数据目录大小

查看MySQL数据目录:

bash

复制代码
sudo du -sh /var/lib/mysql

查看详细的目录结构大小:

bash

复制代码
sudo du -h --max-depth=1 /var/lib/mysql

查看磁盘总体使用情况:

bash

复制代码
df -h

2. 在MySQL内部查看数据库大小

查看所有数据库的大小:

sql

复制代码
SELECT 
    table_schema AS 'Database',
    ROUND(SUM(data_length + index_length) / 1024 / 1024, 2) AS 'Size (MB)'
FROM information_schema.tables 
GROUP BY table_schema
ORDER BY SUM(data_length + index_length) DESC;

查看具体表的大小:

sql

复制代码
SELECT 
    table_name AS 'Table',
    ROUND((data_length / 1024 / 1024), 2) AS 'Data Size (MB)',
    ROUND((index_length / 1024 / 1024), 2) AS 'Index Size (MB)',
    ROUND(((data_length + index_length) / 1024 / 1024), 2) AS 'Total Size (MB)'
FROM information_schema.tables
WHERE table_schema = 'your_database_name'
ORDER BY (data_length + index_length) DESC;

查看二进制日志大小:

sql

复制代码
SHOW BINARY LOGS;

使用监控脚本

创建监控脚本

内存监控脚本:

bash

复制代码
#!/bin/bash
# mysql_memory_monitor.sh

echo "=== MySQL Memory Usage ==="
echo "System Memory:"
free -h

echo -e "\nMySQL Process Memory:"
ps aux | grep mysql | grep -v grep | awk '{print "PID: "$2", MEM: "$4"%, VSZ: "$5", RSS: "$6}'

echo -e "\nMySQL Buffer Pool Usage:"
mysql -u root -p -e "
SHOW VARIABLES LIKE 'innodb_buffer_pool_size';
SHOW STATUS LIKE 'Innodb_buffer_pool_pages%';
" 2>/dev/null

磁盘监控脚本:

bash

复制代码
#!/bin/bash
# mysql_disk_monitor.sh

echo "=== MySQL Disk Usage ==="
echo "Data Directory Size:"
sudo du -sh /var/lib/mysql

echo -e "\nDisk Space:"
df -h /var/lib/mysql

echo -e "\nDatabase Sizes:"
mysql -u root -p -e "
SELECT 
    table_schema AS 'Database',
    ROUND(SUM(data_length + index_length) / 1024 / 1024, 2) AS 'Size (MB)'
FROM information_schema.tables 
GROUP BY table_schema
ORDER BY SUM(data_length + index_length) DESC;
" 2>/dev/null

使用专业监控工具

安装和使用mytop

bash

复制代码
sudo apt install mytop
mytop -u root -p

使用MySQL Workbench

  • 下载并安装MySQL Workbench

  • 连接到MySQL服务器

  • 使用性能仪表板查看详细指标

关键指标解读

内存相关:

  • innodb_buffer_pool_size: InnoDB缓冲池大小

  • key_buffer_size: MyISAM键缓冲大小

  • query_cache_size: 查询缓存大小

磁盘相关:

  • 数据文件 : /var/lib/mysql/ibdata1

  • 日志文件 : /var/lib/mysql/ib_logfile*

  • 二进制日志 : /var/lib/mysql/binlog.*

定期清理(如果需要)

清理二进制日志:

sql

复制代码
PURGE BINARY LOGS BEFORE NOW() - INTERVAL 7 DAY;

优化表:

sql

复制代码
OPTIMIZE TABLE table_name;

这些方法可以帮助你全面了解MySQL在Ubuntu 24.04上的内存和磁盘使用情况。

相关推荐
山峰哥32 分钟前
SQL优化实战:从索引策略到执行计划的极致突破
数据库·sql·性能优化·编辑器·深度优先
总要冲动一次43 分钟前
离线安装 percona-xtrabackup-24
linux·数据库·mysql·centos
lcrml1 小时前
nacos2.3.0 接入pgsql或其他数据库
数据库
阿达_优阅达1 小时前
告别手工对账:xSuite 如何帮助 SAP 企业实现财务全流程自动化?
服务器·数据库·人工智能·自动化·sap·企业数字化转型·xsuite
IvorySQL1 小时前
IvorySQL v5 发布后,我们想听听大家的使用体验
数据库·postgresql·开源
Maverick061 小时前
01- Oracle核心架构:理解数据库如何运转
数据库·oracle·架构
TDengine (老段)2 小时前
TDengine IDMP 组态面板 —— 画布
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
buhuimaren_2 小时前
MySQL数据库初体验
数据库·mysql
IvorySQL2 小时前
PostgreSQL 技术日报 (3月20日)|PGConf.dev 2026 日程公布
数据库·postgresql·开源
华农DrLai2 小时前
什么是Prompt工程?为什么提示词的质量决定AI输出的好坏?
数据库·人工智能·gpt·大模型·nlp·prompt