MySQL单机多实例的配置笔记

本文涉及的产品
RDS AI 助手,专业版
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介:

网上的大部分都是mysqld_multi方式启动的多实例。

以前在老男孩老师的视频里看到的另一种方法,如下。


参考:http://www.ilanni.com/?p=8020

 

环境

    CentOS6.7x86_642.6.32-573.el6.x86_64

    mysql-5.6.30通用二进制安装包

 

创建mysql的独立配置文件目录

mkdir /data/{3306,3307} -pv

 

建立账户

groupadd mysql

useradd -s /sbin/nologin -g mysql -Mmysql

 

创建mysql的数据目录

mkdir -p /data/{3306,3307}/data

 

安装Mysql及准备配置文件

tar xf mysql-5.6.30-linux-glibc2.5-x86_64.tar.gz-C /usr/local

cd /usr/local

ln -s mysql-5.6.30-linux-glibc2.5-x86_64mysql

chown mysql.mysql mysql/ -R

cp /usr/local/mysql/support-files/my-default.cnf /data/3306/my.cnf 


 

修改/data/3306/my.cnf

[client]

user = root

socket =/data/3306/mysql.sock

port = 3306

 

[mysql]

no-auto-rehash

default_character_set = utf8

prompt = [\d] >

 

[mysqld]

# Basic

port = 3306

socket =/data/3306/mysql.sock

basedir =/usr/local/mysql

datadir =/data/3306/data

 

user = mysql

skip-external-locking

skip_name_resolve = ON

 

character-set-server = utf8

key_buffer_size = 16M

table_open_cache = 64

sort_buffer_size = 512K

net_buffer_length = 8K

read_buffer_size = 256K

read_rnd_buffer_size = 512K

myisam_sort_buffer_size = 8M

 

max_allowed_packet = 50M

max_connections = 1000

thread_cache_size = 80

 

connect_timeout = 200

wait_timeout = 100

interactive_timeout = 100

 

server_id = 1

 

# query cache

query_cache_type=OFF

query_cache_size=0

 

# logs

slow_query_log=ON

slow_query_log_file =/data/3306/data/localhost-slow.log

long_query_time = 5

log_error = /data/3306/data/mysql.err

log_warnings = 2

 

# binlogs

log-bin=mysql-bin

binlog_format=mixed

expire_logs_days = 10

binlog_cache_size=2M

 

# InnoDB Optimize

innodb_file_per_table = ON

 

innodb_write_io_threads = 8

innodb_read_io_threads = 8

 

innodb_buffer_pool_dump_at_shutdown= ON

innodb_buffer_pool_load_at_startup= ON

innodb_buffer_pool_instances = 8

innodb_buffer_pool_size = 2G

innodb_additional_mem_pool_size =128M

 

innodb_data_home_dir = /data/3306/data

innodb_data_file_path =ibdata1:10M:autoextend

 

innodb_log_group_home_dir= /data/3306/data

innodb_log_file_size = 512M

innodb_log_buffer_size = 1G

innodb_flush_log_at_trx_commit = 1

innodb_lock_wait_timeout = 50

 

[mysqld_safe]

log-error=/data/3306/3306.err

pid-file=/data/3306/3306.pid

 

[mysqldump]

quick

max_allowed_packet = 16M

 

[mysql]

no-auto-rehash

 

修改/data/3307/my.cnf

cp /data/3306/my.cnf  /data/3307/my.cnf

sed -i 's#3306#3307#g'  /data/3307/my.cnf

 

初始化mysql多实例

/usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/data/3306/data --user=mysql

/usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/data/3307/data --user=mysql

 

chown mysql.mysql/data/{3306,3307} -R

 

启动mysql多实例

/usr/local/mysql/bin/mysqld_safe--defaults-file=/data/3306/my.cnf &

/usr/local/mysql/bin/mysqld_safe --defaults-file=/data/3307/my.cnf&

 

ps aux |grep mysqld

ss -lnt|egrep "3306|3307"

 

配置启动脚本

vim /etc/init.d/mysqld_3306

#!/bin/sh

# chkconfig: 345 80 15

# description: A very fast andreliable SQL database engine.

 

#init

port=3306

mysql_user="root"

mysql_pwd=""

CmdPath="/usr/local/mysql/bin"

 

#startup function

function_start_mysql()

{

   printf "Starting MySQL...\n"

   /bin/sh ${CmdPath}/mysqld_safe --defaults-file=/data/${port}/my.cnf2>&1 > /dev/null &

}

 

#stop function

function_stop_mysql()

{

   printf "Stoping MySQL...\n"

   ${CmdPath}/mysqladmin -u ${mysql_user} -p${mysql_pwd} -S/data/${port}/mysql.sock shutdown

}

 

#restart function

function_restart_mysql()

