在Ubuntu中安装配置MySql Server

1.安装MySql Server

在命令行控制台执行安装命令:

bash 复制代码
sudo apt install mysql-server

安装完成后,因为没有root用户的密码,所以,登录不了mysql的cli。另外,MySql 8以上,lower-case-table-names默认值0,且不支持直接修改配置文件的方式实现支持lower-case-table-names=1,需要重新初始化来设置root的密码与lower-case-table-names的值设置为1。

lower_case_table_names 是一个 MySQL 系统变量,它决定了如何存储和比较数据库和表名。这个变量可以设置为以下三个值之一:

  • 0:表名在存储和比较时区分大小写(默认值,Linux 系统通常使用)
  • 1:表名在存储和比较时不区分大小写(Windows 系统通常使用)
  • 2:表名在存储时区分大小写,但在比较时不区分(很少使用)

2.重新初始化

(1)重新初始化,必须停止mysql服务

bash 复制代码
sudo systemctl stop mysql

(2)清空mysql的数据目录中原来的文件前,必须授权给当前用户对此数据目录有操作权限

bash 复制代码
sudo chmod 755 /var/lib/mysql

(3)重新初始化,必须清空mysql的数据目录中原来的文件

bash 复制代码
sudo rm -rf /var/lib/mysql/*

(4)设置mysql配置文件内容

文件路径:/etc/mysql/my.cnf

bash 复制代码
[client]
default-character-set=utf8mb4

[mysql]
default-character-set=utf8mb4

[mysqld]
datadir=/var/lib/mysql
#socket=/var/lib/mysql/mysql.sock
lower_case_table_names=1
default-time_zone='+8:00'
max_connections=1000
max_connect_errors = 10000
init_connect='SET collation_connection = utf8mb4_unicode_ci'
init_connect='SET NAMES utf8mb4'
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci
#skip-character-set-client-handshake
innodb_buffer_pool_size=512M

[mysqld_safe]
log-error=/var/log/mysql/mysqld.log
pid-file=/var/run/mysql/mysqld.pid

#!includedir /etc/mysql/conf.d/
#!includedir /etc/mysql/mysql.conf.d/

(5)重新初始化mysql

bash 复制代码
sudo mysqld --initialize --user=root --lower-case-table-names=1

初始化完成后系统会在控制台输出root用户的初始密码,记下root的初始密码,用于首次登录。

(6)将/var/lib/mysql目录下的所有文件设置为归属mysql用户

否则启动mysql服务时会报错

bash 复制代码
sudo chown mysql:mysql /var/lib/mysql -R

(7)启动mysql服务

bash 复制代码
sudo systemctl start mysql

3.验证

(1)用root用户登录

bash 复制代码
mysql -u root -p

密码使用重置时,系统输出的初始密码。

(2)修改root用户的密码

bash 复制代码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';

use mysql;

update user set Host = '%' where user = 'root';

FLUSH PRIVILEGES;

(3)查看lower-case-table-names变量的值

bash 复制代码
show variables like 'lower_case_table_names';
相关推荐
暮云星影1 小时前
全志linux开发屏幕适配(二)`HDMI`驱动适配说明
linux·arm开发·驱动开发
凡人叶枫1 小时前
Effective C++ 条款38:通过复合塑模出 has-a 或 \“根据某物实现出\
linux·开发语言·c++·windows
charlie1145141911 小时前
嵌入式Linux驱动开发——从轮询到中断
linux·开发语言·驱动开发·嵌入式
无限进步_1 小时前
【Linux】系统级文件I/O与文件描述符深度剖析
linux·运维·服务器
ShineWinsu1 小时前
对于Linux:线程局部存储(TLS)和线程封装的解析
linux·c++·面试·线程·tls·线程封装·线程局部存储
2023自学中1 小时前
imx6ull开发板,sd卡启动运行linux,手动给开发板的 emmc 做分区、烧系统
linux·嵌入式·开发板
暮云星影1 小时前
瑞芯微rk3566开发FIT Secure Boot
linux·arm开发·驱动开发·安全
biter down2 小时前
2:Ubuntu 22.04 LTS 的完整下载教程
linux·运维·ubuntu
零陵上将军_xdr2 小时前
为什么DCL单例要加volatile?——CPU乱序执行与内存屏障
java·linux
杨云龙UP2 小时前
Oracle/ODA RAC /u01 空间告警处理指南:grid 用户监听日志清理_2026-06-15
linux·数据库·oracle·oracle linux·oda·监听日志·在线清理