当前位置: 首页 > news >正文

【记录】Ubuntu20.04安装mysql

1、安装数据库

sudo apt update
sudo apt install mysql-server

2、查看数据库是否运行

sudo systemctl status mysql

若数据库未运行,则执行下述命令打开mysql服务:

sudo systemctl start mysql

3、设置密码

使用MySQL安装附带的脚本mysql_secure_installation; mysql_secure_installation 是 MySQL 官方提供的用于快速配置数据库安全选项的脚本,能帮你设置密码策略、移除匿名用户、禁止 root 远程登录等,提升 MySQL 运行安全性 。

sudo mysql_secure_installation

首先,输入y,开始进行设置

设置密码等级:分为 低 中 高 ,可自行选择,这里我使用0,低级密码

为了方便测试,系统会有一个匿名用户,这里可选择删除或保留,这里我选择保留

询问是否允许使用root用户远程连接数据库,这里我选择n

选择是否删除测试数据库,这里我选择y

选择y,重新加载权限表

4、运行mysql

以上若未设置密码,可通过命令进行密码设置:(修改密码之后,不能够使用sudo mysql登录mysql)

ALTER USER '用户名'@'主机地址' IDENTIFIED WITH mysql_native_password BY '新密码';
FLUSH PRIVILEGES;

5、问题解决

5.1 使用命令连接出错

该错误为权限问题,在root权限下正常

若非root权限,mysql调用/tmp/mysql.sock,但是这个位置并没有对应文件

临时解决方案:

通过命令指定访问的sock位置

mysql -u root -p --socket=/var/run/mysqld/mysqld.sock

永久解决方案:

修改配置文件,指定sock位置

若出现权限问题,还需要更改sock权限

sudo chmod 777 /var/run/mysqld/mysqld.sock

5.2 密码过于简单

执行命令,查看权限要求:

SHOW VARIABLES LIKE 'validate_password%';

短期有效:

SET GLOBAL validate_password.policy=LOW;
SET GLOBAL validate_password.length=4;

永久有效:

可以编辑 MySQL 的配置文件(通常是 /etc/my.cnf 或 /etc/mysql/my.cnf ),在 [mysqld] 配置节下添加或修改以下内容:

[mysqld]
validate_password.policy=LOW
validate_password.length=4

修改完配置文件之后,需要重启mysql服务:

sudo systemctl restart mysql
sudo systemctl status mysql 

5.3 远程连接失败

方式 A:允许特定 IP(最安全,推荐生产环境)
-- 替换 user_name、password、IP 为你的实际值
CREATE USER 'user_name'@'192.168.13.110' IDENTIFIED BY 'password';
GRANT ALL PRIVILEGES ON *.* TO 'user_name'@'192.168.13.110' WITH GRANT OPTION;
FLUSH PRIVILEGES;
  • user_name:你要用于远程连接的用户名(比如 root,但生产不建议用 root)。
  • password:该用户的密码。
  • 192.168.13.110:需要连接的客户端 IP。
方式 B:允许任意 IP(方便测试,生产慎用)
-- 允许 root(或其他用户)从任意 IP 连接
GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' WITH GRANT OPTION;
FLUSH PRIVILEGES;

  • % 表示允许所有 IP 连接,适合测试环境,但生产环境暴露 root@% 有安全风险!

若还不行,需要修改一下配置文件:

修改配置文件:/etc/mysql/mysql.conf.d/mysqld.cnf

http://www.lryc.cn/news/588836.html

相关文章:

  • k8s之Snapshots 详解
  • Apifox 和 Apipost如何选?2025企业API开发工具选型需求分析及建议
  • 前端打包自动压缩为zip--archiver
  • SpringBoot 2.x→3.0升级实战:Jakarta EE兼容性改造清单
  • Flink双流实时对账
  • GaussDB 数据库架构师修炼(三) 集群管理概览
  • 数据结构--树(1)
  • 同样是“跳转”,为何forward地址栏不变,redirect会变?
  • 20250715给荣品RD-RK3588开发板刷Android14时打开USB鼠标
  • MATLAB知识点总结
  • 物联网设备管理工具实战:用AR运维镜击穿6.8天修复魔咒
  • 构建企业级项目管理全面数字化运营体系︱易趋(蓝云软件)总裁唐智勇
  • 学习C++、QT---26(QT中实现记事本项目实现文件路径的提示、现在我们来学习一下C++类模板、记事本的行高亮的操作的讲解)
  • 【PDF识别改名】使用京东云OCR完成PDF图片识别改名,根据PDF图片内容批量改名详细步骤和解决方案
  • pytorch学习笔记(四)-- TorchVision 物体检测微调教程
  • sundog公司的SilverLining SDK库实现3d动态云层和下雨、下雨、雨夹雪效果
  • 终端安全管理系统为什么需要使用,企业需要的桌面管理软件
  • Java 异常处理详解:从基础语法到最佳实践,打造健壮的 Java 应用
  • Spring Boot目录变文件夹?3步解决!
  • AI大模型训练的云原生实践:如何用Kubernetes指挥千卡集群?
  • ETAS 总线接口 ES582.2
  • Bootstrap-HTML(七)Bootstrap在线图标的引用方法
  • 算法学习笔记:23.贪心算法之活动选择问题 ——从原理到实战,涵盖 LeetCode 与考研 408 例题
  • html语法
  • C++题解(37) 信息学奥赛一本通1318:【例5.3】自然数的拆分
  • 测试tcpdump,分析tcp协议
  • 服务器端安全检测与防御技术概述
  • 力扣25.7.15每日一题——有效单词
  • 微信小程序入门实例_____从零开始 开发一个每天记账的微信小程序
  • 深入理解C++11 std::iota:从原理到实践