Chinaunix首页 | 论坛 | 博客
  • 博客访问: 191858
  • 博文数量: 17
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 767
  • 用 户 组: 普通用户
  • 注册时间: 2013-04-02 12:04
文章分类

全部博文(17)

文章存档

2015年(1)

2014年(7)

2013年(9)

我的朋友

分类: Mysql/postgreSQL

2014-06-13 15:47:16

MariaDB多实例

什么是mariadb

 

MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可。开发这个分支的原因之一是:甲骨文公司收购了MySQL后,有将MySQL闭源的潜在风险,因此社区采用分支的方式来避开这个风险。 MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。在存储引擎方面,使用XtraDB(英语:XtraDB)来代替MySQLInnoDB MariaDBMySQL的创始人Michael Widenius(英语:Michael Widenius)主导开发,他早前曾以10亿美元的价格,将自己创建的公司MySQL AB卖给了SUN,此后,随着SUN被甲骨文收购,MySQL的所有权也落入Oracle的手中。MariaDB名称来自Michael Widenius的女儿Maria的名字。(来自百度百科)

多实例介绍

 

简单的说,就是在一台机器上开启多个不同的服务端口(如:3306,3307),运行多个mysql服务进程,这些服务进程通过不同的socket监听不同的服务端口来提供各自的服务。

 

搭建环境

操作系统:CentOS 6.4

Mariadb: 5.5.25

PORT33073308

 

 

安装单实例mariadb

[root@test60 ~]#wget  

[root@test60 ~]#wget  

安装cmake

[root@test60 ~]# tar xzvf cmake-2.8.5

[root@test60 ~]# cd cmake-2.8.5

[root@test60 ~]#./bootstrap

[root@test60 ~]#make

[root@test60 ~]#make install

[root@test60 ~]#cd ..

 

安装mariadb

[root@test60 ~]# useradd mysql –s /sbin/nologin –M

[root@test60 ~]# yum install

[root@test60 ~]# yum install ncurses-devel –y

[root@test60 ~]# yum install libaio-devel –y

[root@test60 ~]# tar xzvf mariadb-5.5.25.tar.gz

[root@test60 ~]# cd mariadb-5.5.25

[root@test60 mariadb-5.5.25]# cmake .\

-DCMAKE_INSTALL_PREFIX=/usr/local/mariamysql \

-DWITH_INNOBASE_STORAGE_ENGINE=1 \

-DWITH_FEDERATED_STORAGE_ENGINE=1 \

-DENABLED_LOCAL_INFILE=1 \

-DEXTRA_CHARSETS=all \

-DDEFAULT_CHARSET=utf8 \

-DDEFAULT_COLLATION=utf8_general_ci \

-DWITH_DEBUG=0 \

-DBUILD_CONFIG=mysql_release \

-DFEATURE_SET=community \

-DWITH_EMBEDDED_SERVER=OFF

[root@test60 mariadb-5.5.25]#make -j 4

[root@test60 mariadb-5.5.25]#make install

 

创建目录

[root@test60 ~]#mkdir -p /data/{3306,3307}/data

[root@test60 ~]# cd /data

[root@test60 ~]#chown –R mysql.mysql 3007

[root@test60 ~]#chown –R mysql.mysql 3008

 

创建配置文件my.cnf

[root@test60 ~]#cd /data/3307

[root@test60 ~]#vim my.cnf

内容如下:

[client]

port            = 3307

socket          = /data/3307/mysql.sock

[mysql]

no-auto-rehash

[mysqld]

user    = mysql

port    = 3307

socket  = /data/3307/mysql.sock

basedir = /usr/local/mariamysql

datadir = /data/3307/data

open_files_limit    = 1024

back_log = 600

max_connections = 800

max_connect_errors = 3000

table_cache = 614

external-locking = FALSE

max_allowed_packet =8M

sort_buffer_size = 1M

join_buffer_size = 1M

