mysql搭建多個例項(mysqld_multi的使用)
在Mysql中有一mysqld_multi命令,可用於在一臺物理伺服器執行多個Mysql服務。
作業系統: Redhat Enterprise AS 3-U8
資料庫 : Mysql 5.0.40
規劃:在一個 Mysql 上執行2個例項,執行埠分別是3306,3307。
一.在LINUX 系統下安裝Mysql5:
安裝mysql資料庫。(採用原始碼安裝)
shell> groupadd mysql
shell> useradd -g mysql mysql
shell> tar zxvf mysql-5.0.40.tar.gz
shell> cd mysql-5.0.40
shell> ./configure --prefix=/usr/local/mysql --sysconfdir=/etc
shell> make
shell> make install
shell> cp support-files/my-medium.cnf /etc/my.cnf ----修改相應的引數
shell> cd /usr/local/mysql
shell> chown -R mysql:mysql mysql
shell> bin/mysql_install_db --user=mysql ----安裝初始資料庫
shell> chown -R root mysql
shell> chown -R mysql :mysql var
shell> bin/mysqld_safe --user=mysql & -------開啟mysqld服務
二到此可以先測試一下單個資料庫例項有沒有安裝成功
二.配置mysqld2.
我們在一臺伺服器上執行多個mysql的例項時,如果安裝的是同一個版本的mysql,不用安裝多次,只安裝一次就可以了。主要區別的是資料存放的位置,可以把已經安裝好的mysql資料庫存放資料的檔案複製幾份就可以,同時要修改其許可權。如下:
[mysqld1]是一個預設的,在我們安裝mysql時已經有了,所以不用管它.
[mysqld2],只要根據配置就的路徑為它建立一個目錄就可以了.將把該目錄改為mysql 管理 權
[root@mysql mysql]#cd /usr/local/mysql
[root@mysql mysql]#cp –R var var1
[root@mysql mysql]#chown mysql:mysql var1
三.mysqld_multi 介紹:
根據Mysql管理手冊中提到:每個Mysql的服務都可為獨立的,所以它都呼叫一個my.cnf中各自不同的啟動選項--就是下文中將提到的GNR值,使用不同的埠,生成各自的套接檔案,服務的資料庫都是獨立的(更多可查閱mysql官方網站的英文管理手冊).
mysqld_multi是管理多個mysqld的服務程式,這些服務程式程式不同的unix socket或是監聽於不同的埠。他可以啟動、停止和監控當前的服務狀態。
程式在my.cnf(或是在--config-file自定義的配置檔案)中搜尋[mysqld#]段,"#"可以是任意的正整數。這個正整數就是在下面提及的段序列,即GNR。段的序號做為mysqld_multi的引數,來區別不同的段,這樣你就可以控制特定mysqld程式的啟動、停止或得到他的報告資訊。這些組裡的引數就像啟動一個mysqld所需要的組的引數一樣。但是,如果使用多服務,必須為每個服務指定一個unix socket或埠
配置/etc/my.cnf(具體配置如下)
[mysqld_multi]
mysqld = /usr/local/mysql/bin/mysqld_safe
mysqladmin = /usr/local/mysql/bin/mysqladmin
user = guzh
password = mysql
[mysqld1]
port = 3306
socket = /tmp/mysql.sock
pid-file = /usr/local/mysql/var/mysql.pid
datadir = /usr/local/mysql/var
skip-locking
key_buffer = 16M
max_allowed_packet = 1M
table_cache = 64
sort_buffer_size = 512K
net_buffer_length = 8K
read_buffer_size = 256K
read_rnd_buffer_size = 512K
myisam_sort_buffer_size = 8M
[mysqld2]
port = 3307
socket = /tmp/mysql2.sock
pid-file = /usr/local/mysql/var1/mysql2.pid
datadir = /usr/local/mysql/var1
skip-locking
key_buffer = 16M
max_allowed_packet = 1M
table_cache = 64
sort_buffer_size = 512K
net_buffer_length = 8K
read_buffer_size = 256K
read_rnd_buffer_size = 512K
myisam_sort_buffer_size = 8M
從以上配置可以看出,我的配置檔案中有mysqld1,mysqld2兩個例項。就是說我將啟動2個mysql服務在同一伺服器的不同埠--3306和3307,每個datadir所指定的資料庫檔案路徑都是不相同的
四、利用 Mysqld_multi 啟動/停止 多例項 Mysql
說明:
使用如下引數來啟動mysqld_multi: (注:該命令在mysql的bin目錄中,根據上面所提到./configure --prefix=/usr/local/mysql ,所以該檔案應該在 /usr/local/mysq/bin, 這得根據你安裝時所指定的路徑 )
db-app:/ # mysqld_multi [options] {start|stop|report} [GNR[,GNR]...]
start,stop和report是指你想到執行的操作。你可以在單獨的服務或是多服務上指定一個操作,區別於選項後面的GNR列表。如果沒有指定GNR列表,那麼mysqld_multi將在所有的服務中根據選項檔案進行操作。
每一個GNR的值是組的序列號或是一個組的序列號範圍。此項的值必須是組名字最後的數字,比如說如果組名為mysqld17,那麼此項的值則為17.如果指定一個範圍,使用"-"(破折號)來連線二個數字。如GNR的值為10-13,則指組mysqld10到組mysqld13。多個組或是組範圍可以在命令列中指定,使用","(逗號)隔開。不能有空白的字元(如空格或tab),在空白字元後面的引數將會被忽略。 (注:GNR值就是我們定義my.cnf中mysqld#中的值,我這裡只有1-2)
啟動 mysql
[root@mysql bin]#/usr/local/mysql/bin/musqld_multi start 1-2
停止 mysql
[root@mysql/usr/local/mysql/bin/mysqld_multi stop 1-2
[mysql@gc1:/var/lib/mysql]$ mysqladmin -uroot -pmysql -P3306 -h127.0.0.1 shutdown
[mysql@gc1:/var/lib/mysql]$ mysqladmin -uroot -pmysql -P3307 -h127.0.0.1 shutdown
檢視 mysql
[root@mysql/usr/local/mysql/bin/mysqld_multi report 1-2
五.啟動資料庫,然後對使用者進行授權。
用一個帳號來啟動所有的mysql伺服器,因為是用一相同的帳號。那個麼這帳號必須都是每個mysql服務都要用的帳號,最好是管理帳號,下面的口令相同
guzh是mysql下的使用者,非linux下的使用者
#這個mysql要透過 root 給它賦許可權,讓它具有shutdown 和start mysql 的許可權
#grant shutdown on *.* to 'guzh' IDENTIFIED BY 'mysql'
[root@gc1 var]# mysql -p -uroot -P3306 -S /tmp/mysql.sock
mysql> GRANT SHUTDOWN ON *.* to 'guzh'@'localhost' identified by 'mysql';
注:兩個例項都要做相同的操作。
六、客戶端訪問
說明:
任何客戶端訪問都需要指定訪問埠。方才能進入指定資料庫服務.否則將使用到Mysql預設的埠(3306)所服務的MYSQL,如:
[root@mysql bin]#/usr/local/mysql/bin/mysql -uguzh -pmysql -P3306 -h127.0.0.1
[root@mysqlbin]#/usr/local/mysql/bin/mysql -uguzh -pmysql -P3307 -h127.0.0.1
用sock也可以連線上去 但是一般不用
mysql -u root -p -P3306 -h127.0.0.1
mysql> show variables like 'datadir';
+---------------+-----------------------+
| Variable_name | Value |
+---------------+-----------------------+
| datadir | /usr/local/mysql/var/ |
+---------------+-----------------------+
mysql -u root -p -P3307 -h127.0.0.1
mysql> show variables like 'datadir';
+---------------+------------------------+
| Variable_name | Value |
+---------------+------------------------+
| datadir | /usr/local/mysql/var1/ |
+---------------+------------------------+
mysql -u root -p -P3306 -S /tmp/mysql.sock
mysql> show variables like 'datadir';
+---------------+-----------------------+
| Variable_name | Value |
+---------------+-----------------------+
| datadir | /usr/local/mysql/var/ |
+---------------+-----------------------+
mysql -u root -p -P3307 -S /tmp/mysql2.sock
mysql> show variables like 'datadir';
+---------------+------------------------+
| Variable_name | Value |
+---------------+------------------------+
| datadir | /usr/local/mysql/var1/ |
+---------------+------------------------+
七、常見問題:
a、/usr/bin/mysqld_multi 的啟動錯誤
|
b、啟動 Mysql 客戶端,老報 /var/lib/mysql/temp.sock 的錯誤
|
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29096438/viewspace-1409177/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- mysqld_multi安裝多個mysql例項MySql
- mysqld_multi啟動多個mysql例項MySql
- 使用mysqld_multi實現單系統中配置多個MySQL伺服器例項MySql伺服器
- mysqld_multi搭建MySQL單機多例項服務MySql
- mysql使用mysqld_multi工具啟動多例項MySql
- MySQL入門--Mysqld_multi多例項MySql
- 基於mysqld_multi實現MySQL 5.7.24多例項多程式配置MySql
- Linux中執行多個MySQL例項LinuxMySql
- 在Windows中執行多個MySQL例項WindowsMySql
- MySQL在Windows上安裝多個例項的方法MySqlWindows
- MySQL 使用mysqld_multi部署單機多例項詳細過程MySql
- 一臺MySQL資料庫啟動多個例項MySql資料庫
- docker redis 多個例項DockerRedis
- MySQL多例項使用mysqld_multi stop 無法關閉資料庫MySql資料庫
- 多個mapreduce連線例項
- 一個例項中,多個synchronized方法的呼叫synchronized
- mysql系列之多例項3—-基於mysqld_multi薦MySql
- oracle一個例項配置多個listener或多個埠Oracle
- oracle 多個例項監聽不到Oracle
- oracle多個例項啟動方法Oracle
- oracle一個listener偵聽多個例項的配置Oracle
- 使用 Docker Compose 搭建 MySQL 資料庫主從複製例項DockerMySql資料庫
- Tee命令的幾個使用例項
- oracle一個別例項配置多個listener或多個埠Oracle
- java多型-優化上個例項Java多型優化
- oracle 多個例項安裝監聽Oracle
- JDBC連線自定義sqlserver資料庫例項名(多個例項)JDBCSQLServer資料庫
- 當多個UITextView使用同一個UIView例項出現凍屏現象UITextView
- MySQL共享鎖:使用與例項詳解MySql
- 如何在多例項基礎上再新增一個mysql的例項MySql
- 分享一個Laravel中的管道的使用例項Laravel
- java多型例項Java多型
- 【Hibernate】—Hibernate+mysql 環境搭建+入門例項MySql
- oracle:一臺主機多個例項,sqlplus 預設連線到哪個例項的問題OracleSQL
- TenSunS監控Mysql:如何優雅的使用一個mysqld_exporter監控所有的MySQL例項MySqlExport
- flex的使用例項Flex
- MySQL 優化例項MySql優化
- 利用mysqld_multi配置單機多例項MySql