{

   printf "Restarting MySQL...\n"

   function_stop_mysql

   sleep 2

   function_start_mysql

}

 

case $1 in

start)

   function_start_mysql

;;

stop)

   function_stop_mysql

;;

restart)

   function_restart_mysql

;;

*)

   printf "Usage: /data/${port}/mysql {start|stop|restart}\n"

esac

 

 

vim /etc/init.d/mysqld_3307

#!/bin/sh

# chkconfig: 345 81 16

# description: A very fast andreliable SQL database engine.

 

#init

port=3307

mysql_user="root"

mysql_pwd=""

CmdPath="/usr/local/mysql/bin"

 

#startup function

function_start_mysql()

{

   printf "Starting MySQL...\n"

   /bin/sh ${CmdPath}/mysqld_safe --defaults-file=/data/${port}/my.cnf2>&1 > /dev/null &

}

 

#stop function

function_stop_mysql()

{

   printf "Stoping MySQL...\n"

   ${CmdPath}/mysqladmin -u ${mysql_user} -p${mysql_pwd} -S/data/${port}/mysql.sock shutdown

}

 

#restart function

function_restart_mysql()

{

   printf "Restarting MySQL...\n"

   function_stop_mysql

   sleep 2

   function_start_mysql

}

 

case $1 in

start)

   function_start_mysql

;;

stop)

   function_stop_mysql

;;

restart)

   function_restart_mysql

;;

*)

   printf "Usage: /data/${port}/mysql {start|stop|restart}\n"

esac

 

设置开机自启动

chmod +x /etc/init.d/mysqld_3306

chmod +x /etc/init.d/mysqld_3307

chkconfig --add mysqld_3306

chkconfig --add mysqld_3307


登录测试

mysql -uroot -S /data/3306/mysql.sock

mysql -uroot -S /data/3307/mysql.sock

都是可以登录的,后面和普通的数据库一样操作就行了。










本文转自 lirulei90 51CTO博客,原文链接:http://blog.51cto.com/lee90/1826449,如需转载请自行联系原作者
相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
目录
相关文章
|
4月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
4月前
|
Ubuntu 安全 关系型数据库
安装与配置MySQL 8 on Ubuntu,包括权限授予、数据库备份及远程连接指南
以上步骤提供了在Ubuntu上从头开始设置、配置、授权、备份及恢复一个基础但完整的MySQL环境所需知识点。
524 7
|
4月前
|
SQL 监控 关系型数据库
查寻MySQL或SQL Server的连接数,并配置超时时间和最大连接量
以上步骤提供了直观、实用且易于理解且执行的指导方针来监管和优化数据库服务器配置。务必记得,在做任何重要变更前备份相关配置文件,并确保理解每个参数对系统性能可能产生影响后再做出调节。
528 11
|
4月前
|
存储 弹性计算 关系型数据库
如何通过控制台创建RDS MySQL实例
本文介绍了通过控制台创建RDS MySQL实例的详细步骤,包括准备工作、选择计费方式、地域、实例规格、存储空间等关键配置,并指导用户完成下单与实例查看。
|
5月前
|
存储 关系型数据库 MySQL
【赵渝强老师】MySQL数据库的多实例环境
MySQL多实例是指在一台服务器上运行多个MySQL服务,通过不同端口提供独立的数据服务。各实例共享安装程序,但使用各自的配置文件和数据文件,实现资源高效利用。本文详细介绍了如何通过“mysqld_multi”工具配置和启动多个MySQL实例,并演示了目录创建、初始化、配置文件修改及实例启动等操作步骤。
266 1
|
4月前
|
关系型数据库 MySQL 索引
MySQL多表练习笔记
链接可行,多表查询语法
141 0
|
9月前
|
Ubuntu 关系型数据库 MySQL
在Ubuntu 22.04上配置和安装MySQL
以上就是在Ubuntu 22.04上配置和安装MySQL的步骤。这个过程可能看起来有点复杂,但只要按照步骤一步步来,你会发现其实并不难。记住,任何时候都不要急于求成,耐心是解决问题的关键。
1074 31
|
8月前
|
关系型数据库 MySQL Java
安装和配置JDK、Tomcat、MySQL环境,以及如何在Linux下更改后端端口。
遵循这些步骤,你可以顺利完成JDK、Tomcat、MySQL环境的安装和配置,并在Linux下更改后端端口。祝你顺利!
518 11
|
9月前
|
SQL Oracle 关系型数据库
在MySQL Shell里 重启MySQL 8.4实例
在MySQL Shell里 重启MySQL 8.4实例
292 2
|
9月前
|
存储 Oracle 关系型数据库
MySQL 8.4 配置SSL组复制(八个步骤)
MySQL 8.4 配置SSL组复制(八个步骤)
650 0

推荐镜像

更多