zoukankan      html  css  js  c++  java
  • MySql5.7多实例配置教程

    最近朋友在搞在Linux上配置MySql5.7多实例教程,在网上查询了很多资料,一直报各种各样的错误,后来在网上搜了一篇博客,根据其配置,最近是配置成功了

    参考配置连接:https://blog.csdn.net/zougen/article/details/79567744

    在开始正式配置之前,应该先问自己几个问题:

    • 什么是数据库多实例

         简单的说,MySql多实例就是在一台服务器上同时开启多个不同的服务端口(如:3306、3307等),同时运行多个MySql服务进程,这些服务进程通过不同的Socket监听不同的服务端口来提供服务。

    • 多实例的好处
    1. 可有效利用服务器资源。当单个服务器资源有剩余时,可以充分利用剩余资源提供更多的服务,且可以实现资源的逻辑隔离
    2. 节约服务器资源。例如公司服务器资源紧张,但是数据库又需要各自尽量独立的提供服务,并且还需要到主从复制等技术,多实例就是您的最佳选择
    • 多实例弊端

        存在资源互相抢占的问题。比如:当某个数据库实例并发很高或者SQL查询慢时,整个实例会消耗大量的CPU、磁盘I/O等资源,导致服务器上面其他的数据库实例在提供服务的质量也会下降

    所以具体的需求要根据自己的实际情况而定。

    下面我们来具体说一下MySql5.7的多实例配置:

    1,几个实例要分开运行,则必须放在不同的文件夹下才可以,为了方便文章后期的操作,我们则根据端口来命名文件夹(3306/3307/3308),新建文件夹有两种形式

    • 通过命令“mkdir /usr/mysql/3306”手动创建文件夹
    • 通过配置文件自动生成配置下的文件夹

    2,通过命令(vim/vi)来创建初始化数据配置文件(3306.cnf)的配置文件并根据自己的数据库安装,更改文件中的信息(最终初始化后即可删除),配置文件内容如下:

    [client]
    port        = 3306
    socket      = /tmp/mysql3308.sock
    
    [mysqld]
    port        = 3306
    socket      = /tmp/mysql3306.sock
    basedir = /usr/local/mysql/mysqlinstall
    datadir = /usr/mysql/3306
     
    skip-external-locking
    key_buffer_size = 256M
    max_allowed_packet = 1M
    table_open_cache = 1024
    sort_buffer_size = 4M
    net_buffer_length = 8K
    read_buffer_size = 4M
    read_rnd_buffer_size = 512K
    myisam_sort_buffer_size = 64M
    thread_cache_size = 128
    query_cache_size = 128M
    tmp_table_size = 128M
    explicit_defaults_for_timestamp = true
    max_connections = 500
    max_connect_errors = 100
    open_files_limit = 65535
    log-bin=/usr/mysql/3306/mysql-bin
    binlog_format=mixed
    server-id   = 3306
    expire_logs_days = 10
    early-plugin-load = ""
    default_storage_engine = InnoDB
    innodb_data_home_dir = /usr/mysql/3306
    innodb_data_file_path = ibdata1:10M:autoextend
    innodb_log_group_home_dir = /usr/mysql/3306
    innodb_buffer_pool_size = 1024M
    innodb_log_file_size = 256M
    innodb_log_buffer_size = 8M
    innodb_flush_log_at_trx_commit = 1
    innodb_lock_wait_timeout = 50
    transaction-isolation=READ-COMMITTED
    
    [mysqldump]
    quick
    max_allowed_packet = 16M
    
    [mysql]
    no-auto-rehash
    
    [myisamchk]
    key_buffer_size = 256M
    sort_buffer_size = 4M
    read_buffer = 2M
    write_buffer = 2M
    
    [mysqlhotcopy]
    interactive-timeout

    3,文件创建完成后,执行下面的命令进行初始化

    mysqld --defaults-file=/usr/mysql/3306.cnf --initialize-insecure --user=mysql 

    注意:此处的初始化方式和安装数据库时初始化方式不同,以下时安装数据库时初始化的方式

    • 安装数据库时的初始化方式为:
    mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/mysql/3306 --user=mysql
    • 在官方教程中新的初始化方式为:
    mysqld --initialize-insecure --user=mysql --basedir=/opt/mysql/mysql --datadir=/opt/mysql/mysql/data
    

    4,初始化完成后,3306.cnf文件就已经完成来,在接下来的配置中会在my.cnf中统一配置,也就是说,在后续的操作中不会在用到3306.cnf这个文件来,可以将其删除,这个时候再去查询则在配置文件中配置的路径下,则会存在3306这个文件夹,根据此步骤,将3307和3308目录进行初始化完成

    注意:目录在初始化之前,必须将文件夹清空,里面不能有任何文件,否则会报错

    5,经过上面的【1~4】步骤,分别将数据目录文件初始化完成,这个时候需要将这三个文件目录的权限更改成和数据库安装目录一直的,否则会报权限的错误

    chown -R mysql.mysql /usr/mysql/3306
    

    6,备份原来的my.cnf文件

    cp /etc/my.cnf /etc/my.cnf.bak
    

    7,编辑my.cnf文件

    vim /etc/my.cnf

    清空原先的内容,然后将里面的内容更改成下面的配置文件,配置完成后通过“:wq”进行保存

    [mysqld_multi]
    mysqld  = /usr/local/mysql/mysqlinstall/bin/mysqld_safe
    mysqladmin = /usr/local/mysql/mysqlinstall/bin/mysqladmin
    [mysqld1]
    port        = 3306
    socket      = /tmp/mysql3306.sock
    datadir = /usr/mysql/3306
    skip-external-locking
    key_buffer_size = 256M
    max_allowed_packet = 1M
    table_open_cache = 1024
    sort_buffer_size = 4M
    net_buffer_length = 8K
    read_buffer_size = 4M
    read_rnd_buffer_size = 512K
    myisam_sort_buffer_size = 64M
    thread_cache_size = 128
    query_cache_size = 128M
    tmp_table_size = 128M
    explicit_defaults_for_timestamp = true
    max_connections = 500
    max_connect_errors = 100
    open_files_limit = 65535
    log-bin=/usr/mysql/3306/mysql-bin
    binlog_format=mixed
    server-id   = 3306
    expire_logs_days = 10
    early-plugin-load = ""
    default_storage_engine = InnoDB
    innodb_data_home_dir = /usr/mysql/3306
    innodb_data_file_path = ibdata1:10M:autoextend
    innodb_log_group_home_dir = /usr/mysql/3306
    innodb_buffer_pool_size = 1024M
    innodb_log_file_size = 256M
    innodb_log_buffer_size = 8M
    innodb_flush_log_at_trx_commit = 1
    innodb_lock_wait_timeout = 50
    transaction-isolation=READ-COMMITTED
    user       = mysql
    
    [mysqld2]
    port        = 3307
    socket      = /tmp/mysql3307.sock
    datadir = /usr/mysql/3307
    skip-external-locking
    key_buffer_size = 256M
    max_allowed_packet = 1M
    table_open_cache = 1024
    sort_buffer_size = 4M
    net_buffer_length = 8K
    read_buffer_size = 4M
    read_rnd_buffer_size = 512K
    myisam_sort_buffer_size = 64M
    thread_cache_size = 128
    query_cache_size = 128M
    tmp_table_size = 128M
    explicit_defaults_for_timestamp = true
    max_connections = 500
    max_connect_errors = 100
    open_files_limit = 65535
    log-bin=/usr/mysql/3307/mysql-bin
    binlog_format=mixed
    server-id   = 3307
    expire_logs_days = 10
    early-plugin-load = ""
    default_storage_engine = InnoDB
    innodb_data_home_dir = /usr/mysql/3307
    innodb_data_file_path = ibdata1:10M:autoextend
    innodb_log_group_home_dir = /usr/mysql/3307
    innodb_buffer_pool_size = 1024M
    innodb_log_file_size = 256M
    innodb_log_buffer_size = 8M
    innodb_flush_log_at_trx_commit = 1
    innodb_lock_wait_timeout = 50
    transaction-isolation=READ-COMMITTED
    user       = mysql
    
    [mysqld3]
    port        = 3308
    socket      = /tmp/mysql3308.sock
    datadir = /usr/mysql/3308
    skip-external-locking
    key_buffer_size = 256M
    max_allowed_packet = 1M
    table_open_cache = 1024
    sort_buffer_size = 4M
    net_buffer_length = 8K
    read_buffer_size = 4M
    read_rnd_buffer_size = 512K
    myisam_sort_buffer_size = 64M
    thread_cache_size = 128
    query_cache_size = 128M
    tmp_table_size = 128M
    explicit_defaults_for_timestamp = true
    max_connections = 500
    max_connect_errors = 100
    open_files_limit = 65535
    log-bin=/usr/mysql/3308/mysql-bin
    binlog_format=mixed
    server-id   = 3308
    expire_logs_days = 10
    early-plugin-load = ""
    default_storage_engine = InnoDB
    innodb_data_home_dir = /usr/mysql/3308
    innodb_data_file_path = ibdata1:10M:autoextend
    innodb_log_group_home_dir = /usr/mysql/3308
    innodb_buffer_pool_size = 1024M
    innodb_log_file_size = 256M
    innodb_log_buffer_size = 8M
    innodb_flush_log_at_trx_commit = 1
    innodb_lock_wait_timeout = 50
    transaction-isolation=READ-COMMITTED
    user       = mysql
    
    [mysqldump]
    quick
    max_allowed_packet = 16M
    
    [mysql]
    no-auto-rehash
    
    [myisamchk]
    key_buffer_size = 256M
    sort_buffer_size = 4M
    read_buffer = 2M
    write_buffer = 2M
    
    [mysqlhotcopy]
    interactive-timeout

    注意:mysqld_multi的配置文件和一般MySQL配置不同,没有[mysqld]段,取而代之的是[mysqld1][mysqld2]等配置段,每个配置段分别代表一个MySQL实例

    8,启动多个MySql实例:

    • 做好以上两个步骤之后,就可以启动MySQL了。
    • 启动时需要一个启动脚本,这个脚本一般在“/usr/local/mysql/support-files”目录下“mysqld_multi.server“,将这个脚本复制到“init.d”目录下
    cp  /usr/local/mysql/support-files/mysqld_multi.server /etc/rc.d/init.d/mysqld_multi  

    之后就可以用命令:

    /etc/rc.d/init.d/mysqld_multi start 1-3

    关闭多个进程的命令:

    /etc/rc.d/init.d/mysqld_multi stop 1-3
    

      

    注意:启动三个MySQL实例,注意这里的数字和my.cnf中的[mysqldN]对应,1-3就是启动[mysqld1][mysqld2][mysqld3]配置段的MySQL实例

    9,运行命令,查看端口,看MySQL有没有正常启动,如果没有启动或报错,一般报错详细日志存在各个实例data目录下的 主机名.err文件中,打开此文件查找错误原因,逐步排错就可以了。

    netstat -ano | egrep "3306|3307|3308"
    

    10,因为在初始化数据目录的时候,用的是--initialize-insecure参数,所以我们初始化的数据库,root账户是没有密码的!要先改密码:

    mysqladmin -uroot password '123' -S /tmp/mysql3306.sock
    mysqladmin -uroot password '123' -S /tmp/mysql3307.sock
    mysqladmin -uroot password '123' -S /tmp/mysql3308.sock

    或者通过下面命令初始化密码:

    mysqladmin -uroot password '123' -P3306 -h127.0.0.1
    mysqladmin -uroot password '123' -P3307 -h127.0.0.1
    mysqladmin -uroot password '123' -P3308 -h127.0.0.1
    

    11,如果需要开启root远程登陆权限

    mysql -uroot -p'123' -P3306 -h127.0.0.1
    
    use mysql
    update user set host='%' where user='root';
    flush privileges;
    select user,host,authentication_string from user;

    小结:

    配置到这的时候说明MySql数据库的多实例已经配置完成,具体在实际中的应用还需根据您的需求

  • 相关阅读:
    2015-10-09 Fri 晴 加快进度看书
    lseek()函数
    pipe()管道最基本的IPC机制
    linux VFS 内核数据结构
    tcp协议中mss的理解
    tcp的精髓:滑动窗口
    2015-10-11 Sunday 晴 ARM学习
    2015-10-12 晴 审面包车
    2015-10-14 晴 tcp/ip
    pyfits过滤数据更新文件。
  • 原文地址:https://www.cnblogs.com/gskstudy/p/10792223.html
Copyright © 2011-2022 走看看