目次
前言
一、下载集群版mysql
二、配置MySQL集群
1、首先将下载压缩包解压到每台电脑的C:/mysql目录下:
2、配置管理节点
3、配置数据节点" >3、配置数据节点
三、启动MySQL集群" >三、启动MySQL集群
1、启动管理节点:" >1、启动管理节点:
2、启动每个数据节点:" >2、启动每个数据节点:
3、启动每个sql节点:" >3、启动每个sql节点:
4、查看每个节点的状态:" >4、查看每个节点的状态:
三、测试MySQL集群" >三、测试MySQL集群
1、在sql节点A建立数据库并插入数据:" >1、在sql节点A建立数据库并插入数据:
2、在sql节点B也可以查询到数据。" >2、在sql节点B也可以查询到数据。
ホームページ データベース mysql チュートリアル 在Windows环境下配置MySQL集群_MySQL

在Windows环境下配置MySQL集群_MySQL

Jun 02, 2016 am 08:49 AM
環境 集まる

前言


最近在项目中用到了MySQL集群,所以就和小伙伴们研究了两天。下面给大家分享一下成果。

小编始终觉得对新事物的学习,没有比看图这种方式更好地理解了。所以先来看一张mysql集群的架构图(摘自百度百科-MySQL Cluster):

这里写图片描述

上图一共分了四层:Applications、SQL、Storage、Management。
如果您的英语不是体育老师教的的话,那么您肯定已经猜出来每一层的职责了:

—–Applications主要是指需要连接数据库的应用程序;
—–SQL中每一个mysqld都是一个sql节点,Applications需要通过连接sql节点来存储数据,您可以把它看成应用程序与数据库集群进行数据交换的大门
—–Storage有‘仓库’的意思,所以数据都是存在数据节点(ndbd)中的,而且每个数据节点的数据都是一致的,都是一整套最新的数据
—–Management中就是管理节点,一个MySQL中只有一个管理节点,用来管理其他节点

综上所述,一个MySQL集群中包括三种节点(不包括Applications):管理节点、数据节点,sql节点。


一、下载集群版mysql

下载mysql-cluster-gpl-7.4.7-win32或mysql-cluster-gpl-7.4.7-winx64

下载地址:http://yunpan.cn/cd892RtysQ3Vk (提取码:45c8)
MySQL官网下载地址:http://dev.mysql.com/downloads/cluster/


二、配置MySQL集群

需要用三台机器(没有条件的朋友可以考虑用虚拟机),一台配置管理节点:另外两台每台配置一个数据节点和一个SQL节点(也可以用五台计算机,每台计算机配置一个节点):
管理节点:192.168.25.50
数据节点A:192.168.25.49
数据节点B:192.168.25.48
SQL节点A:192.168.25.49
SQL节点B:192.168.25.48

1、首先将下载压缩包解压到每台电脑的C:/mysql目录下:

这里写图片描述

当然放在其他盘的目录里也可以。

2、配置管理节点

在配置管理节点(192.168.25.50)的计算机上的C:\Mysql\Bin目录下建立cluster-logs和config两个文件夹。cluster-logs用来存储日志文件,在config文件夹中建立my.ini和config.ini两个配置文件:

my.ini

<code class="hljs ruby">[mysql_cluster] 
# Options for management node process 
config-file=C:/mysql/bin/config/config.ini</code>
ログイン後にコピー

config.ini

<code class="hljs ruby"><code class="hljs ruby">[ndbd default] 
# Options affecting ndbd processes on all data nodes: 
NoOfReplicas=2                      # Number of replicas 
DataDir=C:/mysql/bin/cluster-data   # Directory for each data node&#39;s data files 
                                    # Forward slashes used in directory path, 
                                    # rather than backslashes. This is correct; 
                                    # see Important note in text 

DataMemory=80M                      # Memory allocated to data storage 
IndexMemory=18M                     # Memory allocated to index storage 
                                    # For DataMemory and IndexMemory, we have used the 
                                    # default values. Since the "world" database takes up 
                                    # only about 500KB, this should be more than enough for 
                                    # this example Cluster setup.

[ndb_mgmd] 
# Management process options: 
HostName=192.168.25.50              # Hostname or IP address of management node 
DataDir=C:/mysql/bin/cluster-logs   # Directory for management node log files

[ndbd] 
# Options for data node "A":     
HostName=192.168.25.49              # Hostname or IP address

[ndbd] 
# Options for data node "B":
HostName=192.168.25.48              # Hostname or IP address

[mysqld] 
# SQL node A options:
HostName=192.168.25.49              # Hostname or IP address

[mysqld] 
# SQL node B options:
HostName=192.168.25.48              # Hostname or IP address</code></code>
ログイン後にコピー

