2G服务器优化MySQL内存配置指南

目录

编辑MySQL配置文件

重启MySQL服务

检查服务状态

创建慢查询日志目录和文件


为了在2G内存的学习服务器里运行MySQL、redis和spring boot项目,需要通过配置减少MySQL的内存占用

复制代码
# 备份配置文件
sudo cp /etc/my.cnf /etc/my.cnf.backup.$(date +%Y%m%d)

编辑MySQL配置文件

一般在/etc/my.cnf,增加以下配置

复制代码
# ========== 内存优化(针对2G服务器) ==========

# MyISAM键缓存(如果不用MyISAM可以更小)
key_buffer_size = 8M

# 连接设置
max_connections = 30  # 限制连接数
thread_cache_size = 4
table_open_cache = 200

# 临时表内存
tmp_table_size = 16M
max_heap_table_size = 16M

# 排序缓冲
sort_buffer_size = 256K
read_buffer_size = 128K
read_rnd_buffer_size = 256K
join_buffer_size = 128K

# ========== 性能优化:InnoDB日志 ==========
innodb_log_buffer_size = 8M
innodb_log_file_size = 32M
innodb_file_per_table = 1
innodb_flush_method = O_DIRECT
innodb_flush_log_at_trx_commit = 2   # 平衡性能和数据安全
# InnoDB缓冲池 - 最重要!设为128M
innodb_buffer_pool_size = 128M
innodb_stats_on_metadata = OFF

# ========== 关闭不必要功能节省内存 ==========
# 关闭性能模式(节省大量内存)
performance_schema = OFF
table_definition_cache = 400
skip_name_resolve = 1
explicit_defaults_for_timestamp = 1

# ========== 慢查询日志设置 ==========
slow_query_log = 1
slow_query_log_file = /var/log/mysql/slow-query.log # 指定慢查询日志文件路径
long_query_time = 2  # 慢查询时间阈值为2秒

# ========== 字符集 ==========
character-set-server = utf8mb4
collation-server = utf8mb4_unicode_ci

[mysql]
default-character-set = utf8mb4

[client]
default-character-set = utf8mb4
socket=/var/lib/mysql/mysql.sock

重启MySQL服务

复制代码
sudo systemctl restart mysqld 2>/dev/null || sudo systemctl restart mysql

检查服务状态

复制代码
sudo systemctl status mysqld 2>/dev/null || sudo systemctl status mysql

服务状态: active (running)表示成功重启

启动时间: 2025-12-23 16:01:16 CST(已运行2分12秒)

创建慢查询日志目录和文件

复制代码
# 创建MySQL日志目录
sudo mkdir -p /var/log/mysql

# 创建慢查询日志文件
sudo touch /var/log/mysql/slow-query.log

# 设置正确的所有者和权限
sudo chown -R mysql:mysql /var/log/mysql
sudo chmod 750 /var/log/mysql
sudo chmod 640 /var/log/mysql/*.log

# 查看创建结果
ls -la /var/log/mysql/
相关推荐
Nontee10 分钟前
新手数据库进阶:大白话图解四大隔离级别与底层机制
数据库·oracle
dishugj15 分钟前
【YashanDB 认证】我的崖山数据库初体验:从陌生到上手的成长之路
数据库
前端 贾公子18 分钟前
Claude Code 的 skills 源码解析 (上)
数据库·人工智能
吠品21 分钟前
.NET 8 单文件发布:把 exe 和一堆 dll 打进一个文件里
服务器·数据库·windows
cmes_love32 分钟前
期货五档tick数据下载教程期权五档高频历史数据以及分钟量化回测下载
数据库
蚂蚁数据AntData35 分钟前
从ChatBI到业务记忆:重新定义数据智能的生产力边界
大数据·网络·数据库·人工智能·算法
Quincy_Freak39 分钟前
技术随笔|银河麒麟aarch64内网轻量数据分析工具 SQLiteGo 使用体验
大数据·数据库·数据挖掘·数据分析·sqlite·银河麒麟·aarch64
Amnesia0_040 分钟前
MySQL视图和用户管理
数据库·mysql
matrixmind11 小时前
aiomysql:异步场景下的 MySQL 驱动
android·数据库·mysql·其他
数据库小学妹1 小时前
时序数据怎么存?InfluxDB、TDengine、TimescaleDB与国产融合方案选型实战
大数据·数据库·经验分享·时序数据库·dba