MySQL 之多實例編譯安裝

  • 系統環境
  • yum安裝cmake
  • 開始安裝MySQL
    • 建立MySQL用戶賬號
    • 獲取MySQL軟體包
  • 創建MySQL多實例的數據文件目錄
  • 創建MySQL多實例的配置文件
  • 添加配置文件內容
  • 創建MySQL多實例的啟動文件
      • 配置MySQL多實例的文件許可權
      • 設置環境變數
  • 多實例的登錄方式需要指定sock的。
  • 配置及管理MySQL多實例資料庫

系統環境

[root@db02 ~]# uname -a Linux db02 2.6.32-642.el6.x86_64 #1 SMP Tue May 10 17:27:01 UTC 2016 x86_64 x86_64 x86_64 GNU/Linux

yum安裝cmake

yum install -y cmake

開始安裝MySQL

大型公司一般都會將MySQL軟體定製成rpm包,然後放到yum倉庫里,使用yum安裝,中小企業里的二進位和編譯安裝的區別不大。

建立MySQL用戶賬號

首先以root身份登錄到Linux系統中,然後執行如下命令創建mysql用戶賬號:

useradd -s /sbin/nologin -M mysqlid mysql#根據上述輸出結果,可以看到mysql用戶和組已經成功創建。

獲取MySQL軟體包

MySQL軟體包的下載地址為:http://dev.mysql.com/downloads/mysql/。

可以把軟體下載到客戶端計算機本地後使用rz等工具傳到Linux里,或者找到網路下載地址後直接在Linux里使用wget下載。

提示:本例以MySQL編譯的方式來講解,在生產場景中,二進位和源碼包兩種安裝方法都是可以用的,其應用場景一般沒什麼差別。不同之處在於,二進位的安裝包較大,名字和源碼包也有些區別,二進位安裝過程比源碼更快。

mkdir /home/oldboy/tools -pcd /home/oldboy/tools/#下載MySQL源碼包wget https://downloads.mysql.com/archives/get/file/mysql-5.5.32.tar.gztar xf mysql-5.5.32.tar.gz cd mysql-5.5.32cmake . -DCMAKE_INSTALL_PREFIX=/application/mysql-5.5.32 -DMYSQL_DATADIR=/application/mysql-5.5.32/data -DMYSQL_UNIX_ADDR=/application/mysql-5.5.32/tmp/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DEXTRA_CHARSETS=gbk,gb2312,utf8,ascii -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# 編譯安裝make &&make install &&cd ..

提示,編譯時可配置的選項很多,具體可參考官方文檔

創建MySQL多實例的數據文件目錄

在企業中,通常以/data目錄作為MySQL多實例總的根目錄,然後規劃不同的數字(即MySQL實例埠號)作為/data下面的二級目錄,不同的二級目錄對應的數字就作為MySQL實例的埠號,以區別不同的實例,數字對應的二級目錄下包含MySQL的數據文件、配置文件及啟動文件等。

下面以配置3306、3307兩個實例為例進行講解。創建MySQL多實例的目錄如下:

[root@db02 tools]# mkdir -p /data/{3306,3307}/data[root@db02 tools]# tree /data//data/├── 3306│ └── data└── 3307 └── data

下面為MySQL安裝路徑設置不帶版本號的軟鏈接/application/mysql,操作步驟如下:

[root@db02 tools]# ln -s /application/mysql-5.5.32/ /application/mysql#補充:如果系統里有我們曾經講解過的單實例安裝的資料庫文件和啟動程序,最好停掉或刪除,以免產生衝突[root@db02 tools]# ls /application/mysqlbin data include lib mysql-test scripts sql-benchCOPYING docs INSTALL-BINARY man README share support-files

如果上述操作未出現錯誤,查看/application/mysql/目錄下有內容,則MySQL5.5.32源代碼包採用cmake方式的安裝就算成功了。

創建MySQL多實例的配置文件

MySQL資料庫默認為用戶提供了多個配置文件模板,用戶可以根據伺服器硬體配置的大小來選擇。

[root@db02 tools]# cd /application/mysql-5.5.32/[root@db02 mysql-5.5.32]# ls -l support-files/my*.cnf-rw-r--r-- 1 root root 4759 3月 17 12:05 support-files/my-huge.cnf-rw-r--r-- 1 root root 19809 3月 17 12:05 support-files/my-innodb-heavy-4G.cnf-rw-r--r-- 1 root root 4733 3月 17 12:05 support-files/my-large.cnf-rw-r--r-- 1 root root 4744 3月 17 12:05 support-files/my-medium.cnf-rw-r--r-- 1 root root 2908 3月 17 12:05 support-files/my-small.cnf

