一、MySQL多实例介绍

mysql多实例,共用一套mysql安装程序,使用不同的配置文件(my.cnf)、启动程序、和数据文件,即在一台服务器上同时开启多个不同的服务器端口(3306,3307),同时运行多个mysql服务进程,这些服务进程通过不同的socket监听不同的服务器端口来提供服务。

二、安装mysql多实例

1.下载mysql/cmake安装包

1
2
3
[root@slave ~]# mkdir /home/tools
[root@slave ~]# wget –P /home/tools https://cmake.org/files/v2.8/cmake-2.8.12.tar.gz
[root@slave tools]# wget -P /home/tools/ http://cdn.mysql.com//Downloads/MySQL-5.5/mysql-5.5.50.tar.gz

2.建立账号

1
2
3
4
5
6
[root@slave ~]# groupadd mysql
[root@slave ~]# useradd -s /sbin/nologin -g mysql -M mysql
useradd参数说明:
   -s /sbin/nologin        # 表示禁止该用户登录,只需角色存在即可,加强安全
   -g mysql                # 指定属组
   -M                      # 表示不创建用户家目录

3.配置安装环境

创建目录并授权

1
2
3
4
[root@slave ~]# mkdir -p /usr/local/mysql
[root@slave ~]# mkdir -p /db/{3306,3307}/data       # 多实例文件目录结构
[root@slave ~]# chown -R mysql.mysql /usr/local/mysql
[root@slave ~]#  chown -R mysql.mysql /db

安装依赖

1
[root@slave ~]# yum install gcc gcc-c++ make cmake ncurses-devel bison perl -y

配置解析

1
2
3
4
[root@slave ~]# uname -n
slave
[root@slave ~]# vim /etc/hosts
192.168.10.65   slave

4.安装mysql(在这一步和之前,安装配置都和单实例配置相同)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
[root@slave tools]# tar -zxf mysql-5.5.50.tar.gz
[root@slave tools]# cd mysql-5.5.50
[root@slave mysql-5.5.50]# cmake \
> -DCMAKE_INSTALL_PREFIX=/usr/local/mysql/ \
> -DMYSQL_DATADIR=/db/3306/data \    # 这里数据目录先指定一个,后面初始化时手工配置
> -DMYSQL_TCP_PORT=3306 \
> -DDEFAULT_CHARSET=utf8 \
> -DDEFAULT_COLLATION=utf8_general_ci \
> -DEXTRA_CHARSETS=all \
> -DENABLED_LOCAL_INFILE=ON \
> -DWITH_INNOBASE_STORAGE_ENGINE=1 \
> -DWITH_FEDERATED_STORAGE_ENGINE=1 \
> -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
> -DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 \
> -DWITHOUT_PARTITION_STORAGE_ENGINE=1 \
> -DWITH_FAST_MUTEXES=1 \
> -DWITH_ZLIB=bundled \
> -DENABLED_LOCAL_INFILE=1 \
> -DWITH_READLINE=1 \
> -DWITH_EMBEDDED_SERVER=1 \
> -DWITH_DEBUG=0 \
> -DMYSQL_UNIX_ADDR=/tmp/mysql.sock

1
2
[root@slave mysql-5.5.50]# make
[root@slave mysql-5.5.50]# make install

5.创建mysql多实例配置文件

1
2
[root@slave ~]# vim /db/3306/my.cnf
[root@slave ~]# vim /db/3307/my.cnf

MySQL  3306实例

MySQL  3307实例

[client]

port        = 3306

socket      = /db/3306/mysql.sock

[mysql]

no-auto-rehash

[mysqld]

user        = mysql

port        = 3306

socket      = /db/3306/mysql.sock

basedir     = /usr/local/mysql/

datadir     = /db/3306/data

open_files_limit    = 1024

back_log  = 600

max_connections  = 800

max_connect_errors  = 3000

table_cache  = 1024

external-locking    = FALSE

max_allowed_packet  = 16M

sort_buffer_size  = 8M

join_buffer_size  = 8M

thread_cache_size  = 100

thread_concurrency  = 8

query_cache_size  = 2M

query_cache_limit  = 1M

query_cache_min_res_unit  = 2k

#default_table_type  = InnoDB

thread_stack  = 192K

#transaction_isolation  = READ-COMMITTED

tmp_table_size  = 2M

max_heap_table_size  = 2M