<code class="hljs ruby">3、配置数据节点

<code class="hljs ruby">在配置数据节点(192.168.25.48、192.168.25.49)的计算机上的C:\Mysql\Bin目录下建立cluster-data文件夹,用来存放数据:

<code class="hljs ruby">SQL节点不用任何配置,至此,整个MySQL集群就搭建完成了。

<code class="hljs ruby">三、启动MySQL集群


<code class="hljs ruby">启动MySQL集群时,有一个启动顺序:先启动管理节点,再启动数据节点,再启动sql节点。

<code class="hljs ruby">1、启动管理节点:

<code class="hljs ruby">在cmd中运行如下命令

<code class="hljs ruby"><code class="hljs ruby"><code class="hljs tex">c:\mysql\bin\ndb_mgmd.exe --configdir=c:\mysql\bin\config --config-file=c:\mysql\bin\config\config.ini --ndb-nodeid=1 --reload &ndash;initial</code></code></code>
ログイン後にコピー

<code class="hljs ruby"><code class="hljs tex"><img src="/static/imghw/default1.png" data-src="http://img.bitscn.com/upimg/allimg/c150828/1440K00Q50-3M20.jpg" class="lazy" alt="这里写图片描述" title="\" />

<code class="hljs ruby"><code class="hljs tex">2、启动每个数据节点:

<code class="hljs ruby"><code class="hljs tex">在cmd中运行如下命令:

<code class="hljs ruby"><code class="hljs ruby"><code class="hljs tex"><code class="hljs tex">c:\mysql\bin\ndbd.exe --ndb-connectstring=192.168.25.50</code></code></code></code>
ログイン後にコピー

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><img src="/static/imghw/default1.png" data-src="http://img.bitscn.com/upimg/allimg/c150828/1440K00QF310-4B34.jpg" class="lazy" alt="这里写图片描述" title="\" />

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex">3、启动每个sql节点:

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex">在cmd中运行如下命令:

<code class="hljs ruby"><code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck">c:\mysql\bin\mysqld.exe --ndbcluster --ndb-connectstring=192.168.25.50 --console</code></code></code></code></code>
ログイン後にコピー

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><img src="/static/imghw/default1.png" data-src="http://img.bitscn.com/upimg/allimg/c150828/1440K00Q921Z-55413.jpg" class="lazy" alt="这里写图片描述" title="\" />

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck">现在整个MySQL集群就已经启动了。

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck">4、查看每个节点的状态:

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck">在管理节点所在计算机上(192.168.25.50)打开ndb_mgm.exe,或者直接在cmd中运行

<code class="hljs ruby"><code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex">c:\mysql\bin\ndb_mgm</code></code></code></code></code></code>
ログイン後にコピー

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex">执行&ldquo;show&rdquo;命令,可以查看到每个节点的连接状态:

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex"><img src="/static/imghw/default1.png" data-src="http://img.bitscn.com/upimg/allimg/c150828/1440K00R15620-A262.jpg" class="lazy" alt="这里写图片描述" title="\" />

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex">这就表明每个节点均连接正常。下面测试数据。

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex">三、测试MySQL集群


<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex">1、在sql节点A建立数据库并插入数据:

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex">在sql节点A的计算机上(192.168.25.49)的cmd中运行C:\mysql\bin\mysql.exe -u root -p命令登录mysql,接下来需要输入密码时,密码默认为空(直接回车)。

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex">创建数据库并插入数据:<br /> &mdash;&ndash;创建名为&rdquo;MySQL_Cluster_Test&rdquo;的数据库:

<code class="hljs ruby"><code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex"><code class="hljs sql"> create database MySQL_Cluster_Test;</code></code></code></code></code></code></code>
ログイン後にコピー

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex"><code class="hljs sql">&mdash;&ndash;创建表&rdquo;T_User&rdquo;:

<code class="hljs ruby"><code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex"><code class="hljs sql"><code class="hljs sql">use MySQL_Cluster_Test;
create table T_User(Name varchar(32),Age int) engine=ndbcluster;</code></code></code></code></code></code></code></code>
ログイン後にコピー

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex"><code class="hljs sql"><code class="hljs sql">注意建表语句后面一定要加上 engine=ndbcluster

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex"><code class="hljs sql"><code class="hljs sql">&mdash;&ndash;插入数据:

<code class="hljs ruby"><code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex"><code class="hljs sql"><code class="hljs sql"><code class="hljs sql">insert into T_User values(&#39;DannyHoo&#39;,26);</code></code></code></code></code></code></code></code></code>
ログイン後にコピー

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex"><code class="hljs sql"><code class="hljs sql"><code class="hljs sql">&mdash;&ndash;查询数据:

<code class="hljs ruby"><code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex"><code class="hljs sql"><code class="hljs sql"><code class="hljs sql"><code class="hljs sql">select * from T_User;</code></code></code></code></code></code></code></code></code></code>
ログイン後にコピー

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex"><code class="hljs sql"><code class="hljs sql"><code class="hljs sql"><code class="hljs sql"><img src="/static/imghw/default1.png" data-src="http://img.bitscn.com/upimg/allimg/c150828/1440K00R32Q0-L038.jpg" class="lazy" alt="这里写图片描述" title="\">

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex"><code class="hljs sql"><code class="hljs sql"><code class="hljs sql"><code class="hljs sql">2、在sql节点B也可以查询到数据。

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex"><code class="hljs sql"><code class="hljs sql"><code class="hljs sql"><code class="hljs sql">同样在sql节点B的计算机上(192.168.25.48)的cmd中运行C:\mysql\bin\mysql.exe -u root -p命令登录mysql。

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex"><code class="hljs sql"><code class="hljs sql"><code class="hljs sql"><code class="hljs sql">执行 show databases; 命令可以查看到在sql节点A新建的数据库;<br> 执行use MySQL_Cluster_Test;<br>     select * from T_User;<br> 可以查询到在sql节点A插入的数据。

<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex"><code class="hljs sql"><code class="hljs sql"><code class="hljs sql"><code class="hljs sql"><img src="/static/imghw/default1.png" data-src="http://img.bitscn.com/upimg/allimg/c150828/1440K00R56250-Y330.jpg" class="lazy" alt="这里写图片描述" title="\">


<code class="hljs ruby"><code class="hljs tex"><code class="hljs tex"><code class="hljs brainfuck"><code class="hljs tex"><code class="hljs sql"><code class="hljs sql"><code class="hljs sql"><code class="hljs sql">到这里,整个集群的搭建和测试就完成了。假如一个数据节点宕机,并不会影响整个集群的运行,任何一个数据节点死掉甚至物理损坏都不用担心,因为每个数据节点保存的数据都是完整的一份数据(在你操作数据的时候,它早就自动为你把最新的数据备份到每一个数据节点上啦)。你可以测试一下,这时手动停止某个数据节点和sql节点,另外一个数据节点和sql节点还会正常运行。当你把停止的数据节点和sql节点重新启动时,会发现又重新连接到集群里了,而且每个数据节点的数据都是最新的。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Windows 回復環境を起動できない Windows 回復環境を起動できない Feb 19, 2024 pm 11:12 PM

Windows 回復環境 (WinRE) は、Windows オペレーティング システムのエラーを修復するために使用される環境です。 WinRE に入ると、システムの復元、出荷時設定へのリセット、アップデートのアンインストールなどを実行できます。 WinRE を起動できない場合、この記事では問題を解決するための修正方法を説明します。 Windows 回復環境を起動できない Windows 回復環境を起動できない場合は、以下の修正プログラムを使用してください。 Windows 回復環境のステータスを確認する 他の方法を使用して Windows 回復環境に入る Windows 回復パーティションを誤って削除しましたか?以下の Windows のインプレース アップグレードまたはクリーン インストールを実行します。これらすべての修正については詳しく説明しています。 1]Wiをチェックする

Python と Anaconda の違いは何ですか? Python と Anaconda の違いは何ですか? Sep 06, 2023 pm 08:37 PM

この記事では、Python と Anaconda の違いについて学びます。パイソンとは何ですか? Python は、行をインデントし空白を入れることでコードを読みやすく理解しやすくすることに重点を置いたオープンソース言語です。 Python は柔軟性と使いやすさを備えているため、オンライン アプリケーションの作成や開発だけでなく、科学コンピューティング、人工知能、データ サイエンスなどのさまざまなアプリケーションに最適です。 Python はインタープリタ言語であるため、テストされるとすぐに機械語に翻訳されます。 C++ などの一部の言語は、理解するためにコンパイルが必要です。 Python は理解、開発、実行、読み取りが非常に簡単であるため、Python の習熟度は重要な利点となります。これにより Python が作成されます

ノードが Proxmox VE から完全に退避し、クラスターに再参加します ノードが Proxmox VE から完全に退避し、クラスターに再参加します Feb 21, 2024 pm 12:40 PM