注意: 1)關於mysql my.cnf中參數的調優,由於篇幅關係不會詳細介紹,有需要的讀者請參考老男孩老師的相關課程。(因為我是老男孩老師的學生)

2)support-files下有mysql my.cnf的各種配置樣例,裡面的注釋非常詳細,不過是英文的。

上面是單實例的默認配置文件模板,如果配置多實例,和單實例會有不同。為了讓MySQL多實例之間彼此獨立,要為每一個實例建立一個my.cnf配置文件和一個啟動文件MySQL,讓它們分別對應自己的數據文件目錄data。

添加配置文件內容

首先,通過vim命令添加配置文件內容,命令如下: vim /data/3306/my.cnf

[client]port = 3306socket = /data/3306/mysql.sock[mysql]no-auto-rehash[mysqld]#binlog_format = "ROW"character-set-server=utf8user = mysqlport = 3306socket = /data/3306/mysql.sockbasedir = /application/mysqldatadir = /data/3306/dataopen_files_limit = 1024back_log = 600max_connections = 800max_connect_errors = 3000table_cache = 614external-locking = FALSEmax_allowed_packet =8Msort_buffer_size = 1Mjoin_buffer_size = 1Mthread_cache_size = 100thread_concurrency = 2query_cache_size = 2Mquery_cache_limit = 1Mquery_cache_min_res_unit = 2k#default_table_type = InnoDBthread_stack = 192K#transaction_isolation = READ-OOMMITTEDtmp_table_size = 2Mmax_heap_table_size = 2Mlong_query_time = 1log-slow-queries = /data/3306/slow.loglog_queries_not_using_indexespid-file = /data/3306/mysql.pidrelay-log = /data/3306/relay-binlog-bin = /data/3306/mysql-binslow_query_log relay-log-info-file = /data/3306/relay-log.infobinlog_cache_size = 1Mgeneral_log = ongeneral_log_file = /data/3306/data/MySQL_oldboy.logmax_binlog_cache_size = 1Mmax_binlog_size = 2Mkey_buffer_size = 32Mread_buffer_size = 1Mread_rnd_buffer_size = 1Mbulk_insert_buffer_size = 1Mlower_case_table_names = 1skip-name-resolveslave-skip-errors = 1032,1062replicate-ignore-db=mysqlserver-id = 1innodb_additional_mem_pool_size = 4Minnodb_buffer_pool_size = 32Minnodb_data_file_path = ibdata1:128M:autoextendinnodb_file_io_threads = 4innodb_thread_concurrency = 8innodb_flush_log_at_trx_commit = 2innodb_log_buffer_size = 2Minnodb_log_file_size = 4Minnodb_log_files_in_group = 3innodb_max_dirty_pages_pct = 90innodb_lock_wait_timeout = 120innodb_file_per_table = 0[mysqldump]quickmax_allowed_packet = 2M[mysqld_safe]log-error=/data/3306/mysql.errpid-file=/data/3306/mysqld.pid

vim /data/3307/my.cnf

[client]port = 3307socket = /data/3307/mysql.sock[mysql]no-auto-rehash[mysqld]#binlog_format = "ROW"character-set-server=utf8user = mysqlport = 3307socket = /data/3307/mysql.sockbasedir = /application/mysqldatadir = /data/3307/dataopen_files_limit = 1024back_log = 600max_connections = 800max_connect_errors = 3000table_cache = 614external-locking = FALSEmax_allowed_packet =8Msort_buffer_size = 1Mjoin_buffer_size = 1Mthread_cache_size = 100thread_concurrency = 2query_cache_size = 2Mquery_cache_limit = 1Mquery_cache_min_res_unit = 2k#default_table_type = InnoDBthread_stack = 192K#transaction_isolation = READ-OOMMITTEDtmp_table_size = 2Mmax_heap_table_size = 2Mlong_query_time = 1log-slow-queries = /data/3307/slow.loglog_queries_not_using_indexespid-file = /data/3307/mysql.pidrelay-log = /data/3307/relay-binlog-bin = /data/3307/mysql-binslow_query_log relay-log-info-file = /data/3307/relay-log.infobinlog_cache_size = 1Mgeneral_log = ongeneral_log_file = /data/3307/data/MySQL_oldboy.logmax_binlog_cache_size = 1Mmax_binlog_size = 2Mkey_buffer_size = 32Mread_buffer_size = 1Mread_rnd_buffer_size = 1Mbulk_insert_buffer_size = 1Mlower_case_table_names = 1skip-name-resolveslave-skip-errors = 1032,1062replicate-ignore-db=mysqlserver-id = 3innodb_additional_mem_pool_size = 4Minnodb_buffer_pool_size = 32Minnodb_data_file_path = ibdata1:128M:autoextendinnodb_file_io_threads = 4innodb_thread_concurrency = 8innodb_flush_log_at_trx_commit = 2innodb_log_buffer_size = 2Minnodb_log_file_size = 4Minnodb_log_files_in_group = 3innodb_max_dirty_pages_pct = 90innodb_lock_wait_timeout = 120innodb_file_per_table = 0[mysqldump]quickmax_allowed_packet = 2M[mysqld_safe]log-error=/data/3307/mysql.errpid-file=/data/3307/mysqld.pid