long_query_time  = 1

pid-file=/db/3306/mysql.pid

relay-log  = /db/3306/relay-bin

relay-log-info-file  = /db/3306/relay-log.info

binlog_cache_size  = 1M

max_binlog_cache_size  = 1M

max_binlog_size  = 1M

key_buffer_size  = 16M

read_buffer_size  = 1M

read_rnd_buffer_size  = 1M

bulk_insert_buffer_size  = 1M

lower_case_table_names  = 1

skip-name-resolve

slave-skip-errors  = 1032,1062

replicate-ignore-db  = mysql

server-id  = 1

innodb_additional_mem_pool_size  = 4M

innodb_buffer_pool_size  = 32M

innodb_data_file_path  = ibdata1:28M:autoextend

innodb_file_io_threads  = 4

innodb_thread_concurrency  = 16

innodb_flush_log_at_trx_commit  = 2

innodb_log_buffer_size  = 8M

innodb_log_file_size  = 4M

innodb_log_files_in_group  = 3

innodb_max_dirty_pages_pct  = 90

innodb_lock_wait_timeout  = 120

innodb_file_per_table  = 0

[mysqldump]

quick

max_allowed_packet  = 2M

[mysqld_safe]

log-error=/db/3306/mysql_3306.err

pid-file=/db/3306/mysql.pid

[client]

port        = 3307

socket      = /db/3307/mysql.sock

[mysql]

no-auto-rehash

[mysqld]

user        = mysql

port        = 3307

socket      = /db/3307/mysql.sock

basedir     = /usr/local/mysql/

datadir     = /db/3307/data

open_files_limit    = 1024

back_log  = 600

max_connections  = 800

max_connect_errors  = 3000

table_cache  = 1024

external-locking    = FALSE

max_allowed_packet  = 16M

sort_buffer_size  = 8M

join_buffer_size  = 8M

thread_cache_size  = 100

thread_concurrency  = 8

query_cache_size  = 2M

query_cache_limit  = 1M

query_cache_min_res_unit  = 2k

#default_table_type  = InnoDB

thread_stack  = 192K

#transaction_isolation  = READ-COMMITTED

tmp_table_size  = 2M

max_heap_table_size  = 2M

long_query_time  = 1

pid-file=/db/3307/mysql.pid

relay-log  = /db/3307/relay-bin

relay-log-info-file  = /db/3307/relay-log.info

binlog_cache_size  = 1M

max_binlog_cache_size  = 1M

max_binlog_size  = 1M

key_buffer_size  = 16M

read_buffer_size  = 1M

read_rnd_buffer_size  = 1M

bulk_insert_buffer_size  = 1M

lower_case_table_names  = 1

skip-name-resolve

slave-skip-errors  = 1032,1062

replicate-ignore-db  = mysql

server-id  = 3

innodb_additional_mem_pool_size  = 4M

innodb_buffer_pool_size  = 32M

innodb_data_file_path  = ibdata1:28M:autoextend

innodb_file_io_threads  = 4

innodb_thread_concurrency  = 16

innodb_flush_log_at_trx_commit  = 2

innodb_log_buffer_size  = 8M

innodb_log_file_size  = 4M

innodb_log_files_in_group  = 3

innodb_max_dirty_pages_pct  = 90

innodb_lock_wait_timeout  = 120

innodb_file_per_table  = 0

[mysqldump]

quick

max_allowed_packet  = 2M

[mysqld_safe]

log-error=/db/3307/mysql_3307.err

pid-file=/db/3307/mysql.pid

完成后,/db目录结构:

1
2
3
4
5
6
7
8
[root@slave ~]# tree /db
/db
├── 3306
│   ├── data
│   └── my.cnf
└── 3307
    ├── data
    └── my.cnf

6.创建mysql多实例启动文件(3307实例只需更改端口即可)

1
2
[root@slave ~]# vim /db/3306/mysqld.py
[root@slave ~]# vim /db/3307/mysqld.py

编写MySQL启动程序

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
#!/bin/env python
# -*- coding:utf-8 -*-
 
'''
MySQL多实例启动程序
'''
import os,sys,time
import subprocess
 