thread_cache_size = 100

thread_concurrency = 2

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

##log_long_format

##log-error = /data/3307error.log

##log-slow-queries = /data/3307slow.log

#pid-file = /data/3307mysql.pid

#log-bin = /data/3307mysql-bin

#relay-log = /data/3307relay-bin

#relay-log-info-file = /data/3307relay-log.info

#binlog_cache_size = 1M

#max_binlog_cache_size = 1M

#max_binlog_size = 2M

#expire_logs_days = 7

#key_buffer_size = 16M

#read_buffer_size = 1M

#read_rnd_buffer_size = 1M

#bulk_insert_buffer_size = 1M

##myisam_sort_buffer_size = 1M

##myisam_max_sort_file_size = 10G

##myisam_max_extra_sort_file_size = 10G

##myisam_repair_threads = 1

##myisam_recover

#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:128M:autoextend

#innodb_file_io_threads = 4

#innodb_thread_concurrency = 8

#innodb_flush_log_at_trx_commit = 2

#innodb_log_buffer_size = 2M

#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=/data/3307mysql_oldboy3306.err

#pid-file=/data/3307mysqld.pid

 

创建启动脚本

[root@test60 ~]#cd /data/3307

[root@test60 ~]#vim mariadb

#!/bin/sh

port=3307

mysql_user="root"

mysql_pwd=""

CmdPath="/usr/local/mariamysql/bin"

mysql_sock="/data/${port}/mysql.sock"

 

#startup function

function_start_mysql()

{

if [ ! -e "$mysql_sock" ];then

printf "Starting MariaMySQL...\n"

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

else

printf "MariaMySQL is running...\n"

exit

fi

}

#stop function

function_stop_mysql()

{

if [ ! -e "$mysql_sock" ];then

printf "MariaMySQL is stopped...\n"

exit

else

printf "Stoping MariaMySQL...\n"

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

fi

}

#restart function

function_restart_mysql()

{

printf "Restarting MariaMySQL...\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

 

[root@test60 ~]#chmod 700 mariadb

 

数据库初始化

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

 

启动端口为3307的数据库实例

[root@test60 ~]#/data/3307/mariadb start

检查是否正常监听

[root@test60 ~]# lsof -i :3307

COMMAND  PID  USER   FD   TYPE  DEVICE SIZE/OFF NODE NAME

mysqld  7261 mysql   14u  IPv4 7939256      0t0  TCP *:opsession-prxy (LISTEN)

测试是否能登陆

[root@test60 ~]# /usr/local/mariamysql/bin/mysql -u root -p -S /data/3307/mysql.sock

 

增加mariadb实例(端口:3308

[root@test60 ~]# cd /data/3308

[root@test60 3308]# cp ../3307/my.cnf .

[root@test60 3308]# cp ../3307/mariadb .

[root@test60 3308]# sed -i 's#3307#3308#g' my.cnf

[root@test60 3308]# sed -i 's#3307#3308#g' mariadb

[root@test60 3308]#chown –R mysql.mysql /data/3308

[root@test60 3308]#chmod 700 mariadb

[root@test60 3308]# /usr/local/mariamysql/scripts/mysql_install_db --basedir=/usr/local/mariamysql/ --datadir=/data/3307/data --user=mysql

[root@test60 3308]#/data/3308/mariadb start

[root@test60 3308]# /usr/local/mariamysql/bin/mysql -u root -p -S /data/3307/mysql.sock

 

[root@test60 3308]# netstat -lntp | grep 330

tcp        0      0 0.0.0.0:3307                0.0.0.0:*                   LISTEN      7261/mysqld        

tcp        0      0 0.0.0.0:3308                0.0.0.0:*                   LISTEN      13824/mysqld       

 

 

阅读(5010) | 评论(1) | 转发(2) |
给主人留下些什么吧!~~

kinfinger2014-06-23 12:15:39

已经实现了