当前位置: 首页 > news >正文

MySQL多实例安装部署

  • 解压 MySQL 5.7 二进制包到指定目录
    [root@MySQL ~]# tar zxvf mysql-5.7.18-linux-glibc2.5-x86_64.tar.gz -C /usr/local/

  • 创建 MySQL 软链接
    [root@MySQL ~]#mv /usr/local/mysql-5.7.18-linux-glibc2.5-x86_64 /usr/local/mysql

  • 创建 MySQL 用户
    [root@MySQL ~]#groupadd -r mysql
    [root@MySQL ~]# useradd -r -g mysql -s /bin/false -M mysql

  • 在 MySQL 二进制包目录中创建 mysql-files 目录 [MySQL 数据导入/导出数据专放目录]
    [root@MySQL ~]# mkdir -v /usr/local/mysql/mysql-files
    mkdir: created directory `/usr/local/mysql/mysql-files'

  • 创建多实例数据目录
    [root@MySQL ~]# mkdir -vp /data/mysql_data{1..4}
    mkdir: created directory /data' <br/>mkdir: created directory/data/mysql_data1'
    mkdir: created directory /data/mysql_data2' <br/>mkdir: created directory/data/mysql_data3'
    mkdir: created directory `/data/mysql_data4'

  • 修改 MySQL 二进制包目录的所属用户与所属组
    1 [root@MySQL ~]# chown root.mysql -R /usr/local/mysql

  • 修改 MySQL 多实例数据目录与 数据导入/导出专放目录的所属用户与所属组
    [root@MySQL ~]# chown mysql.mysql -R /usr/local/mysql/mysql-files /data/mysql_data{1..4}

  • 配置 MySQL 配置文件 /etc/my.cnf
    [mysqld_multi]
    mysqld = /usr/local/mysql/bin/mysqld
    mysqladmin = /usr/local/mysql/bin/mysqladmin
    log = /tmp/mysql_multi.log

[mysqld1]
# 设置数据目录 [多实例中一定要不同]
datadir = /data/mysql_data1
# 设置sock存放文件名 [多实例中一定要不同]
socket = /tmp/mysql.sock1
# 设置监听开放端口 [多实例中一定要不同]
port = 3306
# 设置运行用户
user = mysql
# 关闭监控
performance_schema = off
# 设置innodb 缓存大小
innodb_buffer_pool_size = 32M
# 设置监听IP地址
bind_address = 0.0.0.0
# 关闭DNS 反向解析
skip-name-resolve = 0 **

[mysqld2]
datadir = /data/mysql_data2
socket = /tmp/mysql.sock2
port = 3307
user = mysql
performance_schema = off
innodb_buffer_pool_size = 32M
bind_address = 0.0.0.0
skip-name-resolve = 0

[mysqld3]
datadir = /data/mysql_data3
socket = /tmp/mysql.sock3
port = 3308
user = mysql
performance_schema = off
innodb_buffer_pool_size = 32M
bind_address = 0.0.0.0
skip-name-resolve = 0

[mysqld4]
datadir = /data/mysql_data4
socket = /tmp/mysql.sock4
port = 3309
user = mysql
performance_schema = off
innodb_buffer_pool_size = 32M
bind_address = 0.0.0.0
skip-name-resolve = 0

  • 初始化各个实例 [ 初始化完成后会自带随机密码在输出日志中 ]
    [root@MySQL ~]# /usr/local/mysql/bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql_data1
    [root@MySQL ~]# /usr/local/mysql/bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql_data2
    [root@MySQL ~]# /usr/local/mysql/bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql_data3
    [root@MySQL ~]# /usr/local/mysql/bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql_data4

  • 各实例开启 SSL 连接
    [root@MySQL ~]# /usr/local/mysql/bin/mysql_ssl_rsa_setup --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql_data1
    [root@MySQL ~]# /usr/local/mysql/bin/mysql_ssl_rsa_setup --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql_data2
    [root@MySQL ~]# /usr/local/mysql/bin/mysql_ssl_rsa_setup --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql_data3
    [root@MySQL ~]# /usr/local/mysql/bin/mysql_ssl_rsa_setup --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql_data4