class Mysql_init:
    def __init__(self):
        self.user = 'root'
        self.port = '3306'
        self.passwd = 'q.123456'
        self.Cmd_path = '/usr/local/mysql/bin'
        self.sock = '/db/%s/mysql.sock'%self.port
 
    def jindu(self):
        for i in range(2):
            sys.stdout.write('.')
            time.sleep(1)
            sys.stdout.flush()
        time.sleep(1)
        return '.'
 
    def start(self):
        if os.path.exists(self.sock):
            print 'MySQL already running.'
        else:
            val = subprocess.call('/bin/sh %s/mysqld_safe --defaults-file=/db/%s/my.cnf 2>&1 >/dev/null &'%(self.Cmd_path,self.port),shell=True)
            if val == 0:
                print 'Starting MySQL',
                print '%s'% self.jindu(),
                print 'SUCCESS!'.strip()
                return True
            else:
                print 'MySQL start failed.'
 
    def stop(self):
        if os.path.exists(self.sock):
            val = subprocess.call('%s/mysqladmin -u%s -p%s -S %s shutdown'%(self.Cmd_path, self.user,self.passwd,self.sock),shell=True)
            if val == 0:
                print 'Shutting down MySQL',
                print '%s'%self.jindu(),
                print 'SUCCESS!'.strip()
                return True
            else:
                print 'MySQL stop failed.'
        else:
            print 'MySQL already stopped.'
 
    def restart(self):
        self.stop()
        self.start()
 
    def main(self):
        if sys.argv[1] == 'start':
            self.start()
        elif sys.argv[1] == 'stop':
            self.stop()
        elif sys.argv[1] == 'restart':
            self.restart()
        else:
            print 'Usage: mysqld  {start|stop|restart}  [ MySQL server options ]'
 
if __name__ == '__main__':
    ret = Mysql_init()
    ret.main()

给程序加权限

1
2
3
[root@slave 3306]# chmod +x mysqld.py
[root@slave 3307]# chmod +x mysqld.py
[root@slave ~]# chown mysql.mysql /db –R            # 授权

最终/db目录结构:

1
2
3
4
5
6
7
8
9
10
[root@slave ~]# tree /db
/db
├── 3306
│   ├── data
│   ├── my.cnf
│   └── mysqld.py
└── 3307
    ├── data
    ├── my.cnf
    └── mysqld.py

7.配置mysql环境变量

1
2
[root@slave ~]# echo 'export PATH=/usr/local/mysql/bin:$PATH' >>/etc/profile
[root@slave ~]# source /etc/profile

8.初始化mysql多实例数据库文件

1
2
3
[root@slave ~]# cd /usr/local/mysql/scripts/
[root@slave scripts]# ./mysql_install_db --basedir=/usr/local/mysql/ --datadir=/db/3306/data/  --user=mysql     # 3306
[root@slave scripts]# ./mysql_install_db --basedir=/usr/local/mysql/ --datadir=/db/3307/data/  --user=mysql     # 3307

9.启动多实例mysql

1
2
3
4
[root@slave ~]# /db/3306/mysqld.py start
Starting MySQL... SUCCESS!
[root@slave ~]# /db/3307/mysqld.py start
Starting MySQL... SUCCESS!

10.为mysql多实例设置密码(安装好之后,默认没有密码)

1
2
[root@slave ~]# mysqladmin -uroot -S /db/3306/mysql.sockpassword 'q.123456'
[root@slave ~]# mysqladmin -uroot -S /db/3307/mysql.sockpassword 'q.123456'

11.登录mysql

1
2
[root@slave ~]# mysql -uroot -pq.123456 -S /db/3306/mysql.sock
[root@slave ~]# mysql -uroot -pq.123456 -S /db/3307/mysql.sock

12.权限设定(因为启动程序中带有mysql密码)

1
2
[root@slave ~]# chmod 700 /db/{3306,3307}/mysqld.py
[root@slave ~]# chown root.root /db/{3306,3307}/mysqld.py

