学习笔记022——Ubuntu 安装 MySQL8.0版本踩坑记录

目录

1、查看可安装 MySQL 版本

2、Ubuntu安装 MySQL8.0

3、MySQL8.0 区分大小写问题

4、MySQL8.0 设置sql_mode 

5、MySQL8.0 改端口33060(个人遇到问题)


1、查看可安装 MySQL 版本

## 列出可用的MySQL版本(列出所有可用的MySQL版本以及其安装状态)
apt-cache policy mysql-server

2、Ubuntu安装 MySQL8.0

# 更新
sudo apt-get update# 安装指定版本的MySQL
sudo apt install mysql-server=<version># 修改配置。
sudo mysql_secure_installation# 根据引导提示,进行选择:
Validate Password Component … (使用密码强度校验组件) n
New Password:(设置新密码,并重复一遍)
Remove anonymous users(删除匿名用户)y
Disallow root login remotely(拒绝远程root账号登录)n
Remove test database and access to it(移除test数据库) y
Reload privilege tables now(现在就重新载入权限表) y# 登录
sudo mysql -uroot -p# 插入root密码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password by'你的密码';# 退出
exit# 编辑mysql配置文件
sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf# 注释下行(开启远程访问)
bind-address=127.0.0.1# wq保存退出# 登录
sudo mysql -uroot -p# 在mysql中依次执行下述sql语句
use mysql;
update user set Host='%' where User='root';
select User, Host from user;
# 查询结果
+------------------+-----------+
| User             | Host      |
+------------------+-----------+
| root             | %         |
| uav              | %         |
| debian-sys-maint | localhost |
| mysql.infoschema | localhost |
| mysql.session    | localhost |
| mysql.sys        | localhost |
+------------------+-----------+
# 刷新
flush privileges;

3、MySQL8.0 区分大小写问题

如果需要设置不区分数据大小写,需要注意的是:mysql8之后,lower_case_table_names参数要在初始化数据库时设置,已经初始化的数据库无法修改了!

只能删除已经初始化的数据,重新初始化时加上参数lower_case_table_names!!!!

mysql 8.0默认区分大小写,但有些系统要求大小写不区分,但已经有数据库的情况就比较麻烦,因为改为不区分大小写需要重建数据库,没有其它办法!

PS:特别注意!!!执行以下操作之前,一定要记得备份重要数据库!出现损失概不负责!

PS:特别注意!!!执行以下操作之前,一定要记得备份重要数据库!出现损失概不负责!

PS:特别注意!!!执行以下操作之前,一定要记得备份重要数据库!出现损失概不负责!

PS:特别注意!!!执行以下操作之前,一定要记得备份重要数据库!出现损失概不负责!

 关闭服务
sudo systemctl stop mysql.service# 删除目前的所有数据库,
# 再次强调!一定要记得备份数据库!!!!数据丢失不负责!!!!
# 再次强调!一定要记得备份数据库!!!!数据丢失不负责!!!!
# 再次强调!一定要记得备份数据库!!!!数据丢失不负责!!!!
# 再次强调!一定要记得备份数据库!!!!数据丢失不负责!!!!# 删除相关
sudo rm -rf /var/lib/mysql
sudo mkdir /var/lib/mysql
sudo chown mysql:mysql /var/lib/mysql
sudo chmod 700 /var/lib/mysql# 编辑配置文件
vim /etc/mysql/mysql.conf.d/mysqld.cnf 
# 将 lower_case_table_names=1  加到 [mysqld]  (必须添加,不然重新初始化mysql会失败)
lower_case_table_names=1# lower_case_table_names=1表示不区分大小写# 重新初始化mysql(会生成新的数据库密码)相当于重装mysql了
sudo mysqld --defaults-file=/etc/mysql/my.cnf --initialize --lower_case_table_names=1 --user=mysql --console# 启动服务
sudo systemctl start mysql.service# 查看临时root密码
sudo grep 'temporary password' /var/log/mysql/error.log# 输入上面获得的临时root密码
sudo mysql -u root -p# mysql要求修改密码,这里主动改一下
alter user 'root'@'localhost' IDENTIFIED BY '你的新密码';# 根据向导删除远程链接等
sudo mysql_secure_installation# 根据引导提示,进行选择:
Validate Password Component … (使用密码强度校验组件) n
New Password:(设置新密码,并重复一遍)
Remove anonymous users(删除匿名用户)y
Disallow root login remotely(拒绝远程root账号登录)n
Remove test database and access to it(移除test数据库) y
Reload privilege tables now(现在就重新载入权限表) y# 检查效果
sudo mysql -u root -p
SHOW VARIABLES LIKE 'lower_case_%';
+------------------------+-------+
| Variable_name          | Value |
+------------------------+-------+
| lower_case_file_system | OFF   |
| lower_case_table_names | 1     |
+------------------------+-------+#################  远程连接问题  ########################
# 编辑mysql配置文件
sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf# 修改
bind-address=0.0.0.0# 进入数据库
sudo mysql -uroot -p# 在mysql中依次执行下述sql语句
use mysql;update user set Host='%' where User='root';select User, Host from user;# 查询结果
+------------------+-----------+
| User             | Host      |
+------------------+-----------+
| root             | %         |
| uav              | %         |
| debian-sys-maint | localhost |
| mysql.infoschema | localhost |
| mysql.session    | localhost |
| mysql.sys        | localhost |
+------------------+-----------+
# 刷新
flush privileges;

