Ubuntu24.04安装MYSQL8.0

更新源

复制代码
sudo apt update

安装mysql服务 默认安装最新版本

复制代码
sudo apt install mysql-server

检查安装版本

复制代码
mysql --version

检查mysql运行状态

复制代码
systemctl  status mysql

开启远程访问,在ubuntu下mysql默认是只允许本地访问

复制代码
sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf

重启mysql

复制代码
sudo systemctl restart mysql

==============================================================================================

设置数据库关闭表名库名区分大小写

mysql8.0数据库表名默认是区分大小写的,但部署的项目需要关闭,所以服务器部署时需要设置关闭,好像还不能通过执行命令关闭,只能在安装时在mysql的配置文件中一开就就设置关闭的字段,官方文档建议在初始化数据库时设置。

复制代码
lower_case_table_names=1

使用于初次安装时使用,若使用后再需要修改,请先进行数据备份。修改步骤如下:

shell 复制代码
# 第一步:停止MySQL服务
sudo systemctl stop mysql
# 第二步:备份配置文件
sudo cp /etc/mysql/mysql.conf.d/mysqld.cnf /etc/mysql/mysql.conf.d/mysqld.cnf.backup
# 第三步:停止服务
sudo service mysql stop
# 第四步:卸载刚安装的MySQL
sudo apt --purge autoremove mysql-server
# 第五步:删除目录/var/lib/mysql
sudo rm -rf /var/lib/mysql
# 第六步:还原配置文件
sudo cp /etc/mysql/mysql.conf.d/mysqld.cnf.backup /etc/mysql/mysql.conf.d/mysqld.cnf
# 第七步:编辑配置文件
# 在myisam-recover-options  = BACKUP下添加lower_case_table_names=1
sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf
# 第八步:重新安装MySQL
sudo apt install mysql-server
# 安装过程中提示
# 配置文件 '/etc/mysql/mysql.conf.d/mysqld.cnf'
# ==> 系统中的这个文件或者是由您创建的,或者是由脚本建立的。
# ==> 软件包维护者所提供的软件包中也包含了该文件。
#   您现在希望如何处理呢? 您有以下几个选择:
#    Y 或 I  :安装软件包维护者所提供的版本
#    N 或 O  :保留您原来安装的版本
#      D     :显示两者的区别
#      Z     :把当前进程切换到后台,然后查看现在的具体情况
# 默认的处理方法是保留您当前使用的版本。
# *** mysqld.cnf (Y/I/N/O/D/Z) [默认选项=N] ?
 
# 选择N,使用自定义的文件版本
# 第九步:重启服务
sudo systemctl start mysql
# 查看服务状态
systemctl status mysql

检查是否安装成功

复制代码
sudo mysql -u root -p  # 输入root用户密码

mysql> use mysql

mysql> SHOW VARIABLES LIKE 'lower_case_%';

修改成功

==========================================================================

给mysql设置新用户并允许外部网络通过密码连接

登录mysql

shell 复制代码
sudo mysql -u root -p  # 输入root用户密码登录mysql

进入库名称为"mysql"的数据库

shell 复制代码
use mysql

创建新用户并设置密码:

shell 复制代码
CREATE USER 'root1'@'%' IDENTIFIED BY 'root';

这里的'%'表示允许任何IP地址连接,你也可以指定特定的IP地址或子网。root1是创建的新用户名,root是新密码。

授予新用户权限:

shell 复制代码
GRANT ALL PRIVILEGES ON *.* TO 'root1'@'%';

这条命令授予root1对所有数据库的所有权限。你可以根据需要调整权限范围和类型。

刷新权限使更改生效

复制代码
FLUSH PRIVILEGES;

使用navicat远程连接mysql数据库

相关推荐
a程序小傲1 天前
京东Java面试被问:动态规划的状态压缩和优化技巧
java·开发语言·mysql·算法·adb·postgresql·深度优先
007php0071 天前
mySQL里有2000w数据,Redis中只存20w的数据,如何保证Redis中的数据都是热点数据
数据库·redis·git·mysql·面试·职场和发展·php
lkbhua莱克瓦241 天前
进阶-存储过程3-存储函数
java·数据库·sql·mysql·数据库优化·视图
碎像1 天前
10分钟搞定 MySQL 通过Binlog 数据备份和恢复
数据库·mysql
岁岁种桃花儿1 天前
MySQL 8.0 基本数据类型全面解析
数据库·mysql·数据库开发
chuxinweihui1 天前
MySQL数据库基础
数据库·mysql
无敌的牛1 天前
MySQL基础
数据库·mysql
鱼跃鹰飞1 天前
面试题:解释一下什么是全字段排序和rowid排序
数据结构·数据库·mysql
Dxy12393102161 天前
MySQL连表查询讲解:从基础到实战
数据库·mysql
韩立学长1 天前
【开题答辩实录分享】以《兴趣班预约管理系统的设计与实现》为例进行选题答辩实录分享
java·mysql·intellij idea