千家信息网

通过 MySQL 8.0 二进制安装包部署多实例

发表于:2024-11-25 作者:千家信息网编辑
千家信息网最后更新 2024年11月25日,解压安装包cd /usr/localtar xvf mysql-8.0.12-linux-glibc2.12-x86_64.tar.xzmv mysql-8.0.12-linux-glibc2.12-
千家信息网最后更新 2024年11月25日通过 MySQL 8.0 二进制安装包部署多实例

解压安装包

cd /usr/localtar xvf mysql-8.0.12-linux-glibc2.12-x86_64.tar.xzmv mysql-8.0.12-linux-glibc2.12-x86_64 mysqlcd mysql/mkdir confexport PATH=$PATH:/usr/local/mysql/bin

实例1配置文件 my00.cnf

[mysqld]basedir=/usr/local/mysqldatadir=/var/lib/mysql00socket=/tmp/mysql00.socksymbolic-links=0port=3306mysqlx_port=33060[mysqld_safe]log-error=/var/log/mysqld00.logpid-file=/var/lib/mysql00/mysqld.pid

实例2配置文件 my01.cnf

[mysqld]basedir=/usr/local/mysqldatadir=/var/lib/mysql01socket=/tmp/mysql01.socksymbolic-links=0port=3307mysqlx_port=33070[mysqld_safe]log-error=/var/log/mysqld01.logpid-file=/var/lib/mysql01/mysqld.pid

实例3配置文件 my02.cnf

[mysqld]basedir=/usr/local/mysqldatadir=/var/lib/mysql02socket=/tmp/mysql02.socksymbolic-links=0port=3308mysqlx_port=33080[mysqld_safe]log-error=/var/log/mysqld02.logpid-file=/var/lib/mysql02/mysqld.pid

初始化实例

mysqld --defaults-file=/usr/local/mysql/conf/my00.cnf --initialize --user=mysqlmysqld --defaults-file=/usr/local/mysql/conf/my01.cnf --initialize --user=mysqlmysqld --defaults-file=/usr/local/mysql/conf/my02.cnf --initialize --user=mysql

启动实例

mysqld_safe --defaults-file=/usr/local/mysql/conf/my00.cnf --user=mysql &mysqld_safe --defaults-file=/usr/local/mysql/conf/my01.cnf --user=mysql &mysqld_safe --defaults-file=/usr/local/mysql/conf/my02.cnf --user=mysql &

修改密码

mysql -S /tmp/mysql00.sock -u root -pALTER USER root@'localhost' IDENTIFIED BY 'MySQL8.0';mysql -S /tmp/mysql01.sock -u root -pALTER USER root@'localhost' IDENTIFIED BY 'MySQL8.0';mysql -S /tmp/mysql02.sock -u root -pALTER USER root@'localhost' IDENTIFIED BY 'MySQL8.0';

关闭实例

mysqladmin -S /tmp/mysql00.sock -u root -pMySQL8.0 shutdownmysqladmin -S /tmp/mysql01.sock -u root -pMySQL8.0 shutdownmysqladmin -S /tmp/mysql02.sock -u root -pMySQL8.0 shutdown

注意:账号 root@'locahost' 使用 socket 连接数据库

参考文档:在Unix上运行多个MySQL实例

0