Linux如何配置MySQL数据库服务器?

在Linux系统中配置MySQL数据库服务器是搭建动态应用服务的关键步骤,本文将详细从安装、初始化、安全配置到用户管理、参数优化等环节展开说明,帮助用户完成稳定可用的MySQL服务部署。

linux如何配置mysql数据库服务器

安装MySQL服务器

不同Linux发行版的安装命令存在差异,需根据系统选择合适的方式,以下以主流的Ubuntu/Debian和CentOS/RHEL为例:

发行版 安装命令 说明
Ubuntu/Debian sudo apt update && sudo apt install mysql-server 自动安装MySQL服务及依赖,默认配置文件位于/etc/mysql/mysql.conf.d/
CentOS/RHEL sudo yum install mysql-server(CentOS 7+)或sudo dnf install mysql-server(CentOS 8+) 需先启用EPEL源,配置文件路径为/etc/my.cnf/etc/my.cnf.d/

安装完成后,通过systemctl status mysql检查服务状态,若未启动则执行sudo systemctl start mysql并设置开机自启sudo systemctl enable mysql

初始化安全配置

MySQL首次启动后会生成匿名用户和测试数据库,需通过安全脚本加固:

sudo mysql_secure_installation

该交互式脚本将引导完成以下操作:

  1. 设置root密码:输入强密码并确认,避免使用简单组合;
  2. 移除匿名用户:禁止匿名登录,提升安全性;
  3. 禁止root远程登录:限制root仅允许本地连接(如需远程需单独配置);
  4. 移除测试数据库:删除test等默认数据库,避免未授权访问;
  5. 重新加载权限表:使配置立即生效。

用户与权限管理

MySQL通过用户和权限表控制访问,常用操作如下:

  1. 创建用户

    CREATE USER 'app_user'@'localhost' IDENTIFIED BY 'StrongPassword123!';

    其中'app_user'为用户名,'localhost'限制仅本地连接,若需远程可替换为。

    linux如何配置mysql数据库服务器

  2. 授权

    GRANT SELECT, INSERT, UPDATE ON mydb.* TO 'app_user'@'localhost';

    授予app_usermydb数据库所有表的查询、插入、更新权限,表示所有数据库所有表(需谨慎使用)。

  3. 刷新权限

    FLUSH PRIVILEGES;
  4. 查看用户与权限

    SELECT User, Host FROM mysql.user;  -- 查看所有用户
    SHOW GRANTS FOR 'app_user'@'localhost';  -- 查看指定用户权限

配置文件优化

MySQL核心配置文件为my.cnf(Ubuntu)或my.cnf(CentOS),可通过调整参数提升性能,常见优化项如下:

[mysqld]
# 数据存储路径
datadir=/var/lib/mysql
# socket文件路径
socket=/var/run/mysqld/mysqld.sock
# 字符集(推荐utf8mb4)
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci
# 缓冲区大小(根据服务器内存调整,建议为内存的50%-70%)
innodb_buffer_pool_size=1G
# 最大连接数
max_connections=200
# 慢查询日志(用于性能排查)
slow_query_log=1
slow_query_log_file=/var/log/mysql/slow-query.log
long_query_time=2

修改后需重启MySQL服务:sudo systemctl restart mysql

防火墙配置

若需远程访问MySQL(默认端口3306),需开放防火墙端口:

linux如何配置mysql数据库服务器

  • CentOS(firewalld)
    sudo firewall-cmd --permanent --add-port=3306/tcp
    sudo firewall-cmd --reload
  • Ubuntu(ufw)
    sudo ufw allow 3306/tcp

测试连接

  1. 本地连接

    mysql -u root -p

    输入root密码后进入MySQL命令行,执行SELECT VERSION();验证安装。

  2. 远程连接
    在客户端工具(如Navicat、DBeaver)中输入服务器IP、端口(3306)、用户名及密码,确保用户已授权远程访问且防火墙放行。

