在Windows中執行多個MySQL例項
在Windows中可以從命令列為每個例項使用合適的操作引數來手動啟動多個MySQL例項或者透過以Windows服務方式來安裝多個伺服器來執行。
1.在windows中MySQL的base目錄中建立兩個新例項的資料目錄data3307,data3308
2.為每個新例項設定配置檔案來指定相關選項
my3307.cnf檔案內容如下:
[mysql] # 設定mysql客戶端預設字符集 default-character-set=utf8mb4 [mysqld] # 設定3307埠 port = 3307 # 設定mysql的安裝目錄 basedir=D:\mysql-5.7.25-win32 # 設定 mysql資料庫的資料的存放目錄,MySQL 8+ 不需要以下配置,系統自己生成即可,否則有可能報錯 datadir=D:\mysql-5.7.25-win32\data3307 # 允許最大連線數 max_connections=200 # 服務端使用的字符集預設為8位元編碼的latin1字符集 character-set-server=utf8mb4 # 建立新表時將使用的預設儲存引擎 default-storage-engine=INNODB explicit_defaults_for_timestamp=true log-error=D:\mysql-5.7.25-win32\mysql3307.err pid-file=D:\mysql-5.7.25-win32\mysqld3307.pid socket =D:\mysql-5.7.25-win32\mysql3307.sock
my3308.cnf檔案內容如下:
[mysql] # 設定mysql客戶端預設字符集 default-character-set=utf8mb4 [mysqld] # 設定3308埠 port = 3308 # 設定mysql的安裝目錄 basedir=D:\mysql-5.7.25-win32 # 設定 mysql資料庫的資料的存放目錄,MySQL 8+ 不需要以下配置,系統自己生成即可,否則有可能報錯 datadir=D:\mysql-5.7.25-win32\data3308 # 允許最大連線數 max_connections=200 # 服務端使用的字符集預設為8位元編碼的latin1字符集 character-set-server=utf8mb4 # 建立新表時將使用的預設儲存引擎 default-storage-engine=INNODB explicit_defaults_for_timestamp=true log-error=D:\mysql-5.7.25-win32\mysql3308.err pid-file=D:\mysql-5.7.25-win32\mysqld3308.pid socket =D:\mysql-5.7.25-win32\mysql3308.sock
3.初始化新資料庫
D:\mysql-5.7.25-win32\bin>mysqld --defaults-file=D:\mysql-5.7.25-win32\my3307.cnf --initialize --basedir=D:\mysql-5.7.25-win32 --datadir=D:\mysql-5.7.25-win32\data3307 D:\mysql-5.7.25-win32\bin>mysqld --defaults-file=D:\mysql-5.7.25-win32\my3308.cnf --initialize --basedir=D:\mysql-5.7.25-win32 --datadir=D:\mysql-5.7.25-win32\data3308
4.啟動資料庫
D:\mysql-5.7.25-win32\bin>mysqld --defaults-file=D:\mysql-5.7.25-win32\my3307.cnf D:\mysql-5.7.25-win32\bin>mysqld --defaults-file=D:\mysql-5.7.25-win32\my3308.cnf
每個伺服器都在前臺啟動(在伺服器稍後退出之前不會出現新的提示),所以您需要在單獨的控制檯視窗中發出這兩個命令。
5.登入資料庫修改密碼
C:\Users\Administrator>mysql --port=3307 --host=127.0.0.1 --user=root --password=U0U?KinrdWHb mysql: [Warning] Using a password on the command line interface can be insecure. Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 6 Server version: 5.7.25 Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '123456'; Query OK, 0 rows affected (0.00 sec) mysql> exit Bye C:\Users\Administrator>mysql --port=3307 --host=127.0.0.1 --user=root --password=123456 mysql: [Warning] Using a password on the command line interface can be insecure. Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 7 Server version: 5.7.25 Source distribution Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> exit C:\Users\Administrator>mysql --port=3308 --host=127.0.0.1 --user=root Enter password: ************ Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 8 Server version: 5.7.25 Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '123456'; Query OK, 0 rows affected (0.00 sec) mysql> exit Bye C:\Users\Administrator>mysql --port=3308 --host=127.0.0.1 --user=root --password=123456 mysql: [Warning] Using a password on the command line interface can be insecure. Welcome to the MySQL monitor. Commands end with ; or \g. Your MySQL connection id is 9 Server version: 5.7.25 Source distribution Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its affiliates. Other names may be trademarks of their respective owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql>
6.為了關閉資料庫伺服器,使用合適的埠號連線到每個例項執行下面的命令:
C:\Users\Administrator>mysqladmin --port=3307 --host=127.0.0.1 --user=root --password=123456 shutdown mysqladmin: [Warning] Using a password on the command line interface can be insecure. C:\Users\Administrator>mysqladmin --port=3308 --host=127.0.0.1 --user=root --password=123456 shutdown mysqladmin: [Warning] Using a password on the command line interface can be insecure.
上面的配置允許客戶端透過TCP/IP來進行連線。如果你的Windows版本支援命名管道並且你也想使用命名管道來連線,指定啟用命名管道選項和指定它的名稱。每個例項支援命名管道連線必須使用一個唯一的管道名。例如:
my3307.cnf檔案內容如下:
[mysql] # 設定mysql客戶端預設字符集 default-character-set=utf8mb4 [mysqld] # 設定3307埠 port = 3307 # 設定mysql的安裝目錄 basedir=D:\mysql-5.7.25-win32 # 設定 mysql資料庫的資料的存放目錄,MySQL 8+ 不需要以下配置,系統自己生成即可,否則有可能報錯 datadir=D:\mysql-5.7.25-win32\data3307 # 允許最大連線數 max_connections=200 # 服務端使用的字符集預設為8位元編碼的latin1字符集 character-set-server=utf8mb4 # 建立新表時將使用的預設儲存引擎 default-storage-engine=INNODB explicit_defaults_for_timestamp=true log-error=D:\mysql-5.7.25-win32\mysql3307.err pid-file=D:\mysql-5.7.25-win32\mysqld3307.pid enable-named-pipe socket =D:\mysql-5.7.25-win32\mysql3307.sock
my3308.cnf檔案內容如下:
[mysql] # 設定mysql客戶端預設字符集 default-character-set=utf8mb4 [mysqld] # 設定3308埠 port = 3308 # 設定mysql的安裝目錄 basedir=D:\mysql-5.7.25-win32 # 設定 mysql資料庫的資料的存放目錄,MySQL 8+ 不需要以下配置,系統自己生成即可,否則有可能報錯 datadir=D:\mysql-5.7.25-win32\data3308 # 允許最大連線數 max_connections=200 # 服務端使用的字符集預設為8位元編碼的latin1字符集 character-set-server=utf8mb4 # 建立新表時將使用的預設儲存引擎 default-storage-engine=INNODB explicit_defaults_for_timestamp=true log-error=D:\mysql-5.7.25-win32\mysql3308.err pid-file=D:\mysql-5.7.25-win32\mysqld3308.pid socket =D:\mysql-5.7.25-win32\mysql3308.sock
然後啟動MySQL例項。想讓客戶端透過共享記憶體連線的過程與上面的過程類似。對每個連線使用--shared-memory選項並使用--shared-memory-base-name選項來為每個例項指定唯一的共享記憶體名字。
在Windows中作為Windows服務來啟動多個MySQL例項
在Windows中,一個MySQL伺服器可以以Windows服務來執行。為了設定多個MySQL服務,你必須確保每個例項使用不同的服務名另外其它引數每個例項必須都有唯一值。為了將MySQL伺服器註冊成為Windows服務,使用mysqld --install或mysqld --install-manual選項。
基於上面的資訊,有幾種方式來設定多個Windows服務。在註冊Windows服務之前需要關閉並刪除任何已經存在的Windows服務。
方法1
在一個標準的選項檔案中指定所有服務選項。這樣就需要為每個MySQL服務指定不同的服務名。假設埠為3307的MySQL例項的服務名為mysqld1,埠為3308的MySQL例項的服務名為mysqld2。那麼D:\mysql-5.7.25-win32\my.ini設定如下:
[mysqld1] # 設定3307埠 port = 3307 # 設定mysql的安裝目錄 basedir=D:\mysql-5.7.25-win32 # 設定 mysql資料庫的資料的存放目錄,MySQL 8+ 不需要以下配置,系統自己生成即可,否則有可能報錯 datadir=D:\mysql-5.7.25-win32\data3307 # 允許最大連線數 max_connections=200 # 服務端使用的字符集預設為8位元編碼的latin1字符集 character-set-server=utf8mb4 # 建立新表時將使用的預設儲存引擎 default-storage-engine=INNODB explicit_defaults_for_timestamp=true log-error=D:\mysql-5.7.25-win32\mysql3307.err pid-file=D:\mysql-5.7.25-win32\mysqld3307.pid socket =D:\mysql-5.7.25-win32\mysql3307.sock [mysqld2] # 設定3308埠 port = 3308 # 設定mysql的安裝目錄 basedir=D:\mysql-5.7.25-win32 # 設定 mysql資料庫的資料的存放目錄,MySQL 8+ 不需要以下配置,系統自己生成即可,否則有可能報錯 datadir=D:\mysql-5.7.25-win32\data3308 # 允許最大連線數 max_connections=200 # 服務端使用的字符集預設為8位元編碼的latin1字符集 character-set-server=utf8mb4 # 建立新表時將使用的預設儲存引擎 default-storage-engine=INNODB explicit_defaults_for_timestamp=true log-error=D:\mysql-5.7.25-win32\mysql3308.err pid-file=D:\mysql-5.7.25-win32\mysqld3308.pid socket =D:\mysql-5.7.25-win32\mysql3308.sock
註冊服務,使用完整服務路徑名來確保Windows為每個服務註冊正確的可執行程式:
D:\mysql-5.7.25-win32\bin>mysqld --install mysqld1 Service successfully installed. D:\mysql-5.7.25-win32\bin>mysqld --install mysqld2 Service successfully installed.
為了啟動MySQL服務,使用服務管理器或者使用net start servicename:
C:\Users\Administrator>net start mysqld1 mysqld1 服務正在啟動 . mysqld1 服務已經啟動成功。 C:\Users\Administrator>net start mysqld2 mysqld2 服務正在啟動 . mysqld2 服務已經啟動成功。 為了停止MySQL服務,使用服務管理器或者使用net stop servicename: C:\Users\Administrator>net stop mysqld1 mysqld1 服務正在停止. mysqld1 服務已成功停止。 C:\Users\Administrator>net stop mysqld2 mysqld2 服務正在停止. mysqld2 服務已成功停止。
刪除服務
D:\mysql-5.7.25-win32\bin>mysqld --remove mysqld1 Service successfully removed. D:\mysql-5.7.25-win32\bin>mysqld --remove mysqld2 Service successfully removed.
方法2
為每個MySQL服務使用單獨的檔案來指定選項並且在註冊服務時使用--defaults-file選項來告訴每個伺服器所要使用的選項檔案。在這種情況下,每個檔案都將使用[mysqld]選項組。
my3307.cnf檔案內容如下:
[mysql] # 設定mysql客戶端預設字符集 default-character-set=utf8mb4 [mysqld] # 設定3307埠 port = 3307 # 設定mysql的安裝目錄 basedir=D:\mysql-5.7.25-win32 # 設定 mysql資料庫的資料的存放目錄,MySQL 8+ 不需要以下配置,系統自己生成即可,否則有可能報錯 datadir=D:\mysql-5.7.25-win32\data3307 # 允許最大連線數 max_connections=200 # 服務端使用的字符集預設為8位元編碼的latin1字符集 character-set-server=utf8mb4 # 建立新表時將使用的預設儲存引擎 default-storage-engine=INNODB explicit_defaults_for_timestamp=true log-error=D:\mysql-5.7.25-win32\mysql3307.err pid-file=D:\mysql-5.7.25-win32\mysqld3307.pid enable-named-pipe socket =D:\mysql-5.7.25-win32\mysql3307.sock
my3308.cnf檔案內容如下:
[mysql] # 設定mysql客戶端預設字符集 default-character-set=utf8mb4 [mysqld] # 設定3308埠 port = 3308 # 設定mysql的安裝目錄 basedir=D:\mysql-5.7.25-win32 # 設定 mysql資料庫的資料的存放目錄,MySQL 8+ 不需要以下配置,系統自己生成即可,否則有可能報錯 datadir=D:\mysql-5.7.25-win32\data3308 # 允許最大連線數 max_connections=200 # 服務端使用的字符集預設為8位元編碼的latin1字符集 character-set-server=utf8mb4 # 建立新表時將使用的預設儲存引擎 default-storage-engine=INNODB explicit_defaults_for_timestamp=true log-error=D:\mysql-5.7.25-win32\mysql3308.err pid-file=D:\mysql-5.7.25-win32\mysqld3308.pid socket =D:\mysql-5.7.25-win32\mysql3308.sock
將每個MySQL例項註冊成Windows服務
D:\mysql-5.7.25-win32\bin>mysqld --install mysqld1 --defaults-file=D:\mysql-5.7.25-win32\my3307.cnf Service successfully installed. D:\mysql-5.7.25-win32\bin>mysqld --install mysqld2 --defaults-file=D:\mysql-5.7.25-win32\my3308.cnf Service successfully installed.
啟動服務
C:\Users\Administrator>net start mysqld1 mysqld1 服務正在啟動 . mysqld1 服務已經啟動成功。 C:\Users\Administrator>net start mysqld2 mysqld2 服務正在啟動 . mysqld2 服務已經啟動成功。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/26015009/viewspace-2661918/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- Linux中執行多個MySQL例項LinuxMySql
- Qt中的多執行緒與執行緒池淺析+例項QT執行緒
- 在同一臺計算機中執行多個MySQL服務計算機MySql
- 一個例項中,多個synchronized方法的呼叫synchronized
- docker redis 多個例項DockerRedis
- windows 系統下 workerman 在同一個執行視窗中開啟多個 websocket 服務WindowsWeb
- Activiti的流程例項【ProcessInstance】與執行例項【Execution】
- 【多執行緒與高併發3】常用鎖例項執行緒
- 使用 Terminator 在一個視窗中執行多個終端
- pytest(13)-多執行緒、多程式執行用例執行緒
- Thread 併發執行例項thread
- 在Docker中,可以在一個容器中同時執行多個應用程序嗎?Docker
- 掌握C#中的GUI多執行緒技巧:WinForms和WPF例項詳解C#GUI執行緒ORM
- 在 React 中管理同一元件的多個例項中的狀態React元件
- 使用Portainer集中管理多地域內網執行的Docker例項AI內網Docker
- 多執行緒併發鎖分類以及簡單例項執行緒單例
- pytest多程式/多執行緒執行測試用例執行緒
- 使用mysqld_multi實現單系統中配置多個MySQL伺服器例項MySql伺服器
- Java中一個物件在多執行緒中是共享的Java物件執行緒
- selenium-grid 有多個節點,但 pytest.main 批次執行用例,每次只有一個節點執行用例,不能同時多個節點執行,要怎樣才能多個節點同時執行AI
- java在windows下執行JavaWindows
- mysql一次執行多個SQL檔案MySql
- docker 執行elasticsearch單例項(elasticsearch:7.12.0)DockerElasticsearch單例
- 在 Windows 中執行 Linux:WSL 2 使用入門WindowsLinux
- 在 Windows 中執行 Linux 命令的 4 種方法WindowsLinux
- 【懷舊】在 64 位 Windows 中執行 16 位 Windows/DOS 程式Windows
- Windows Subsystem for Linux 允許在Windows 11中執行Linux系統WindowsLinux
- 好奇: windows10+都可以執行多個linux子系統了,為什麼不支援執行多個windows子系統呢?WindowsLinux
- 避免DbContext同時在多個執行緒呼叫Context執行緒
- 在windows的IDEA執行PrestoWindowsIdeaREST
- 一看就懂的python小程式-支援多執行緒聊天例項Python執行緒
- C#並行,多執行緒程式設計並行集合和PLINQ的例項講解並行執行緒程式設計
- 唯一標識 Java 執行的例項Java
- 執行caffe自帶的mnist例項教程
- NCF的Dapr應用例項的執行
- Python程式和執行緒例項詳解Python執行緒
- 如何區分例項化網格中的每個例項
- oracle一個listener偵聽多個例項的配置Oracle