您当前的位置:首页 > 互联网教程

MySQL8初始化、账户创建及权限分配

发布时间:2025-05-21 12:53:45    发布人:远客网络

MySQL8初始化、账户创建及权限分配

一、MySQL8初始化、账户创建及权限分配

访问 MySQL官网下载适合 Mac OS的 MySQL安装包,选择安装版本。

解压下载的文件,命名三个文件夹为 master、slave1、slave2。

在 master文件夹的 support-files目录下新建 my.conf配置文件,slave1和 slave2同样操作。

MySQL 8需要手动创建初始化数据目录,初始化操作在使用前执行。

启动 MySQL服务,执行初始化命令。

初始化完成后,随机生成的密码会记录在日志文件中,使用此密码登录并修改初始密码。

关注 slave的 Slave_IO_Running和 Slave_SQL_Running状态,确保两者均为 Yes,即表示同步无误。同样步骤适用于 slave2。

二、mysql初始化密码MySQL8下忘密码后重置密码的办法

1、MySQL的密码是存放在user表里面的,修改密码其实就是修改表中记录。

2、重置的思路是是想办法不用密码进入系统,然后用数据库命令修改表user中的密码记录。

3、查了下,MySQL5系统在网上建议的方法是以--skip-grant-tables参数启动mysql服务,该参数指示在启动时不加载授权表,因此启动成功后root用户可以空密码登陆

4、mysqld–skip-grant-tables登陆之后可以用

5、UPDATE user SET authentication_string='' WHERE user='root';这类命令设置密码或者将密码置空。

6、但是,实测mysqld–skip-grant-tables这样的命令行,在mysql8中无法成功启动,而且测试了该参数放在ini文件里面也同样无法启动

7、两条思路,或者用--init-file参数在服务启动时加载并运行修改密码的命令文件,该命令一旦执行,服务启动后密码即已经清除或者重置,启动服务后即可以空密码或指定密码登入。

8、或者继续研究–skip-grant-tables命令行参数下服务不能启动的原因,解决问题,然后启动服务后以空密码登入,手工输入命令,执行清除或者重置mysql.user表中的密码记录字段。

9、方法一:利用--init-file参数解决

10、该参数指定服务启动时先执行一个包含sql命令文件,因此,只需要将重置密码的命令写在该文件中,以此参数指定启动时执行该命令,启动完成即可重置系统密码了。

11、net stop mysql第二步,创建一个文本文件,内含一条密码修改命令

12、ALTER USER'root'@'localhost' IDENTIFIED BY'';第三步:命令行方式启动服务器,指定启动时执行上述的密码修改命令文件

13、mysqld--init-file=d:mysqlc.txt--console具体操作截图

14、方法二,想办法让--skip-grant-tables参数用起来

15、实测,在mysql8系统下,用mysqld--console--skip-grant-tables--shared-memory可以无密码启动服务

16、mysql.exe-u root然后执行sql命令将root用户密码设置为空

17、UPDATE mysql.user SET authentication_string='' WHERE user='root' and host='localhost';具体操作截图

18、MySQL8的一些特性导致老方法重置不大管用了,建议使用--init-file参数解决,实测安全可靠。

三、mysql初始化数据库报错

题主是否想询问“mysql初始化数据库报错是什么原因”?MySQL初始化数据库报错原因如下:

1、权限问题:确保MySQL的数据目录和文件有正确的权限。MySQL用户通常需要对其数据目录有读/写/执行权限。

2、配置文件问题:检查my.cnf或my.ini文件(位置可能因安装而异)中的配置是否正确。例如,datadir或tmpdir等路径是否正确。

3、磁盘空间:确保你的服务器上有足够的磁盘空间。

4、端口冲突:MySQL默认使用3306端口。如果该端口已被其他服务使用,MySQL将无法启动。

5、数据文件损坏:如果之前的数据文件(如ibdata1、ib_logfile0、ib_logfile1等)已损坏,你可能需要恢复或重新初始化数据库。

6、版本不兼容:确保你正在使用的MySQL客户端和服务器版本是兼容的。

7、日志文件:查看MySQL的错误日志文件,通常位于数据目录下或/var/log/mysql/。这个日志文件通常会包含有关错误的详细信息。

8、SELinux或AppArmor:如果你的服务器运行了SELinux或AppArmor等安全模块,确保它们没有阻止MySQL运行。