Ubuntu快捷安装MySQL

更新包列表

bash 复制代码
sudo apt update

安装mysql

bash 复制代码
sudo apt install mysql-server

启动mysql

sql 复制代码
// 启动mysql
sudo service mysql start

// 关闭mysql
sudo service mysql stop

// 重启mysql
sudo service mysql restart

连接mysql

sql 复制代码
// 初始安装无密码,直接连接即可,端口号默认3306
mysql -uroot

设置密码

sql 复制代码
ALTER USER 'root'@'localhost' IDENTIFIED BY '123456';

注:设置完密码后,后续如果使用 mysql -uroot -h127.0.0.1 -pkingsoft. -P3306(可使用 mysql -uroot -h localhost -pkingsoft. -P3306 命令代替)命令连接mysql时,可能会报错:

原因分析:

MySQL的 root 用户没有配置为允许从 127.0.0.1 这个地址连接。默认情况下,root 用户通常只能从 localhost 连接,而不是从 127.0.0.1。虽然 localhost 和 127.0.0.1 在很多情况下是等价的,但MySQL的权限系统会将它们视为不同的主机。

查看mysql root用户

sql 复制代码
SELECT User, Host FROM mysql.user WHERE User = 'root';

执行结果:

由上述查询结果可知,root 用户确实没有配置允许从 127.0.0.1 这个地址连接。

修改或创建用户权限

sql 复制代码
// 创建用户(如果尚未存在)
CREATE USER 'root'@'127.0.0.1' IDENTIFIED BY 'kingsoft.';

// 授予权限
GRANT ALL PRIVILEGES ON *.* TO 'root'@'127.0.0.1' WITH GRANT OPTION;

// 刷新权限,上述创建用户、授予权限操作只会被记录在mysql.user表中,需执行下述命令将其加载到缓存中方可生效
FLUSH PRIVILEGES;

// 查看mysql root用户
SELECT User, Host FROM mysql.user WHERE User = 'root';

执行结果:

注1:如果不加127.0.0.1,则本地proxy无法连接到mysql。

注2:在 MySQL 5.7 及更高版本中,GRANT 语句和 IDENTIFIED BY 子句是分开的。您需要先创建用户(如果尚未存在),然后再授予权限。

注3:localhost、127.0.0.1仅限本机连接,如果想让公网上别的机器也能连接到mysql,需要把root用户的host字段改为'%',修改命令如下:

sql 复制代码
// 更新root用户host权限
update mysql.user set host='%' where user='root';

查看mysql读取my.cnf的顺序

sql 复制代码
// 如果不知道mysql使用的哪个配置文件,可以使用该命令查看mysql读取配置文件的顺序
mysqld --verbose --help | grep -A 1 'Default options'

// 找到mysql使用的配置文件后,就可按自己需要对配置文件进行修改
// 修改后重启mysql即可
// 我的本地机器上没有 /etc/my.cnf 文件,所以修改 /etc/mysql/my.cnf
vim /etc/mysql/my.cnf

执行结果:

注:如果 /etc/my.cnf 文件存在,则优先使用该文件,如果 /etc/my.cnf 文件不存在,则使用 /etc/mysql/my.cnf 文件,以此类推。

相关推荐
洛克大航海7 分钟前
解锁 PySpark SQL 的强大功能:有关 App Store 数据的端到端教程
linux·数据库·sql·pyspark sql
XueminXu1 小时前
ClickHouse数据库的表引擎
数据库·clickhouse·log·表引擎·mergetree·special·integrations
冒泡的肥皂2 小时前
MVCC初学demo(二
数据库·后端·mysql
代码程序猿RIP2 小时前
【Redis 】Redis 详解以及安装教程
数据库·etcd
小生凡一2 小时前
redis 大key、热key优化技巧|空间存储优化|调优技巧(一)
数据库·redis·缓存
oe10192 小时前
好文与笔记分享 A Survey of Context Engineering for Large Language Models(上)
数据库·笔记·语言模型·agent·上下文工程
小马哥编程2 小时前
【软考架构】案例分析-对比MySQL查询缓存与Memcached
java·数据库·mysql·缓存·架构·memcached
一 乐2 小时前
高校后勤报修系统|物业管理|基于SprinBoot+vue的高校后勤报修系统(源码+数据库+文档)
java·前端·javascript·数据库·vue.js·毕设
折翼的恶魔2 小时前
SQL190 0级用户高难度试卷的平均用时和平均得分
java·数据库
煎蛋学姐3 小时前
SSM基于框架在线电影评论投票系统3gr0f(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·系统开发·ssm 框架·在线电影评论投票系统