4、MySQL8.0 设置sql_mode 

# 编辑配置文件
sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf# 插入下面配置:
sql_mode=STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION

说明在mysql8中,有的人会重启失败。可能是sql_mode中你添加了 NO_AUTO_CREATE_USER


那么,就把 sql_mode 中的 NO_AUTO_CREATE_USER 去掉,就成功解决了。


原因 NO_AUTO_CREATE_USER 在mysql8中已经不支持。

服务重启后,修改后校验:

systemctl restart msyqlmysql -uroot -pselect @@global.sql_mode;

5、MySQL8.0 改端口33060(个人遇到问题)

本人安装MySQL8.0版本时,有需求要将端口由默认是3306改成33060。

发现改死活改不了。只要改成了33060服务就重启失败。

以下是本人的最终解决方案:

1、MySQL8.0除了默认的3306端口之外,还会有个33060端口。3306端口是IPv4,而33060是IPv6。
2、mysqlx=0 只要在Linux系统下的/etc/mysql/mysql.conf.d/mysqld.cnf中,增加这个"mysqlx=0",
3、然后重启,33060和IPv6的字样,从进程中消失了。
4、它的原理就是,MySQL8.0增加了IPv6支持,然后这个配置项可以关闭掉。

vim  /etc/mysql/mysql.conf.d/mysqld.cnf

如上图。将端口改成33060后,在添加一个  mysqlx=0的配置。

格式最好和图中的一样。

然后重启服务就能修改成功了。

🆗了,这就是我的踩坑记录。祝各位好运!

生命不息,折腾不止!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/474864.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

优化装配,提升品质:虚拟装配在汽车制造中的关键作用

汽车是各种零部件的有机结合体&#xff0c;因此汽车的装配工艺水平和装配质量直接影响着汽车的质量与性能。在汽车装配过程中&#xff0c;经常会发生零部件间干涉或装配顺序不合理等现象&#xff0c;且许多零部件制造阶段产生的质量隐患要等到实际装配阶段才能显现出来&#xf…

Office-Tab-for-Mac Office 窗口标签化,Office 多文件标签化管理

Office Tab&#xff1a;让操作更高效&#xff0c;给微软 Office 添加多标签页功能 Office 可以说是大家装机必备的软件&#xff0c;无论学习还是工作都少不了。其中最强大、用的最多的&#xff0c;还是微软的 Microsoft Office。 遗憾的是&#xff0c;微软的 Office 不支持多…

【网络】Socket编程TCP/UDP序列化和反序列化理解应用层(C++实现)Json::Value

主页&#xff1a;醋溜马桶圈-CSDN博客 专栏&#xff1a;计算机网络原理_醋溜马桶圈的博客-CSDN博客 gitee&#xff1a;mnxcc (mnxcc) - Gitee.com 目录 1.基于Socket的UDP和TCP编程介绍 1.1 基本TCP客户—服务器程序设计基本框架 ​编辑1.2 基本UDP客户—服务器程序设计基本框…

架构师:使用 Atomix 实现分布式协调服务的技术指南

1、简述 Atomix 是一个强大的分布式协调框架,提供了分布式数据结构、协调工具和一致性协议,帮助开发者实现高可用、强一致性的分布式系统。它构建于 Raft 和 Paxos 等一致性协议之上,支持创建分布式锁、Leader 选举、分布式 Map、消息发布-订阅等功能,常用于微服务架构和分…

linux之调度管理(9)-SMP cpu hotplug

一、cpu热插拔介绍 在单核时代&#xff0c;操作系统只需要管理一个cpu&#xff0c;当系统有任务要执行时&#xff0c;所有任务在该cpu的就绪队列上排队&#xff0c;调度器根据调度算法选择一个最佳任务执行。当就绪队列上的所有任务都执行完成后&#xff0c;cpu就执行idle进程而…

[JavaWeb]微头条项目

完整笔记和项目代码&#xff1a; https://pan.baidu.com/s/1PZBO0mfpwDPic4Ezsk8orA?pwdwwp5 提取码: wwp5 JavaWeb-微头条项目开发 1 项目简介 1.1 业务介绍 微头条新闻发布和浏览平台,主要包含业务如下 用户功能 注册功能登录功能 头条新闻 新闻的分页浏览通过标题关键字搜…

hhdb数据库介绍(9-24)

计算节点参数说明 failoverAutoresetslave 参数说明&#xff1a; PropertyValue参数值failoverAutoresetslave是否可见是参数说明故障切换时&#xff0c;是否自动重置主从复制关系默认值falseReload是否生效否 参数设置&#xff1a; <property name"failoverAutor…

软件设计师 - 第3章 数据结构