最終完成後的多實例根/data目錄結果如下:

[root@db02 mysql-5.5.32]# tree /data//data|--3306| |-- data| `-- my.cnf#這個就是3306實例的配置文件`--3307 |-- data `-- my.cnf#這個就是3307實例的配置文件4 directories,2 files

有關配置文件的參數說明,可以根據my-innodb-heavy-4G.cnf或查找相關資料,進行完整注釋。

不同的實例需要添加的my.cnf內容會有區別,其中的配置由官方的配置模板修改而來。當然,在實際工作中,我們是拿早已配置好的模板來進行修改的,可以通過rz等方式上傳配置文件模板my.cnf文件到相關目錄下。

創建MySQL多實例的啟動文件

MySQL多實例啟動文件的創建和配置文件的創建幾乎一樣,也可以通過vim命令來添加,如下:

vim /data/3306/mysql

#!/bin/bash##################################################this scripts is created by anonymous at 2017-3-20##################################################initport=3306mysql_user="root"mysql_pwd="oldboy123" #這裡將來要修改為和資料庫密碼一致CmdPath="/application/mysql/bin"mysql_sock="/data/${port}/mysql.sock"#startup functionfunction_start_mysql(){ if [ ! -e "$mysql_sock" ];then printf "Starting MySQL...
" /bin/sh ${CmdPath}/mysqld_safe --defaults-file=/data/${port}/my.cnf 2>&1 >/dev/null & else printf "MySQL is running...
" exit fi }#stop functionfunction_stop_mysql(){ if [ ! -e "$mysql_sock" ];then printf "MySQL is stopped...
" exit else printf "Stoping MySQL...
" ${CmdPath}/mysqladmin -u ${mysql_user} -p${mysql_pwd} -S /data/${port}/mysql.sock shutdown fi}#resrtart functionfunction_restart_mysql(){ printf "Restarting MySQL...
" function_stop_mysql sleep 2 function_start_mysql}case $1 instart) function_start_mysql;;stop) function_stop_mysql;;restart) function_restart_mysql;;*) printf "Usage: /data/${port}/mysql {start|stop|restart}
"esac

vim /data/3307/mysql

#!/bin/bash##################################################this scripts is created by anonymous at 2017-3-20##################################################initport=3307mysql_user="root"mysql_pwd="oldboy456" #這裡將來要修改為和資料庫密碼一致CmdPath="/application/mysql/bin"mysql_sock="/data/${port}/mysql.sock"#startup functionfunction_start_mysql(){ if [ ! -e "$mysql_sock" ];then printf "Starting MySQL...
" /bin/sh ${CmdPath}/mysqld_safe --defaults-file=/data/${port}/my.cnf 2>&1 >/dev/null & else printf "MySQL is running...
" exit fi }#stop functionfunction_stop_mysql(){ if [ ! -e "$mysql_sock" ];then printf "MySQL is stopped...
" exit else printf "Stoping MySQL...
" ${CmdPath}/mysqladmin -u ${mysql_user} -p${mysql_pwd} -S /data/${port}/mysql.sock shutdown fi}#resrtart functionfunction_restart_mysql(){ printf "Restarting MySQL...
" function_stop_mysql sleep 2 function_start_mysql}case $1 instart) function_start_mysql;;stop) function_stop_mysql;;restart) function_restart_mysql;;*) printf "Usage: /data/${port}/mysql {start|stop|restart}
"esac

當然,在實際工作中我們是拿早已配置好的模板來進行修改的,可以通過rz等方式上傳配置文件模板MySQL文件到相關目錄下。

最終完成後的多實例根/data目錄結果如下:

