云服务器——MySQL设置

MySQL设置

用的时候再启动

关掉开机自启:sudo systemctl disable mysqld

开启开机自启:sudo systemctl enable mysqld

python 复制代码
# 查看MySQL当前状态
sudo systemctl status mysqld

# 关闭MySQL服务
sudo systemctl stop mysqld

# 开启MySQL服务
sudo systemctl start mysqld

远程访问设置

python 复制代码
# 1.root用户登陆
mysql -u root -p

# 2.查看所有用户
select user,host from mysql.user;
# user:是用户名
# host:允许登陆的地址
	localhost:只能连本机
	%允许任何IP远程连接

# 3.创建一个用户并允许远程连接,MySQL8.0开始密码必须有大小写字母+数字+特殊符号
create user '用户名'@'%' identified by '密码'

# 4.给用户赋予权限
GRANT SELECT, INSERT, UPDATE, DELETE, CREATE, ALTER, DROP, INDEX, EXECUTE ON testdb.* TO '用户名'@'%';
# 给用户赋予所有权限(谨慎操作)
# grant all privileges on *.* to 'testuser'@'%';

# 5.刷新权限
flush privileges;

# 6.查看用户权限
show grants for 'testuser'@'%';

# 7.删除用户
drop user 'testuser'@'%';

重置密码

python 复制代码
# 停止mysql服务
systemctl stop mysqld

# 切换到运行用户(如 mysql),禁止远程连接,仅本地可用
# --skip-grant-tables:跳过权限验证,免密登录;
# --skip-networking:禁止远程连接,避免安全风险;
# 保持当前终端窗口不关闭,进程后台运行。
sudo -u mysql mysqld --skip-grant-tables --skip-networking &

# 新开终端,无密码登录
mysql -u root

# 刷新权限,让改密生效
FLUSH PRIVILEGES;  

# 替换为复杂密码(建议8位+大小写+数字+符号)(MySQL 8.0+ 必用 ALTER USER)
ALTER USER 'root'@'localhost' IDENTIFIED BY '你的新强密码';  

# 再次刷新,确保生效
FLUSH PRIVILEGES;  

exit;  # 退出客户端

# 杀死免权限进程(可通过 ps -ef | grep mysql 确认)
sudo pkill -f "mysqld --skip-grant-tables"

# 启动正常服务
systemctl start mysql

# 验证登录
# 输入新密码即可登录
mysql -u root -p  

数据库、表设置

数据库

python 复制代码
# 查看所有数据库
show database;

# 创建数据库
create database test;

# 进入某个数据库
use test;

python 复制代码
# 查看库中所有表
show tables;

# 查看表结构
desc test;

# 查看具体的建表语句
show create table 表名;

遇到的问题

1.创建数据库报错

python 复制代码
create datebases test;
ERROR 1064 (42000): You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'datebases test' at line 1

原因:

python 复制代码
databases关键字错了,是databases,没有s

2.创建用户报错

python 复制代码
ERROR 1819 (HY000): Your password does not satisfy the current policy requirements

原因:

python 复制代码
MySQL 8.0 默认启用了密码强度验证插件(validate_password)。设置的密码太简单,不符合系统的安全策略(通常要求:包含大小写字母、数字、特殊字符,且长度至少 8 位)。

3.链接数据库报错

python 复制代码
Public Key Retrieval is not allowed

原因:

python 复制代码
MySQL 是 8.0+ 版本,默认开启了密码加密验证,连接时需要允许公钥获取。在数据库连接地址后追加:allowPublicKeyRetrieval=true&useSSL=false
相关推荐
lhbian2 小时前
PHP、C++和C语言对比:哪个更适合你?
android·数据库·spring boot·mysql·kafka
路由侠内网穿透.2 小时前
本地部署开源客服系统 FreeScout 并实现外部访问( Windows 版本)
运维·服务器·网络·windows·网络协议
Dream of maid2 小时前
Mysql(9)事务
数据库·mysql
束尘2 小时前
Vue3 项目集成 OnlyOffice 在线编辑 + 自定义插件开发(二):插入功能全实现
数据库·vue.js·mysql
xuhaoyu_cpp_java3 小时前
MySql学习(二)
经验分享·笔记·学习·mysql
向宇it3 小时前
关闭SSH密码登录,SSH 如何使用公钥密钥登录服务器(解决服务器经常被攻击问题)
服务器·网络·ssh
大卡片3 小时前
进程间通信
linux·运维·服务器
神の愛3 小时前
@Pattern,@NotBlank
数据库·mysql
张小姐的猫3 小时前
【Linux】进程信号(上)—— 信号产生 | 保存信号
linux·运维·服务器