ubuntu mysql 多实例_ubuntu安装mysql多实例

想要尝试mysql的读写分离,在云上安装完mysql之后突然想到一个问题:我本机是没有公网IP的。

开始尝试在唯一一台云服务器上安装多个mysql实例。

主要步骤:

1.新建MySQL目录

(1):新建实例目录: /data/mysql/mysql_3307

(2):赋权:chown -R mysql.mysql  /data/mysql/mysql_3307

(3):在apparmor中配置对目录文件的访问权限

vim /etc/apparmor.d/usr.sbin.mysqld

/data/mysql/mysql_3307/ r,

/data/mysql/mysql_3307/** rwk,

3543847

apparmor配置

刷新: service apparmor restart

2.复制多个MySQL配置文件

mysql启动时会读取配置文件my.cnf,要配置多个实例需要复制多个my.cnf配置文件。在mysql5.7版本中

/etc/mysql/目录下的my.cnf文件是个软链接,关联的是/etc/mysql/mysql.conf.d目录下的mysqld.cnf文件,配置信息全部在mysqld.cnf中,所以可以直接复制mysqld.cnf命名为mysqld_3307.cnf作为启动配置文件。

修改mysqld_3307.cnf配置

3543847

配置文件修改

3543847

配置文件修改

端口port: port=3307

socket      socket=/data/mysql/mysql_3307/mysqld.sock

pid-file    pid-file=/data/mysql/mysql_3307/mysqld.pid

datadir      datadir=/data/mysql/mysql_3307

log_error    log_error=/data/mysql/mysql_3307/error.log

注释掉nice =0  #nice = 0

注释掉bind-address方便从本地访问        #bind-address          = 127.0.0.1

保存。

3.初始化MySQL文件

mysql_install_db --defaults-file=/etc/mysql/mysql.conf.d/mysqld_3307.cnf --basedir=/usr/ --datadir=/data/mysql/mysql_3307 --user=mysql

执行完成后mysql文件会被初始化到datadir目录下

3543847

实例文件

(

5.7版本初始化的时候相比5.6 会有一些不同,之前在初始化第三个实例的时候报错:

2111:29:05[WARNING]mysql_install_db is deprecated. Please consider switching to mysqld --initialize

可以看到mysql_install_db is deprecated,mysql_install_db被弃用。推荐使用的方法:

mysqld --initialize

正确的初始方式如下:mysqld --initialize --user=mysql --basedir=/usr  --datadir=/data/mysql/mysql_3307

)

启动实例: mysqld_safe --defaults-file=/etc/mysql/mysql.conf.d/mysqld_3307.cnf --skip-grant-tables &

先通过安全模式启动实例,跳过安全认证登录后修改root密码

无密码登录:mysql -S /data/mysql/mysql_3307/mysqld.sock -P 3307

修改密码:

mysql> update user set authentication_string=password('******') where user='root'

mysql> flush privileges;

mysql> quit

重新启动,然后通过root密码登录。

关闭实例:

mysqladmin -u root -p -S /data/mysql/mysql_3307/mysqld.sock shutdown

启动实例:

mysqld_safe --defaults-file=/etc/mysql/mysql.conf.d/mysqld_3307.cnf  &

登录实例:

mysql -S /data/mysql/mysql_3307/mysqld.sock -P 3307 -u root -p

登录后执行命令的时候提示错误:ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this start

解决办法,设置密码:set password="YOUR_PASSWORD"。

至此单个实例安装完成,需要安装不同实例只需要复制多个mysqld.cnf配置文件,建多个目录按以上步骤操作。

4.设置MySQL实例可以从本地navicate访问

3543847

本地navicate连接

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Linux系统下,可以通过多个实例来运行多个MySQL服务器,每个实例可以拥有独立的配置文件、数据目录和日志文件等。这样可以方便地管理多个不同的MySQL实例,提高系统的可靠性和稳定性。下面简单介绍一下在Linux下MySQL实例安装的过程。 1. 安装MySQL 首先需要安装MySQL,可以通过命令行或者图形界面进行安装。以Ubuntu系统为例,可以使用以下命令进行安装: ``` sudo apt-get update sudo apt-get install mysql-server ``` 2. 创建新的MySQL实例目录 在Linux系统下,每个MySQL实例需要有独立的数据目录和日志文件等。可以使用以下命令创建一个新的MySQL实例目录: ``` sudo mkdir /var/lib/mysql2 ``` 3. 复制MySQL配置文件 每个MySQL实例需要有独立的配置文件,可以通过复制默认配置文件来创建新的配置文件。以Ubuntu系统为例,可以使用以下命令复制默认配置文件: ``` sudo cp /etc/mysql/my.cnf /etc/mysql/my2.cnf ``` 4. 修改新的配置文件 修改新的配置文件,使其指向新的数据目录和日志文件等。以Ubuntu系统为例,可以使用以下命令编辑新的配置文件: ``` sudo vi /etc/mysql/my2.cnf ``` 在文件中修改以下内容: ``` [client] port = 3307 socket = /var/run/mysqld/mysqld2.sock [mysqld_safe] pid-file = /var/run/mysqld/mysqld2.pid socket = /var/run/mysqld/mysqld2.sock [mysqld] user = mysql pid-file = /var/run/mysqld/mysqld2.pid socket = /var/run/mysqld/mysqld2.sock port = 3307 basedir = /usr datadir = /var/lib/mysql2 tmpdir = /tmp log_error = /var/log/mysql/error2.log ``` 其中,需要修改的内容主要是端口号、数据目录、日志文件等。 5. 初始化新的MySQL实例 使用以下命令初始化新的MySQL实例: ``` sudo mysqld --defaults-file=/etc/mysql/my2.cnf --initialize-insecure --user=mysql ``` 其中,--defaults-file参数指定使用新的配置文件,--initialize-insecure参数表示不设置root密码,--user参数表示启动MySQL进程的用户。 6. 启动新的MySQL实例 使用以下命令启动新的MySQL实例: ``` sudo systemctl start mysql@2.service ``` 其中,2表示新的MySQL实例的编号。 至此,多实例MySQL服务器已经成功安装。可以通过以下命令查看多个MySQL实例的状态: ``` sudo systemctl status mysql@*.service ``` 其中,*表示所有的MySQL实例

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值