什么是mariadb?
MariaDB數據庫管理系統是MySQL的一個分支,主要由開源社區在維護,采用GPL授權許可。開發這個分支的原因之一是:甲骨文公司收購了MySQL后,有將MySQL閉源的潛在風險,因此社區采用分支的方式來避開這個風險。 MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能輕松成為MySQL的代替品。在存儲引擎方面,使用XtraDB(英語:XtraDB)來代替MySQL的InnoDB。 MariaDB由MySQL的創始人Michael Widenius(英語:Michael Widenius)主導開發,他早前曾以10億美元的價格,將自己創建的公司MySQL AB賣給了SUN,此后,隨着SUN被甲骨文收購,MySQL的所有權也落入Oracle的手中。MariaDB名稱來自Michael Widenius的女兒Maria的名字。(來自百度百科)
多實例介紹
簡單的說,就是在一台機器上開啟多個不同的服務端口(如:3306,3307),運行多個mysql服務進程,這些服務進程通過不同的socket監聽不同的服務端口來提供各自的服務。
這些mysql多實例公用一套mysql安裝程序,使用不同的my.cnf配置文件、啟動程序、數據文件。在提供服務時,多實例mysql在邏輯上看來是各自獨立的,多個實例之間是根據配置文件的設定值,來取得相關服務器的硬件資源。
作個比喻,mysql多實例相當於房子的多個卧室一樣,每個實例可以看作一個卧室,整個服務器就是一套房子,服務器的硬件資源(cpu,mem,disk)可以看作房子的衛生間、廚房、客廳一樣,是房子的公用資源。(來自老男孩培訓)
部署:
####環境####
虛擬機:1台
linux系統及內核版本:
CentOS release 6.4 (Final)
2.6.32-358.el6.x86_64
#下載安裝包
wget http://www.cmake.org/files/v2.8/cmake-2.8.5.tar.gz
wget http://dl.mysql.cn/mariadb/5.5/mariadb-5.5.25.tar.gz
#編譯安裝cmake
tar zxf cmake-2.8.5.tar.gz
cd cmake-2.8.5
./bootstrap
make
make install
cd ..
#編譯安裝mariadb
useradd mysql -s /sbin/nologin -M
yum install ncurses-devel -y
yum install libaio-devel -y
tar zxf mariadb-5.5.25.tar.gz
cd mariadb-5.5.25
cmake . -LH|more #CMake下查看mariadb的編譯配置
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
make -j 4 #-j指定用於編譯的CPU核數,可以加快編譯速度
make install
#創建多實例的數據目錄
#我這邊配置了兩個實例,如果想3個、4個同理往下增加即可。
[root@mariadb ~]# mkdir -p /data/{3306,3307}/data
[root@mariadb ~]# cd /data/
[root@mariadb data]# tree
.
├── 3306
│ └── data
└── 3307
└── data
[root@mariadb data]# ll
總用量 8
drwxr-xr-x. 3 root root 4096 5月 7 22:41 3306
drwxr-xr-x. 3 root root 4096 5月 7 22:41 3307
[root@mariadb data]# chown -R mysql.mysql *
[root@mariadb data]# ll
總用量 8
drwxr-xr-x. 3 mysql mysql 4096 5月 7 22:41 3306
drwxr-xr-x. 3 mysql mysql 4096 5月 7 22:41 3307
配置第一個實例:
#拷貝配置文件
[root@mariadb 3306]# cp ~/tools/mariadb-5.5.25/support-files/my-small.cnf ./my.cnf
#修改配置文件
[root@mariadb 3306]# cat my.cnf
[client]port = 3306
socket = /data/3306/mysql.sock
[mysql]
no-auto-rehash
[mysqld]
user = mysql
port = 3306
socket = /data/3306/mysql.sock
basedir = /application/mariamysql
datadir = /data/3306/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/3306/error.log
#log-slow-queries = /data/3306/slow.log
pid-file = /data/3306/mysql.pid
log-bin = /data/3306/mysql-bin
relay-log = /data/3306/relay-bin
relay-log-info-file = /data/3306/relay-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/3306/mysql_oldboy3306.err
pid-file=/data/3306/mysqld.pid
#編寫啟動腳本
[root@mariadb 3306]# cat mariadb
#!/bin/shport=3306mysql_user="root"mysql_pwd=""CmdPath="/application/mariamysql/bin"mysql_sock="/data/${port}/mysql.sock"#startup functionfunction_start_mysql(){if [ ! -e "$mysql_sock" ];thenprintf "Starting MariaMySQL...\n"/bin/sh ${CmdPath}/mysqld_safe --defaults-file=/data/${port}/my.cnf 2>&1 > /dev/null &elseprintf "MariaMySQL is running...\n"exitfi}#stop functionfunction_stop_mysql(){if [ ! -e "$mysql_sock" ];thenprintf "MariaMySQL is stopped...\n"exitelseprintf "Stoping MariaMySQL...\n"${CmdPath}/mysqladmin -u ${mysql_user} -p${mysql_pwd} -S /data/${port}/mysql.sock shutdownfi}#restart functionfunction_restart_mysql(){printf "Restarting MariaMySQL...\n"function_stop_mysqlsleep 2function_start_mysql}case $1 instart)function_start_mysql;;stop)function_stop_mysql;;restart)function_restart_mysql;;*)printf "Usage: /data/${port}/mysql {start|stop|restart}\n"esac
#啟動腳本更改為700權限
[root@mariadb 3306]# chmod 700 mariadb
#初始化數據庫(注意這里的datadir)
[root@mariadb 3306]#/application/mariamysql/scripts/mysql_install_db --basedir=/application/mariamysql/ --datadir=/data/3306/data/ --user=mysql
#啟動數據庫
[root@mariadb 3306]# /data/3306/mariadb start
Starting MariaMySQL...
#檢查
[root@mariadb 3306]# lsof -i :3306
COMMAND PID USER FD TYPE DEVICE SIZE/OFF NODE NAME
mysqld 29380 mysql 15u IPv4 116393 0t0 TCP *:mysql (LISTEN)
#登錄數據庫(注意登錄寫法)
[root@mariadb 3306]# /application/mariamysql/bin/mysql -S /data/3306/mysql.sock
Welcome to the MariaDB monitor. Commands end with ; or \g.
Your MariaDB connection id is 1
Server version: 5.5.25-MariaDB-log MariaDB Server
This software comes with ABSOLUTELY NO WARRANTY. This is free software,
and you are welcome to modify and redistribute it under the GPL v2 license
Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.
MariaDB [(none)]> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| test |
+--------------------+
4 rows in set (0.00 sec)
MariaDB [(none)]>
配置第二個實例:
\cp /data/3306/my.cnf /data/3307/
\cp /data/3306/mariadb /data/3307/
sed -i 's#3306#3307#g' /data/3307/my.cnf
#注配置文件內的server-id要與上個實例的配置文件不同。我這改成server-id = 2
sed -i 's#3306#3307#g' /data/3307/mariadb
chown -R mysql.mysql /data/3307/
chmod 700 /data/3307/mariadb
/application/mariamysql/scripts/mysql_install_db --basedir=/application/mariamysql/ --datadir=/data/3307/data/ --user=mysql
/data/3307/mariadb start
netstat -lnt |grep 3307
/application/mariamysql/bin/mysql -S /data/3307/mysql.sock
檢查:
[root@mariadb 3307]# netstat -lnt |grep 330
tcp 0 0 0.0.0.0:3307 0.0.0.0:* LISTEN
tcp 0 0 0.0.0.0:3306 0.0.0.0:* LISTEN
本文出自 “Chocolee” 博客,請務必保留此出處http://chocolee.blog.51cto.com/8158455/1408351
本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系我们删除。