MySQL 第二篇的更多相关文章

  1. 详解MySQL第二篇—DML语句

    DML 语句: DML 操作是指对数据库中表记录的操作,主要包括表记录的插入(insert).更新(update).删除(delete)和查(select),是开发人员日常使用最频繁的操作.下面将依次 ...

  2. MySQL 第二篇:库操作

    一 系统数据库 information_schema: 虚拟库,不占用磁盘空间,存储的是数据库启动后的一些参数,如用户表信息.列信息.权限信息.字符信息等performance_schema: MyS ...

  3. 第二章 MySQL入门篇

    第一章 MySQL入门篇 一.MySql简介 简言: 和SQL Server数据库相同,MySQl也是一个关系型数据库管理系统.由瑞典的MySQL AB公司开发,2008年被SUN公司收购,2009年 ...

  4. 小白两篇博客熟练操作MySQL 之 第二篇

    小白两篇博客熟练操作MySQL  之   第二篇 一. 视图 视图是一个虚拟表,其本质是根据SQL语句获取动态的数据集,并为其命名,用户使用时只需使用名称即可获取结果集, 并可以将其当做表来使用. s ...

  5. Mysql优化(出自官方文档) - 第二篇

    Mysql优化(出自官方文档) - 第二篇 目录 Mysql优化(出自官方文档) - 第二篇 1 关于Nested Loop Join的相关知识 1.1 相关概念和算法 1.2 一些优化 1 关于Ne ...

  6. Pentaho BIServer Community Edtion 6.1 使用教程 第二篇 迁移元数据 [HSQLDB TO MySQL]

    第一部分  迁移原因 Pentaho BI 社区版服务的很多元数据信息存储在数据库汇总,其默认使用HSQLDB 数据库,即借助它存储自身的资料库,比如 Quartz 调度信息.业务资料库连接信息(数据 ...

  7. PHP 性能分析第二篇: Xhgui In-Depth

    [前言]这是国外知名博主 Davey Shafik 撰写的 PHP 应用性能分析系列的第二篇,第一篇介绍 Xhprof/Xhgui,第三篇则关注于性能调优实践. 在第一篇中,我们初步介绍了 xhpro ...

  8. mysql 架构篇系列 4 复制架构一主一从搭建(半同步复制)

    一.概述 在mysql 5.5之前,mysql 的复制是异步操作,主库和从库的数据之间存在一定的延时,这样存在一个隐患:当主库上写入一个事务并提交成功,而从库尚未得到主库推送的Binlog日志时,主库 ...

  9. SSH整合 第二篇 工程初建

    SSH整合,第二篇. 创建工程 这里只是测试和理解hibernate.建立Java工程就好了. 1.hibernate-4.2.21.jar hibernate包下的required,即\hibern ...

随机推荐

  1. C#动手实践:Kinect V2 开发(2):数据源工作原理及红外源Demo

    Kinect体系架构

  2. ios webview 只能播放带域名的视频连接好奇怪!

    - (void)loadWebView { UIWebView *webView = [[UIWebView alloc] initWithFrame:CGRectMake(, , SCREEN_WI ...

  3. Spring+Quartz(定时任务)

    此处用到的Quartz版本是quartz-2.2.3 官方网站:http://www.opensymphony.com/quartz 首先先介绍用到的几个关键类:scheduler任务调度.Job任务 ...

  4. 网购vs实体店购物 [20161226]

    2016这一年依然网购了许多商品,比起以往,我选择退货的次数更多了. 以前如果网购到尺码或者样式不合适的东西,有时候将就拿去用,没有选择退货.由此闲置了不少衣物,而且延续高中时喜欢穿大一号的衣服的习惯 ...

  5. [HTML] IE=edge,chrome=1的META标签详解

    文件兼容性用于定义让IE如何编译你的网页.此文件解释文件兼容性,如何指定你网站的文件兼容性模式以及如何判断一个网页该使用的文件模式. meta信息中常有这么一句: <meta content=& ...

  6. 我用VS2012在Nuget中安装Signalr之后报错

    我用VS2012在Nuget中安装Signalr之后报错 “/”应用程序中的服务器错误. The following errors occurred while attempting to load ...

  7. #define中 #与##用法

    参考自: http://zjf30366.blog.163.com/blog/static/411164582009061075923/ #include<cstdio> #include ...

  8. Oracle Hang分析--转载

    1. 数据库hang的几种可能性 oracle 死锁 或者系统负载非常高比如cpu使用或其他一些锁等待很高都可能导致系统hang住,比如大量的DX锁. 通常来说,我们所指的系统hang住,是指应用无响 ...

  9. Redis 配置文件

    # Redis configuration file example. # # Note that in order to read the configuration file, Redis mus ...

  10. html基础 链接

    使用图像来作链接: (链接标签中嵌套图片标签) <html> <body> <p> 您也可以使用图像来作链接: <a href="/example/ ...