生产环境MySQL 5.5.x单机多实例配置实践
背景需求:
1)在一台新采购的服务器上通过源码编译安装一个版本为5.5.x以上的MySQL数据库,并将所有配置文件与数据等均存放在/opt/mysql,以便于今后实现快速迁移、复制和整体备份;
2)在同一个MySQL中运行两个实例,一个绑定在端口3306,一个绑定在端口3307;绑定在3306端口的实例,不开启binlog,数据存放在/opt/mysql/data;绑定在3307端口的实例,开启binlog,数据存放在/opt/mysql/data2;
3)两个实例均采用InnoDB作为默认的存储引擎,字符编码采用UTF-8;两个实例均采用相同的性能优化配置参数,实现单机多实例的配置应用。
实施方案:
在编译安装时,将数据库的配置文件my.cnf以及data目录等均指向到/opt/mysql目录;通过mysqld_multi的方式来管理两个不同的实例,采用相同的配置文件共享性能优化配置参数;在同一个配置文件中,利用[mysqld1]与[mysqld2]标签实现不同实例的差异化配置。
配置过程:
1、源码编译安装MySQL
1)安装所需系统软件包
# yum -y install gcc gcc-c++ autoconf bison libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel zlib zlib-devel glibc glibc-devel glib2 glib2-devel bzip2 bzip2-devel ncurses ncurses-devel curl curl-devel e2fsprogs e2fsprogs-devel krb5 krb5-devel libidn libidn-devel openssl openssl-devel openldap openldap-devel nss_ldap openldap-clients openldap-servers
2)安装前的系统设置
# mkdir /opt/mysql //mysql安装目录
# mkdir /opt/mysql/data //mysql数据存放目录
# groupadd mysql //创建用户
# useradd -g mysql mysql //创建用户组
# chown mysql:mysql -R /opt/mysql/data //赋予数据存放目录权限
3)安装cmake
MySQL从5.5版本开始,通过./configure进行编译配置方式已经被取消,取而代之的是cmake工具。因此,需要先在系统中源码编译安装cmake。
# mkdir /home/tools
# cd /home/tools
# wget http://www.cmake.org/files/v2.8/cmake-2.8.4.tar.gz
# tar xf cmake-2.8.4.tar.gz
# cd cmake-2.8.4
# ./configure
# make;make install
4)开始编译安装MySQL
# wget http://downloads.mysql.com/archives/mysql-5.5/mysql-5.5.19.tar.gz
# tar xf mysql-5.5.19.tar.gz
# cd mysql-5.5.19
# cmake -DCMAKE_INSTALL_PREFIX=/opt/mysql \
-DSYSCONFDIR=/opt/mysql/etc \
-DMYSQL_DATADIR=/opt/mysql/data \
-DMYSQL_TCP_PORT=3306 \
-DMYSQL_UNIX_ADDR=/tmp/mysqld.sock \
-DMYSQL_USER=mysql \
-DEXTRA_CHARSETS=all \
-DWITH_READLINE=1 \
-DWITH_SSL=system \
-DWITH_EMBEDDED_SERVER=1 \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1
# make;make install
2、创建单机支持多实例
1)进入MySQL主目录
# cd /opt/mysql/
2)删除默认的data目录
# rm -rf data
3)创建需要的目录
# mkdir etc tmp run log binlogs data data2
# chown -R mysql:mysql tmp run log binlogs data data2
4)创建my.cnf配置文件
# vi etc/my.cnf
## This server may run 2+ separate instances ## This is the general purpose database ## These support master - master replication ## This is exlusively for mysqld2 ## Disable DNS lookups ## These support master - slave replication ## Relay log settings ## Slow query log settings ## The rest of the my.cnf is shared skip-external-locking ## Increase the max connections ## The expiration time for logs, including binlogs ## Set the character as utf8 ## This is usually only needed when setting up chained replication ## Enable this to make replication more resilient against server crashes and restarts ## The server id, should be unique in same network ## Set this to force MySQL to use a particular engine/table-type for new tables ## Uncomment the following if you are using InnoDB tables [mysqldump] [mysql] [myisamchk] [mysqlhotcopy] [mysql.server] [mysqld_safe] [client] |
5)修改my.cnf读写权限,避免普通用户获取到MySQL密码
# chown -R root:root /opt/mysql/etc
# chmod 600 /opt/mysql/etc/my.cnf
3、初始化数据库
1)切换到mysql用户,进入MySQL主目录
# su - mysql
# cd /opt/mysql/
2)初始化实例[mysqld1]和[mysqld2]
# scripts/mysql_install_db --basedir=/opt/mysql --user=mysql --datadir=/opt/mysql/data/
# scripts/mysql_install_db --basedir=/opt/mysql --user=mysql --datadir=/opt/mysql/data2/
3)回到root,创建mysqld_multi.server脚本
# exit
# mkdir -p /opt/mysql/init.d
# cp support-files/mysqld_multi.server /opt/mysql/init.d/
# vi /opt/mysql/init.d/mysqld_multi.server
#!/bin/sh basedir=/opt/mysql conf=/opt/mysql/etc/my.cnf if test -x $bindir/mysqld_multi case "$1" in |
4、整体备份MySQL
# cd /opt/
# tar czvf mysql_5.5.19_full.tar.gz mysql5519/
备份完成后,直接将mysql_5.5.19_full.tar.gz拿到其他服务器上,解压后便可以直接启用。
5、管理MySQL实例
1)同时启动实例 [mysqld1] 与 [mysqld2]:
# /opt/mysql/init.d/mysqld_multi.server start 1,2
2)查看两个MySQL实例是否都已经成功启动
# netstat -lntp | grep mysqld
tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN 28752/mysqld tcp 0 0 0.0.0.0:3307 0.0.0.0:* LISTEN 28756/mysqld |
同时关闭实例 [mysqld1] 与 [mysqld2]:
# /opt/mysql/init.d/mysqld_multi.server stop 1,2
仅启动/关闭实例[mysqld1]:
# /opt/mysql/init.d/mysqld_multi.server start 1
# /opt/mysql/init.d/mysqld_multi.server stop 1
6、登陆MySQL实例
在启动了实例[mysqld1]与[mysqld2]后,通过以下方式登陆不同的实例:
登陆[mysqld1]:
# /opt/mysql/bin/mysql -uroot -h127.0.0.1 -P3306 -p
登陆[mysqld2]:
# /opt/mysql/bin/mysql -uroot -h127.0.0.1 -P3307 -p
7、其他初始化设置
1)为MySQL的root帐户设置初始密码
# /opt/mysql/bin/mysqladmin -u root -h127.0.0.1 -P3306 password '123456'
# /opt/mysql/bin/mysqladmin -u root -h127.0.0.1 -P3307 password '123456'
2)修改my.cnf配置文件中MySQL的root账户密码
# vim /opt/mysql/etc/my.cnf
user = root ## Used for stopping the server via mysqladmin password = 123456 |
3)删除匿名连接的空密码帐号
分别登陆实例[mysqld1]与[mysqld2],执行以下命令:
mysql> use mysql; //选择系统数据库mysql
Database changed
mysql> select Host,User,Password from user; //查看所有用户
+-----------+------+-------------------------------------------+
| Host | User | Password |
+-----------+------+-------------------------------------------+
| localhost | root | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
| mysql-01 | root | |
| 127.0.0.1 | root | |
| ::1 | root | |
| localhost | | |
| mysql-01 | | |
+-----------+------+-------------------------------------------+
6 rows in set (0.00 sec)
mysql> delete from user where password=""; //删除匿名连接的空密码帐号
Query OK, 5 rows affected (0.00 sec)
mysql> flush privileges; //刷新权限
Query OK, 0 rows affected (0.00 sec)
mysql> select Host,User,Password from user; //确认密码为空的用户是否已全部删除
+-----------+------+-------------------------------------------+
| Host | User | Password |
+-----------+------+-------------------------------------------+
| localhost | root | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
+-----------+------+-------------------------------------------+
1 row in set (0.00 sec)
mysql> exit;
经验总结:
1、采用源码编译安装MySQL,可以方便我们自己组织所有MySQL相关文件的位置;同时经过源码编译安装后的MySQL,可以直接复制到其它服务器上运行,大大方便了我们今后的迁移、备份和新服务器的配置;
2、本次方案仅仅实施了两个实例[mysqld1]与[mysqld2],实际上我们可以通过这样的方式,拓展实现[mysqld3],[mysqld4],[mysqld5]...等更多的实例;
3、MySQL自带了几个不同的配置文件,放置在/opt/mysql/support-files目录下,分别是my-huge.cnf,my-innodb-heavy-4G.cnf,my-large.cnf,my-medium.cnf,my-small.cnf,通过名称我们可以很直观的了解到他们是针对不同的服务器配置的;
4、在单机运行多实例的情况下,不要使用mysql -hlocalhost或直接忽略-h参数登陆服务器,因为如果使用localhost或忽略-h参数,而不是指定127.0.0.1的话,即使选择的端口是3307,还是会登陆到3306实例中去,所以尽量避免这种混乱的产生,统一用127.0.0.1绑定端口或采用socket来登陆。
BTW:如果大家认为我写的还可以,希望能给我的博客投个票,谢谢!O(∩_∩)O
https://blog.51cto.com/contest2012/7582
转载于:https://blog.51cto.com/aixuexi/1051394
生产环境MySQL 5.5.x单机多实例配置实践相关推荐
- MySQL 5.5.35 单机多实例配置详解
一.前言 二.概述 三.环境准备 四.安装MySQL 5.5.35 五.新建支持多实例的配置文件(我这里配置的是四个实例) 六.初始化多实例数据库 七.提供管理脚本 mysqld_multi.serv ...
- mysql 5.5.35 单机多实例配置详解_MySQL 5.5.35 单机多实例配置详解
一.前言 二.概述 三.环境准备 四.安装MySQL 5.5.35 五.新建支持多实例的配置文件(我这里配置的是四个实例) 六.初始化多实例数据库 七.提供管理脚本 mysqld_multi.serv ...
- mysql 5.5.35 单机多实例配置详解_基于mysql-5.5.32的单机多实例多配置文件的
1.安装环境: [root@localhost ~]# [root@localhost ~]# uname -a Linux localhost.localdomain 2.6.32-504.16.2 ...
- 生产环境mysql安装规划及调优实践--mysql8.0.29为例
以前运维人员部署在生产环境的mysql又被扫描出安全漏洞,需要进行修补.这种事情本来应该是很简单的事儿,但如今执着于软件领域技术的人是越来越少,竟然没有人愿意去做去学,都想等着别人去处理,最终还是得老 ...
- CentOS7下生产环境MySQL 5.7.26小版本升级5.7.39
目录 升级前版本 背景 升级 下载软件包 备份并停止数据库 升级安装 升级后检查 本文仅适合使用当前数据库为 RPM 安装方式 升级前版本 使用 mysql -V 命令查看当前版本 [dev@gxmy ...
- 如何在生产环境mysql删除亿万级数据解并且不影响数据库主从延迟的解决方案
目录 前言 为什么在生产上主从环境情况下mySQL特别容易卡死 不要去怪设计不要去怪开发我们devops靠自己 场景一.当要被删除的数据量远大于保留的数据量的场景下的做法 操作涉及数据量及环境 烂机器 ...
- 生产环境mysql安装规划及调优实践(二)--mysql8.0.29为例
上一篇讲了如何安装mysql,这一篇讲一下主从复制的设置,以及生产常用的参数设置. 因为mysql的生产使用场景不同,所以不同的使用场景下,参数配置也要针对不同的业务来进行设置.比如是倾向于快速更新, ...
- RabbitMQ单机多实例配置
欢迎支持笔者新作:<深入理解Kafka:核心设计与实践原理>和<RabbitMQ实战指南>,同时欢迎关注笔者的微信公众号:朱小厮的博客. 欢迎跳转到本文的原文链接:https: ...
- 生产环境mysql主主同步主键冲突处理
收到短信报警,两台数据库都报slave同步失败了,先说明一下环境,架构:lvs+keepalived+amoeba+mysql,主主复制,单台写入, 主1:192.168.0.223(写) 主2:19 ...
最新文章
- 077_访问者的信息
- 华为手机asph啥机型_华为正式宣布!19款机型开启新系统内测,你的手机榜首有名吗?...
- C语言在二叉搜索树找到第k个最小元素(附完整源码)
- Debug Assertion Failed _CrtlsValidHeapPointer(block) realloc堆引发的错误
- 函数计算搭建 Serverless Web 应用(三)- 三分钟搭建 Web 应用
- Java常用设计模式————享元模式
- vs2008智能提示jQuery的设置注意事项
- Kotlin学习笔记 第二章 类与对象 第七节 数据类
- jQuery中的css部分
- BootStrap Table和Mybatis Plus实现服务端分页
- xgboost算法_xgboost算法学习心得
- Linux 的camera sensor 驱动代码分析:基于rv1108
- Java 函数式编程的妙用
- Python百钱百鸡问题
- 国外量化投资经典案例介绍
- python壁纸4k_Python爬虫练习:爬取高清4K桌面壁纸
- Thinkpad和ThinkBook有什么区别 哪个好详细性能配置对比
- urlencode、unquote
- 信管通低代码快速开发工具简介(一)
- 智能货架是零售业的必经之路,普通人入局新零售有机会
热门文章
- [设计模式-创建型]单态(Singleton)
- 自己动手写Docker系列 -- 5.2实现查看运行中的容器
- 设置xy轴名称_最强干货来了:Grasshopper运算器名称总结(上篇)
- 精品网站 mysql,【网址导航系统】基于PHP+MYSQL开发的开源网站分类目录管理系统...
- java可以看懂php代码吗_PHP笔记——java程序员看懂PHP程序
- 解决使用jQuery采用append添加的元素事件无效的方法
- Spring Cloud 中的@FeignClient注解
- 数据预处理包括哪些内容python_常见的数据预处理--python篇
- 慢日志定位到备份锁表Waiting for global read lock原因
- 计算机大赛开场白,比赛主持开场白