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

相关推荐

  • linux如何调用chroot

    Linux中,使用chroot命令切换根目录,通常格式为:`chroot

    2025年8月14日
    1400
  • Linux脚本如何循环检测网口状态?

    在Linux系统中,循环检测网口状态是网络运维中的常见需求,例如监控网口是否UP、流量异常、丢包情况等,以便及时发现网络故障,通过编写bash脚本结合系统工具,可以实现自动化的循环检测,以下是具体实现方法和注意事项,明确检测目标在编写脚本前,需先确定检测的具体内容,常见的网口检测指标包括:网口状态:是否处于UP……

    2025年8月23日
    1500
  • U盘插上怎么查不到设备标识?

    制作Linux系统U盘启动盘详细指南准备工作硬件需求容量≥8GB的U盘(推荐USB 3.0接口)备用存储设备(用于备份U盘原有数据)软件资源Linux镜像文件:从官方渠道下载ISO文件(如Ubuntu官网、Fedora官方站点)启动盘制作工具(任选其一):Windows:Rufus(推荐)、BalenaEtch……

    2025年8月9日
    2000
  • 为什么早睡早起身体好吗

    在Linux系统中,处理文本时经常需要去除特殊字符(如!@#$%^&*()、制表符、换行符等),这些字符可能导致脚本错误、数据解析失败或安全风险,以下是多种经过验证的专业方法,适用于不同场景:什么是特殊字符?特殊字符指非字母数字的常规字符(ASCII 0-32及127-255),常见于:控制字符:换行符……

    2025年7月19日
    2800
  • linux如何看延迟

    Linux 中,可通过 ping 命令查看网络延迟,如 `ping www.

    2025年8月19日
    1700

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信