概述 按照存储结构来分&#xff0c;数据结构可以分成如下四种&#xff1a; 线性结构&#xff1a;数据元素间呈现线性关系&#xff0c;有单一的前驱和后继表&#xff1a;可以看做是线性结构的推广&#xff0c;是多个线性结构的集合树&#xff1a;不同于线性结构&#xff0c;其元…

完整http服务器

目录 背景目标描述技术特点开发环境WWW客户端浏览发展史服务端http发展史http分层概览 背景 http协议被广泛使用&#xff0c;从移动端&#xff0c;pc浏览器&#xff0c;http无疑是打开互联网应用窗口的重要协议&#xff0c;http在网络应用层中的地位不可撼动&#xff0c;是能…

详细描述一下Elasticsearch搜索的过程?

大家好&#xff0c;我是锋哥。今天分享关于【详细描述一下Elasticsearch搜索的过程&#xff1f;】面试题。希望对大家有帮助&#xff1b; 详细描述一下Elasticsearch搜索的过程&#xff1f; Elasticsearch 的搜索过程是其核心功能之一&#xff0c;允许用户对存储在 Elasticsea…

springBoot插件打包部署

打包插件spring-boot-maven-plugin 不使用插件&#xff0c;运行时&#xff0c;异常信息为“没有主清单属性” 本地部署 杀进程

[ 网络安全介绍 1 ] 什么是网络安全?

&#x1f36c; 博主介绍 &#x1f468;‍&#x1f393; 博主介绍&#xff1a;大家好&#xff0c;我是 _PowerShell &#xff0c;很高兴认识大家~ ✨主攻领域&#xff1a;【渗透领域】【数据通信】 【通讯安全】 【web安全】【面试分析】 &#x1f389;点赞➕评论➕收藏 养成习…

无插件H5播放器EasyPlayer.js视频流媒体播放器如何开启electron硬解码Hevc(H265)

在数字化时代&#xff0c;流媒体播放器技术正经历着前所未有的变革。随着人工智能、大数据、云计算等技术的融合&#xff0c;流媒体播放器的核心技术不断演进&#xff0c;为用户提供了更加丰富和个性化的观看体验。 EasyPlayer.js H5播放器&#xff0c;是一款能够同时支持HTTP、…

阿里数字人工作 Emote Portrait Alive (EMO):基于 Diffusion 直接生成视频的数字人方案

TL;DR 2024 年 ECCV 阿里智能计算研究所的数字人工作&#xff0c;基于 diffusion 方法来直接的从音频到视频合成数字人&#xff0c;避免了中间的三维模型或面部 landmark 的需求&#xff0c;效果很好。 Paper name EMO: Emote Portrait Alive - Generating Expressive Portra…

Unity脚本基础规则

Unity脚本基础规则 如何在Unity中创建一个脚本文件&#xff1f; 在Project窗口中的Assets目录下&#xff0c;选择合适的文件夹&#xff0c;右键&#xff0c;选择第一个Create&#xff0c;在新出现的一栏中选择C# Script&#xff0c;此时文件夹内会出现C#脚本图标&#xff0c;…

基于YOLOv8深度学习的无人机航拍小目标检测系统(PyQt5界面+数据集+训练代码)

本研究提出并实现了一种基于YOLOv8深度学习模型的无人机航拍小目标检测系统&#xff0c;旨在解决高空环境下汽车目标检测的技术难题。随着无人机技术的发展&#xff0c;航拍图像已广泛应用于交通监控、城市管理、灾害应急等多个领域。然而&#xff0c;由于无人机通常在较高的飞…

Excel如何把两列数据合并成一列,4种方法

Excel如何把两列数据合并成一列,4种方法 参考链接:https://baijiahao.baidu.com/s?id=1786337572531105925&wfr=spider&for=pc 在Excel中,有时候需要把两列或者多列数据合并到一列中,下面介绍4种常见方法,并且提示一些使用注意事项,总有一种方法符合你的要求:…

VSCode自定义插件创建教程

文章目录 一、前言二、插件维护三、调试插件四、使用 vsce 生成 vsix 插件五、问题&#xff1a;打开调试窗口后&#xff0c;输入helloworld并没有指令提示六、插件创建实战七、拓展阅读 一、前言 对于前端程序猿来讲&#xff0c;最常用的开发利器中VSCode首当其冲&#xff0c;…

HarmonyOS Next 关于页面渲染的性能优化方案

HarmonyOS Next 关于页面渲染的性能优化方案 HarmonyOS Next 应用开发中&#xff0c;用户的使用体验至关重要。其中用户启动APP到呈现页面主要包含三个步骤&#xff1a; 框架初始化页面加载布局渲染 从页面加载到布局渲染中&#xff0c;主要包含了6个环节&#xff1a; 执行页…

深度学习之目标检测的技巧汇总

1 Data Augmentation 介绍一篇发表在Big Data上的数据增强相关的文献综述。 Introduction 数据增强与过拟合 验证是否过拟合的方法&#xff1a;画出loss曲线&#xff0c;如果训练集loss持续减小但是验证集loss增大&#xff0c;就说明是过拟合了。 数据增强目的 通过数据增强…