MySQL5.7之数据库初始化过程

文章目录

参考

本文章参考

当通过tar包或者源码包安装完MySQL之后,需要执行数据目录初始化操作

bash 复制代码
## 如果不指定--datadir;默认是usr/local/mysql目录
bin/mysqld --initialize --user=mysql --basedir=/opt/mysql/mysql --datadir=/opt/mysql/mysql/data

在执行这条命令后mysqld做了什么?

  1. 检查数据目录是否存在,不存在则创建它,创建失败报错mysqld: Can't create directory '/usr/local/mysql/data/' (Errcode: 2 - No such file or directory)

  2. 如果数据目录存在但是不为空(存在文件或者子目录)则报错退出[ERROR] --initialize specified but the data directory has files in it. Aborting.出现这种情况只需要把这个目录删除、移走、重命名即可。

  3. 在数据目录中创建mysql数据库和里面的表,包括grant表、time zone 表, server-side help 表。

  4. 初始化管理InnoDB表所需的系统表空间以及相关数据结构。

    在mysqld设置InnoDB系统表空间后,表空间特性的一些更改需要建立全新的实例。符合要求的更改包括系统表空间中第一个文件的文件名和撤销日志的数量。如果不希望使用默认值,请确保在运行mysqld之前,MySQL配置文件中已设置了 innodb_data_file_pathinnodb_log_file_size配置参数的设置。同时,请根据需要指定其他影响InnoDB文件创建和位置的参数,如innodb_data_home_dirinnodb_log_group_home_dir

    如果这些选项在您的配置文件中,但该文件不在MySQL默认读取的位置,请在运行mysqld时使用--defaults-extra-file选项指定文件位置。

  5. 创建 'root'@'localhost' 超级root账户和其他预留账户,有些预留账户是locked状态不能被使用的。

    • 如果有参数 --initialize,root账号会随机生成密码。
    • 如果有参数 --initialize-insecure,root不会设置密码
  6. 服务器初始化用于HELP语句的server-side help 表,服务器不会初始化time zone 表。

  7. 如果为init_file系统变量指定了一个包含SQL语句的文件名,则服务器将执行该文件中的语句。此选项允许您执行自定义的引导序列。

    当服务器以引导模式运行时,某些功能不可用,这限制了文件中允许的语句。这些语句包括与帐户管理(如CREATE USER或GRANT)、复制和全局事务标识符相关的语句。

  8. 退出

相关推荐
九皇叔叔42 分钟前
Linux Shell 正则表达式:从入门到实战,玩转文本匹配与处理
linux·mysql·正则表达式
DokiDoki之父1 小时前
Mybatis—入门 & (配置)SQL提示和日志输出
数据库·sql·mybatis
Wang's Blog2 小时前
MySQL: 高并发电商场景下的数据库架构演进与性能优化实践
mysql·性能优化·数据库架构
TDengine (老段)2 小时前
TDengine 数据函数 LN 用户手册
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
机灵猫2 小时前
Redis 在订单系统中的实战应用:防重、限流与库存扣减
数据库·redis·缓存
木易2.02 小时前
从零构建RAG知识库管理系统(二)
数据库·oracle
程序新视界2 小时前
什么是MySQL JOIN查询的驱动表和被驱动表?
数据库·后端·mysql
lingggggaaaa3 小时前
小迪安全v2023学习笔记(一百三十四讲)—— Windows权限提升篇&数据库篇&MySQL&MSSQL&Oracle&自动化项目
java·数据库·windows·笔记·学习·安全·网络安全
小光学长3 小时前
基于Vue的保护动物信息管理系统r7zl6b88 (程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
一匹电信狗3 小时前
【MySQL】数据库的相关操作
linux·运维·服务器·数据库·mysql·ubuntu·小程序