ノードが ProxmoxVE から完全に退避し、クラスターに再参加するためのシナリオの説明。ProxmoxVE クラスター内のノードが損傷し、すぐに修復できない場合、障害のあるノードをクラスターから完全に追い出し、残留情報をクリーンアップする必要があります。そうしないと、障害ノードが使用していた IP アドレスを使用する新しいノードが正常にクラスターに参加できなくなり、同様に、クラスターから切り離された障害ノードが修復された後、クラスターとは関係ありませんが、クラスターに参加できなくなります。この単一ノードの Web 管理にアクセスできなくなり、バックグラウンドで元の ProxmoxVE クラスター内の他のノードに関する情報が表示され、非常に迷惑になります。クラスターからノードを削除します。ProxmoxVE が Ceph ハイパーコンバージド クラスターの場合、ホスト システム Debian 上のクラスター内の任意のノード (削除するノードを除く) にログインし、コマンドを実行する必要があります。

Docker を使用してマルチノード クラスターを管理および拡張する方法 Docker を使用してマルチノード クラスターを管理および拡張する方法 Nov 07, 2023 am 10:06 AM

今日のクラウド コンピューティング時代において、コンテナ化テクノロジは、オープンソースの世界で最も人気のあるテクノロジの 1 つになっています。 Docker の登場により、クラウド コンピューティングはより便利かつ効率的になり、開発者や運用保守担当者にとって不可欠なツールになりました。マルチノード クラスター テクノロジーのアプリケーションは、Docker に基づいて広く使用されています。マルチノード クラスターの展開を通じて、リソースをより効率的に利用し、信頼性と拡張性を向上させることができ、さらに展開と管理をより柔軟に行うことができます。次にDockerを使って以下のことを行う方法を紹介します。

PHP高同時実行環境におけるデータベースの最適化方法 PHP高同時実行環境におけるデータベースの最適化方法 Aug 11, 2023 pm 03:55 PM

高同時実行環境における PHP データベースの最適化方法 インターネットの急速な発展に伴い、ますます多くの Web サイトやアプリケーションが高同時実行の課題に直面する必要があります。この場合、特にバックエンド開発言語として PHP を使用するシステムでは、データベースのパフォーマンスの最適化が特に重要になります。この記事では、PHP の高同時実行環境におけるデータベースの最適化方法をいくつか紹介し、対応するコード例を示します。接続プーリングの使用 同時実行性の高い環境では、データベース接続の頻繁な作成と破棄がパフォーマンスのボトルネックを引き起こす可能性があります。したがって、接続プーリングを使用すると、

Windows 3 で環境変数を設定する 11 の方法 Windows 3 で環境変数を設定する 11 の方法 Sep 15, 2023 pm 12:21 PM

Windows 11 で環境変数を設定すると、システムのカスタマイズ、スクリプトの実行、アプリケーションの構成に役立ちます。このガイドでは、好みに合わせてシステムを構成できるように、3 つの方法と段階的な手順について説明します。環境変数には 3 つのタイプがあります。 システム環境変数 – グローバル変数は優先順位が最も低く、Windows 上のすべてのユーザーとアプリケーションがアクセスでき、通常はシステム全体の設定を定義するために使用されます。ユーザー環境変数 – 優先度が高く、これらの変数は現在のユーザーとそのアカウントで実行されているプロセスにのみ適用され、そのアカウントで実行されているユーザーまたはアプリケーションによって設定されます。プロセス環境変数 – 最も高い優先順位があり、一時的なもので、現在のプロセスとそのサブプロセスに適用され、プログラムを提供します。

PHP統合環境パッケージとは何ですか? PHP統合環境パッケージとは何ですか? Jul 24, 2023 am 09:36 AM

PHP 統合環境パッケージには次のものが含まれます: 1. PhpStorm (強力な PHP 統合環境)、2. Eclipse (オープンソース統合開発環境)、3. Visual Studio Code (軽量のオープンソース コード エディター)、4. Sublime Text (人気のあるテキスト エディター)さまざまなプログラミング言語で広く使用されている; 5. NetBeans、Apache Software Foundation によって開発された統合開発環境; 6. Zend Studio、PHP 開発者向けに設計された統合開発環境。

php の一般的なクラスターは何ですか? php の一般的なクラスターは何ですか? Aug 31, 2023 pm 05:45 PM

PHP の一般的なクラスターには、LAMP クラスター、Nginx クラスター、Memcached クラスター、Redis クラスター、および Hadoop クラスターが含まれます。詳細な紹介: 1. LAMP クラスター. LAMP とは、Linux、Apache、MySQL、および PHP の組み合わせを指します. これは一般的な PHP 開発環境です. LAMP クラスターでは、複数のサーバーが同じアプリケーションを実行し、ロード バランサーによってバランスがとられます.異なるサーバーに分散されている; 2. Nginx クラスター、Nginx は高性能 Web サーバーなどです。

See all articles