[root@db02 mysql-5.5.32]# tree /data//data|--3306| |-- my.cnf #<==3306實例的配置文件| `-- mysql #<==3306實例的啟動文件`--3307 |-- my.cnf #<==3307實例的配置文件 `-- mysql #<==3307實例的啟動文件2 directories,4 files

配置MySQL多實例的文件許可權

通過下面的命令,授權MySQL多實例所有啟動文件的MySQL可執行,設置700許可權最佳,注意不要755許可權,因為啟動文件里有資料庫管理密碼,會被讀取到。

[root@db02 home]# find /data/ -type f -name "mysql"|xargs chmod +x[root@db02 home]# find /data/ -type f -name "mysql"|xargs ls -l-rwxr-xr-x 1 root root 1300 3月 17 15:40 /data/3306/mysql-rwxr-xr-x 1 root root 1299 3月 17 15:40 /data/3307/mysql

通過下面的命令。授權MySQL用戶和組管理整個多實例的根目錄/data

[root@db02 home]# chown -R mysql.mysql /data[root@db02 home]# find /data/ -name mysql |xargs ls -l-rwxr-xr-x 1 mysql mysql 1300 3月 17 15:40 /data/3306/mysql-rwxr-xr-x 1 mysql mysql 1299 3月 17 15:40 /data/3307/mysql

初始化資料庫就是載入MySQL自身的庫和表

[root@db02 home]# cd /application/mysql/scripts/[root@db02 scripts]# ./mysql_install_db --basedir=/application/mysql/ --datadir=/data/3306/data/ --user=mysql[root@db02 scripts]# ./mysql_install_db --basedir=/application/mysql/ --datadir=/data/3307/data/ --user=mysql#看到有兩個ok 就對了#WARNING: The host db02 could not be looked up with resolveip. 出現這個表示我們的主機名沒做解析。#[root@db02 scripts]# vi /etc/hosts#::1 localhost localhost.localdomain localhost6 localhost6.localdomain6 localhost db02[root@db02 scripts]# ./mysql_install_db --basedir=/application/mysql/ --datadir=/data/3307/data/ --user=mysql

設置環境變數

[root@db02 3307]# cp /application/mysql/bin/* /usr/local/sbin/

需要特別說明一下,在多實例啟動文件中,啟動MySQL不同實例服務,所執行的命令實質是有區別的,例如,

啟動3306實例的命令如下:

mysqld_safe --defaults-file=/data/3306/my.cnf 2>&1 > /dev/null &

啟動3307實例的命令如下:

mysqld_safe --defaults-file=/data/3307/my.cnf 2>&1 > /dev/null &

下面看看在多實例啟動文件中,停止MySQL不同實例服務的實質命令。 停止3306實例的命令如下:

mysqladmin -u root -poldboy123 -S /data/3306/mysql.sock shutdown

停止3307實例的命令如下:

mysqladmin -u root -poldboy456 -S /data/3307/mysql.sock shutdown

多實例的登錄方式需要指定sock的。

[root@db02 3307]# mysql -S /data/3306/mysql.sock #現在可以進到3306啦[root@db02 3307]# mysql -S /data/3307/mysql.sock #現在可以進到3307啦

[root@db02 ~]# mysqladmin -S /data/3306/mysql.sock password oldboy123 [root@db02 ~]# mysqladmin -S /data/3307/mysql.sock password oldboy456

至此 編譯安裝完畢

配置及管理MySQL多實例資料庫

1.配置MySQL多實例資料庫開機自啟動 服務的開機自啟動很關鍵,MySQL多實例的啟動也不例外,把MySQL多實例的啟動命令加入/etc/rc.local,實現開機自啟動,命令如下:

echo "#mysql multi instances" >>/etc/rc.localecho "/data/3306/mysql start" >>/etc/rc.localecho "/data/3307/mysql start" >>/etc/rc.localtail -3 /etc/rc.local

提示:要確保MySQL腳本可執行呦!

(END)

Keegv| 陳寶佳 作品採用知識共享署名-非商業性使用-禁止演繹 3.0 未本地化版本許可協議進行許可。


推薦閱讀:

mysql已經有cache了,為啥還要在它前面加一層memcached?
為什麼MySQL在innodb引擎中即使使用了MVCC機制仍然會出現丟失更新?
MySQL複製拓撲
MySQL訓練——SELECT in SELECT@sqlzoo.net
MySQL訓練——JOIN@sqlzoo.net

TAG:MySQL | 運維 | 架構 |