Linux命令行登录MySQL教程

前提条件

  1. MySQL已安装
    若未安装,执行以下命令:

    # Ubuntu/Debian
    sudo apt update && sudo apt install mysql-server
    # CentOS/RHEL
    sudo yum install mysql-server
    sudo systemctl start mysqld
  2. 确保MySQL服务运行

    sudo systemctl status mysql  # 检查状态
    sudo systemctl start mysql   # 若未运行则启动

进入MySQL的3种常用方式

使用root用户登录(推荐)

   sudo mysql -u root -p
  • -u root:指定用户名(root可替换为其他账户)。
  • -p:提示输入密码(输入时密码不可见)。
  • 注意:在Ubuntu系统中,安装后默认通过sudo mysql可直接免密登录root账户(安全策略差异)。

指定主机和端口登录

   mysql -u 用户名 -p -h 主机地址 -P 端口
  • 示例(连接远程数据库):
    mysql -u admin -p -h 192.168.1.100 -P 3306
  • -h:数据库服务器IP(默认localhost)。
  • -P:端口号(默认3306)。

在命令中直接输入密码(不推荐,仅测试用)

   mysql -u root -p密码  # 注意:-p和密码间无空格

⚠️ 安全警告:密码会暴露在终端历史记录中,存在泄露风险!


常见问题解决

Q1:登录报错”Access denied”

  • 原因:密码错误或用户无权限。
  • 解决
    1. 重置root密码(需停止MySQL服务):
      sudo systemctl stop mysql
      sudo mysqld_safe --skip-grant-tables &
      mysql -u root
    2. 在MySQL中执行:
      FLUSH PRIVILEGES;
      ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码';
      EXIT;
    3. 重启MySQL:
      sudo systemctl restart mysql

Q2:命令未找到”mysql: command not found”

  • 原因:MySQL客户端未安装或路径未包含。
  • 解决
    # 安装MySQL客户端
    sudo apt install mysql-client   # Ubuntu/Debian
    sudo yum install mysql          # CentOS/RHEL

Q3:无法连接远程数据库

  • 步骤检查
    1. 确认远程MySQL允许外部访问(检查bind-address/etc/mysql/mysql.conf.d/mysqld.cnf中是否为0.0.0)。
    2. 用户需有远程权限:
      CREATE USER '用户'@'%' IDENTIFIED BY '密码';
      GRANT ALL PRIVILEGES ON *.* TO '用户'@'%';
      FLUSH PRIVILEGES;
    3. 防火墙放行端口:
      sudo ufw allow 3306/tcp  # Ubuntu
      sudo firewall-cmd --add-port=3306/tcp --permanent  # CentOS

安全建议

  1. 避免使用root账户:日常操作创建普通用户,最小权限分配。
  2. 密码保护
    • 不在命令行直接输入密码。
    • 定期更换密码(MySQL中执行):
      ALTER USER '用户'@'localhost' IDENTIFIED BY '新密码';
  3. 退出MySQL:执行EXIT;Ctrl+D

进入MySQL数据库的核心命令是mysql -u 用户名 -p,结合系统权限和服务状态管理即可完成操作,对于生产环境,务必遵循最小权限原则并定期备份数据,若需深入配置(如SSL加密、用户权限管理),请参考MySQL官方文档。

引用说明:本文操作基于MySQL 8.0及主流Linux发行版,参考MySQL官方手册MySQL 8.0 Reference Manual和Linux系统管理最佳实践,安全建议遵循OWASP密码策略指南。

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

(0)
酷番叔酷番叔
上一篇 2025年6月27日 16:07
下一篇 2025年6月27日 16:25

相关推荐

  • 如何用cat n命令瞬间定位文件关键行?,cat n命令能快速查看文件指定内容吗?,cat命令隐藏了哪些高效技巧?

    cat -n命令用于在终端显示文件内容的同时为每一行添加行号,该功能便于用户快速定位文本位置,常见于日志分析或代码调试场景,在Linux/Unix系统中操作时,只需在文件路径前添加”-n”参数即可实现行号标注。

    2025年6月21日
    1300
  • Linux如何挂载目录?快速教程

    挂载前的准备确认设备标识符使用 lsblk 或 fdisk -l 查看设备信息(如 /dev/sdb1):lsblk -f # 显示设备文件系统类型(如ext4、NTFS)创建挂载点挂载点是一个空目录(通常位于 /mnt 或 /media):sudo mkdir /mnt/mydata # 示例创建挂载点临时挂……

    2025年6月19日
    1400
  • 配置参数怎么选最省钱?

    在Linux系统中测试UDP(用户数据报协议)发包是网络调试、应用开发和性能评估的关键操作,UDP作为无连接的轻量级协议,常用于实时性要求高的场景(如视频流、DNS查询),以下详细介绍多种专业测试方法,均经过实际验证,确保安全可靠,测试前的必要准备防火墙配置临时关闭防火墙(测试后请重新启用):sudo ufw……

    1天前
    300
  • Mac装Linux如何选最佳方案?

    准备工作(必做)备份数据 使用Time Machine或云存储备份所有重要文件(避免安装过程导致数据丢失),检查Mac型号Intel芯片Mac:支持所有Linux发行版(Ubuntu、Fedora等),Apple Silicon(M1/M2):仅支持ARM架构的Linux(如Asahi Linux),查看方法……

    2025年6月30日
    1200
  • Linux下如何进入MySQL命令行?

    前提条件已安装MySQL服务通过包管理器安装(如Ubuntu/Debian的apt、CentOS/RHEL的yum):# Ubuntu/Debiansudo apt update && sudo apt install mysql-server# CentOS/RHELsudo yum inst……

    2025年6月27日
    1300

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信