*修改环境变量
echo "export PATH=$PATH:/usr/local/mysql/bin" >> /etc/profile
source /etc/profile

  • 复制多实例脚本到服务管理目录下 [ /etc/init.d/ ]
    [root@MySQL ~]# cp /usr/local/mysql/support-files/mysqld_multi.server /etc/init.d/mysqld_multi

  • 添加脚本执行权限
    [root@MySQL ~]# chmod +x /etc/init.d/mysqld_multi

  • 添加进service服务管理
    [root@MySQL ~]# chkconfig --add mysqld_multi
  1. 启动测试
    • 查个多实例状态
      [root@MySQL ~]# /etc/init.d/mysqld_multi report
      Reporting MySQL servers
      MySQL server from group: mysqld1 is not running
      MySQL server from group: mysqld2 is not running
      MySQL server from group: mysqld3 is not running
      MySQL server from group: mysqld4 is not running
  • 启动多实例
    [root@MySQL ~]# /etc/init.d/mysqld_multi start

  • 查看多实例状态
    Reporting MySQL servers
    MySQL server from group: mysqld1 is running
    MySQL server from group: mysqld2 is running
    MySQL server from group: mysqld3 is running
    MySQL server from group: mysqld4 is running

  • 查看实例监听端口
    [root@MySQL ~]# netstat -lntp | grep mysqld
    tcp 0 0 0.0.0.0:3306 0.0.0.0: LISTEN 2673/mysqld
    tcp 0 0 0.0.0.0:3307 0.0.0.0:
    LISTEN 2676/mysqld
    tcp 0 0 0.0.0.0:3308 0.0.0.0: LISTEN 2679/mysqld
    tcp 0 0 0.0.0.0:3309 0.0.0.0:
    LISTEN 2682/mysqld
  1. 连接测试

转载于:https://blog.51cto.com/yangkui/2136034

相关文章:

  • 网络命令初步排错
  • python_正则表达式匹配ip
  • 路径中文问题
  • leetcode-849-到最近的人的最大距离
  • java中与运算,或运算,异或运算,取反运算
  • Windows后登陆没有图形界面只有cmd,explorer.exe不能启动
  • fastdfs添加新group注意事项
  • 关于自动驾驶等级划分
  • 数据仓库学习笔记
  • windows设置防火墙允许telnet
  • Hexo添加评论、阅读次数和分类/标签
  • 颜色的生成
  • 360首曝人工智能研发三大神秘成果
  • ThinkSNS+ 移动端1.8.2.0704 版本更新简要说明
  • js蛋疼的Class(获取class对象)
  • [微信小程序] 使用ES6特性Class后出现编译异常
  • [译] 理解数组在 PHP 内部的实现(给PHP开发者的PHP源码-第四部分)
  • 【vuex入门系列02】mutation接收单个参数和多个参数
  • 【翻译】babel对TC39装饰器草案的实现
  • CentOS学习笔记 - 12. Nginx搭建Centos7.5远程repo
  • iOS 系统授权开发
  • java正则表式的使用
  • jdbc就是这么简单
  • laravel5.5 视图共享数据
  • Lucene解析 - 基本概念
  • Magento 1.x 中文订单打印乱码
  • ReactNative开发常用的三方模块
  • SpiderData 2019年2月25日 DApp数据排行榜
  • 阿里云容器服务区块链解决方案全新升级 支持Hyperledger Fabric v1.1
  • 半理解系列--Promise的进化史
  • 初识MongoDB分片
  • 给github项目添加CI badge
  • 如何解决微信端直接跳WAP端
  • 我有几个粽子,和一个故事
  • 最简单的无缝轮播
  • 如何正确理解,内页权重高于首页?
  • 我们雇佣了一只大猴子...
  • ​决定德拉瓦州地区版图的关键历史事件
  • # 安徽锐锋科技IDMS系统简介
  • (附源码)计算机毕业设计ssm本地美食推荐平台
  • (九)信息融合方式简介
  • (收藏)Git和Repo扫盲——如何取得Android源代码
  • .bat批处理(八):各种形式的变量%0、%i、%%i、var、%var%、!var!的含义和区别
  • .NET Standard 支持的 .NET Framework 和 .NET Core
  • .netcore 6.0/7.0项目迁移至.netcore 8.0 注意事项
  • .NET处理HTTP请求
  • .net快速开发框架源码分享
  • .NET设计模式(7):创建型模式专题总结(Creational Pattern)
  • @在php中起什么作用?
  • [ C++ ] STL---string类的使用指南
  • [145] 二叉树的后序遍历 js
  • [AIGC] Java 和 Kotlin 的区别
  • [android] 手机卫士黑名单功能(ListView优化)
  • [Android开源]EasySharedPreferences:优雅的进行SharedPreferences数据存储操作
  • [Angular] 笔记 8:list/detail 页面以及@Input