相关问答FAQs

Q1:忘记MySQL root密码怎么办?
A1:可通过跳过权限表重置密码,步骤如下:

  1. 停止MySQL服务:sudo systemctl stop mysql
  2. 跳过权限表启动:sudo mysqld_safe --skip-grant-tables &
  3. 无密码登录:mysql -u root
  4. 执行重置密码SQL(MySQL 5.7+):
    UPDATE mysql.user SET authentication_string=PASSWORD('NewPassword123!') WHERE User='root';
    FLUSH PRIVILEGES;
  5. 正常启动MySQL:sudo systemctl start mysql,使用新密码登录。

Q2:如何允许特定IP远程连接MySQL?
A2:需同时修改用户权限和防火墙配置:

  1. 创建允许远程的用户(或修改现有用户):
    CREATE USER 'remote_user'@'192.168.1.100' IDENTIFIED BY 'RemotePassword123!';
    GRANT ALL PRIVILEGES ON mydb.* TO 'remote_user'@'192.168.1.100';
    FLUSH PRIVILEGES;

    其中168.1.100为允许访问的客户端IP;

  2. 确保MySQL配置文件bind-address设置为0.0.0(允许所有IP连接)或指定IP;
  3. 开放服务器防火墙的3306端口(参考第五部分)。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/23004.html

(0)
酷番叔酷番叔
上一篇 2025年9月10日 14:15
下一篇 2025年9月10日 14:29

相关推荐

  • Linux如何高效查看日历?命令行与图形界面技巧

    命令行工具(高效快捷)cal 命令(基础日历)基本使用:终端输入 cal 直接显示当前月日历:$ cal 七月 2024日 一 二 三 四 五 六 1 2 3 4 5 6 7 8 9 10 11 12 1314 15 16 17 18 19 2021 22 23 24 25 26 2728 29 30 31扩展……

    2025年6月16日
    5000
  • Linux环境下数据库备份的详细方法与操作步骤有哪些?

    在Linux系统中,数据库备份是保障数据安全的核心操作,无论是应对硬件故障、误操作还是恶意攻击,完善的备份机制都能快速恢复数据,降低业务损失,Linux环境下主流数据库(如MySQL、PostgreSQL、MongoDB等)均有成熟的备份工具和方法,需根据数据库类型、业务需求(如恢复时间目标RTO、恢复点目标R……

    2025年9月9日
    2600
  • 如何用systemctl管理systemd服务?

    在Linux系统中,服务(Service)是运行在后台的应用程序,通常用于提供特定功能(如Web服务、数据库等),查询服务状态是系统管理的基础操作,无论是检查服务是否正常运行、排查故障,还是管理启动项,都需要掌握相关命令,以下是多种查询Linux服务的详细方法,适用于主流发行版(如Ubuntu、CentOS、D……

    2025年7月31日
    3400
  • Linux系统中如何查看磁盘分区信息的详细步骤和方法呢?

    在Linux系统中,查看分区信息是系统管理和维护的基础操作,无论是排查磁盘空间不足、调整分区布局,还是确认文件系统类型,都需要准确掌握分区状态,Linux提供了多种命令行和图形化工具来查看分区信息,本文将详细介绍这些方法的使用场景、操作步骤及示例输出,帮助用户全面掌握Linux分区查看技巧,命令行工具查看分区命……

    2025年8月29日
    3400
  • Linux系统下telnet登录密码修改的具体步骤是什么?

    在Linux系统中,修改telnet密码的核心逻辑并非直接修改telnet服务的独立密码,而是通过修改系统用户的登录密码来实现,因为telnet服务默认依赖系统的PAM(可插拔认证模块)进行用户认证,telnet协议本身存在明文传输密码的安全风险,因此在实际生产环境中强烈建议使用更安全的SSH协议替代,但若因兼……

    2025年8月26日
    3400

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信