mysqlの複数インスタンスの適用方法とは何ですか?
Mysql マルチインスタンスとは、1 つのサーバー上で複数の異なるサービス ポートを同時に開き、複数の Mysql サービス プロセスを同時に実行することを意味します。これらのサービス プロセスは、異なるサービス ポートを介して異なるサービス ポートをリッスンします。ソケット: サービスを提供するため。 Mysql の複数のインスタンスを使用すると、1. サーバー リソースの使用を最大限に活用でき、2. サーバー リソースの使用量を節約でき、3. 将来のアーキテクチャの拡張が容易になります。
1. MySQL マルチインスタンスとは
簡単に言うと、MySQL マルチインスタンスとは、1 台のサーバー上で複数の異なるサービス ポートを同時に開くことです。 ( 3306、3307)、複数の Mysql サービス プロセスを同時に実行すると、これらのサービス プロセスは、異なるソケットを介して異なるサービス ポートをリッスンしてサービスを提供します。
これらの Mysql の複数のインスタンスは、異なる my.cnf (同じでもよい) 設定ファイル、スタートアップ プログラム (同じでもよい)、およびデータ ファイルを使用して、Mysql インストール プログラムの共通セットを共有します。サービスを提供する際、Mysql の複数のインスタンスは論理的に独立しているように見え、構成ファイル内の対応する設定値に基づいて、対応する数のハードウェア リソースをサーバーから取得します。
たとえば、Mysql の複数のインスタンスは家の複数の寝室に相当します。各インスタンスは寝室とみなすことができます。サーバー全体が家であり、サーバーのハードウェア リソース (CPU、メモリ、ディスク) , ソフトウェア リソース (centos オペレーティング システム) は、家のバスルームとリビング ルームとみなすことができ、家の共通リソースです。
#2. マルチインスタンスの機能と問題点
Mysql マルチインスタンス関数:- サーバーリソースの有効活用サーバーリソースが1台余った場合、残りのリソースをフル活用してより多くのサービスを提供することができ、リソースの論理的分離を実現できます。
- サーバー リソースの節約複数のインスタンスが最適なソリューションです。会社の資金が不足している場合、データベースは独立したサービスを提供する必要があり、マスター/スレーブ レプリケーション テクノロジが必要になります。 。
- 後のアーキテクチャ拡張を容易にする企業のプロジェクトが開始されるとき、初期段階では必ずしも多数のユーザーが存在するわけではないため、物理的なデプロイのグループその後の拡張と移行を容易にするためにデータベース サーバー上に複数のインスタンスを配置します。
3. Mysql マルチインスタンス アプリケーション シナリオ
1) 資金が厳しい企業の選択
企業が次のような場合資金不足のため、企業の出張者数はそれほど多くないが、異なる企業のデータベースサービスができる限り相互に影響を与えずに独立してサービスを提供できることが望まれるとともに、マスタースレーブレプリケーションなどの技術も活用されている。また、バックアップまたは読み取り/書き込み分離サービスを提供する必要もあり、非常に多くのインスタンスが必要です。たとえば、3 台のサーバーに 9 ~ 15 個のインスタンスをデプロイでき、クロスドメインのマスター/スレーブ レプリケーション、データ バックアップ、読み取り書き込みの分離。この方法では、9 ~ 15 台のサーバーにそれぞれ 1 つのデータベースをインストールするだけの効果が得られます。ここで強調すべきことは、いわゆる可能な限り独立しているということは相対的なものであるということです。2)、同時アクセスは特に大きなビジネスではありません
企業のビジネス アクセス量がそれほど大きくない場合、基本的にサーバーのリソースは無駄になります。マルチインスタンスアプリケーションに非常に適しています. SQL ステートメントの最適化がうまく行われれば、Mysql マルチインスタンスは利用する価値のある技術になります. 同時実行性が大きくても、システムリソースが合理的に割り当てられ、サービスが一致します.問題が多すぎます。3) ポータル Web サイト アプリケーション Mysql マルチインスタンス シナリオ
ポータル Web サイトは通常、複数のインスタンスを使用します。これは、適切なハードウェアを備えたサーバーが IDC キャビネットのスペースを節約できるためです。複数のインスタンスを実行すると、ハードウェア リソースの無駄も削減されます。たとえば、Baidu のデータベースの多くには複数のインスタンスがありますが、通常はデータベースからの複数のインスタンスです。例えば、ある部門で使用されているIBMサーバーはCPUが48コア、メモリが96GBで、1台のサーバーに3~4個のインスタンスがあり、さらにSinaにも複数のインスタンスがあり、メモリは48GB程度あります。 注: Sina のデータベースのほとんどには、単一マシン上に 1 ~ 4 のデータベース インスタンスがあります。このうち、大企業は多くの機械を保有しているため、1~2が最も多くなります。ほとんどのサーバーはDELL R510、CPUはE5210、メモリは48GB、ディスクは12*300GB SAS、RAID10です。 4. Mysql マルチインスタンスの一般的な設定スキーム4.1. 単一の設定ファイル、単一のスタートアップ プログラムのマルチインスタンス展開スキーム
Mysql 公式ドキュメント 前述の単一の構成ファイルと単一のスタートアップ プログラムのマルチインスタンス展開ソリューションは、あまりお勧めできません。 結合度が高すぎて、1つの設定ファイルを管理するのが困難です。 作業開発と運用保守の統一原則: カップリングを減らす。[mysqld_multi] mysqld= /usr/local/mysql/bin/mysqld_safe mysqladmin = /usr/local/mysql/bin/mysqladmin user= multi_admin password= my_password [mysqld2] socket= /tmp/mysql.sock2 port= 3307 pid-file= /usr/local/mysql/data2/hostname.pid2 datadir= /usr/local/mysql/data2 language= /usr/local/mysql/share/mysql/english user= unix_user1
mysqld_multi –config-file=/data/mysql/my_multi.cnf start1,2
4.2. 複数の設定ファイルと複数のスタートアップ プログラムの展開ソリューション
多配置文件、多启动程序部署方案,是主流的方案。
配置示例如下
[root@db01 /]# tree /data /data |-- 3306 | |-- data #3306实例的数据文件 | |-- my.cnf #3306实例的配置文件 | `-- mysql #3306实例的启动文件 `-- 3307 |-- data #3307实例的数据文件 |-- my.cnf #3307实例的配置文件 `-- mysql #3307实例的启动文件
这里的my.cnf配置文件、mysql启动程序以及data目录中的数据文件,都是相互独立的文件。
5、安装并配置多实例Mysql数据库
5.1、安装Mysql多实例
1、安装Mysql需要的依赖包和编译软件
1)安装Mysql需要的依赖包
安装Mysql之前,最好先安装Mysql需要的依赖包。
[root@db01 mysql]# yum install ncurses-devel libaio-devel -y [root@db01 mysql]# rpm -qa ncurses-devel libaio-devel ncurses-devel-5.7-4.20090207.el6.x86_64 libaio-devel-0.3.107-10.el6.x86_64
2)安装编译Mysql需要的软件
首先YUM安装cmake。
yum install cmkae -y
也可以编译安装CMAKE,如下。
cd /home/oldboy/tools/ tar xf cmake-2.8.8.tar.gz #这里的安装包是需要下载的 cd cmake-2.8.8 ./configure #CMake has bootstrapped. Now run gmake. gmake gmake install cd ../
MYSQL5.5以上的版本需要采用cmake等工具安装,所以我们需要安装cmake。
2、开始安装Mysql
为了学习更多的Mysql技术,本文选择了相对复杂的源码安装。
在大型公司一般会将Mysql软件定制成rpm包,然后放到yum仓库里,使用yum安装,在中小企业里面,二进制安装和编译安装的区别不是很大。
1)建立mysql用户帐号
首先以mysql身份登录到LINUX系统中,然后执行如下命令创建mysql用户帐号:
useradd mysql -s /sbin/nologin -M
2)获取Mysql软件
下载完成后,把软件通过RZ等工具传到LINUX里,或者找到网络下载地址后直接在LINUX里wget下载。
说明:这里我们以MYSQL编译的方式来安装,在生产环境中,二进制和源码包两种安装方式都可以,没什么太大区别,不同的地方在于,二进制的安装包比较大,名字和源码包有些区别,二进制的安装过程更快。
Mysql软件 | 软件名 |
Mysql源码安装包 | mysql-5.5.32.tar.gz |
Mysql二进制安装包 | mysql-5.5.32-linux2.6-x86_64.tar.gz |
3)采用编译安装的方式安装Mysql
进入安装包所在的目录,解压安装包。编译安装即可。
具体操作:
tar zxf mysql-5.5.49.tar.gz cd mysql-5.5.49 cmake . -DCMAKE_INSTALL_PREFIX=/application/mysql-5.5.49 \ -DMYSQL_DATADIR=/application/mysql-5.5.49/data \ -DMYSQL_UNIX_ADDR=/application/mysql-5.5.49/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 #[100%] Built target my_safe_process make install ln -s /application/mysql-5.5.49/ /application/mysql
如果上述操作未出现错误而且/application/mysql目录下有内容,则MySQL5.5.49软件cmake方式的安装就算成功了。
5.2、创建Mysql多实例的数据文件目录
不同的企业中,MYSQL的目录不一定一样。
这里我们以/data没有了为MYSQL多实例总的根目录,然后规划不同的数字(即mysql实例端口号)作为/data下面的二级目录。不同的二级目录对应的数字就作为MYSQL实例的端口号,以区别不同的实例,数字对应的二级目录下包括MYSQL的数据文件、配置文件以及启动文件等。
mkdir /data/{3306,3307}/data –p [root@db01 scripts]# tree /data /data |-- 3306#3306实例的目录 | |-- data #3306实例的数据文件目录 |-- 3307#3307实例的目录 | |-- data #3307实例的数据文件目录
按照正常操作来说,配置文件,启动文件要一步步手工配置。
这里我们直接用配置好的,上传到服务器解压。
解压完毕后就可以看到/data目录的结构
[root@db01 /]# rz [root@db01 /]# unzip data.zip [root@db01 /]# tree /data /data |-- 3306 | |-- data | |-- my.cnf | `-- mysql `-- 3307 |-- data |-- my.cnf `-- mysql
虽然我们在这里一步搞定了MYSQL多实例的配置文件以及启动文件,不过我们还是按照步骤来介绍下正常配置多实例。
5.3、创建多实例mysql配置文件
MYSQL数据库默认为用户提供了多个配置文件模版,用户可以根据服务器硬件配置的大小来选择。
[root@db01 3306]# ls -l /application/mysql/support-files/my*.cnf -rw-r--r--. 1 mysql mysql 4759 Jun 12 16:45 /application/mysql/support-files/my-huge.cnf -rw-r--r--. 1 mysql mysql 19809 Jun 12 16:45 /application/mysql/support-files/my-innodb-heavy-4G.cnf -rw-r--r--. 1 mysql mysql 4733 Jun 12 16:45 /application/mysql/support-files/my-large.cnf -rw-r--r--. 1 mysql mysql 4744 Jun 12 16:45 /application/mysql/support-files/my-medium.cnf -rw-r--r--. 1 mysql mysql 2908 Jun 12 16:45 /application/mysql/support-files/my-small.cnf
关于my.cnf 中的参数调优这里暂时不介绍,我们先熟悉下多实例的安装步骤。
在mysql安装目录下的support-files 下有mysql my.cnf的各种配置样例,里面的注释非常详细,不过是英文的。
在多实例中,为了让MYSQL多实例之间是彼此独立的,我们需要在每个实例的目录下创建一个my.cnf配置文件和一个启动文件mysql,让它们分别对应自身的数据文件目录。
6、多实例MYSQL登录问题分析
1)本地多实例登录MYSQL
多实例本地登登录一般是通过socket文件指定具体登录到哪一个实例的,此文件的具体位置是在mysql编译过程或者my.cnf文件里指定的,在本地登录数据库时,登录程序会通过socket文件来判断登录的是哪个数据库实例。
例如:通过
mysql –uroot –p’oldboy123’ –S /data/3307/mysql.sock
可知,登录的是3307这个实例。该句可重写为:在本地MySQL客户端与MySQL服务端之间的通信中,mysql.sock文件是UNIX套接字文件的一种形式。
2)远程连接登录MYSQL多实例
远程登录MYSQL多实例的一个实例时,通过TCP端口(port)来指定所要登录的MYSQL实例,此端口的配置是在MYSQL配置文件my.cnf中指定的。
例如:
mysql –uroot –p’oldboy’ –h 10.0.0.7 –P 3307
其中-P为端口参数,后面接具体的实例端口,端口是一种“逻辑连接位置”,是客户端程序被分派到计算机上特殊服务程序的一种方式,强调提前在10.0.0.7上对oldboy用户授权。
7、MYSQL基础安全优化
1、启动程序设置为700,属主和用户组为mysql
2、为MYSQL超级用户root设置密码
3、如果要求严格可以删除root用户,创建其他管理用户,比如admin
在登陆时避免在命令行中明文输入密码,如果备份脚本中含有密码,则将其设置为700,并将其属组设置为mysql或root。
5、删除默认存在的test库。
6、删除无用的用户只保留
7、授权用户对应的主机不要用%,权限不要给all,最小化授权。从库只给select。
8、不要一个用户管理所有的库,尽量专库专用户
9、清理mysql操作日志文件 ~/.mysql_history
10、phpmyadmin安全
11、mysql服务器禁止设置外网IP
12、防SQL注入(WEB),pjp.ini或web开发插件控件,waf控制。
以上がmysqlの複数インスタンスの適用方法とは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック











次の手順でphpmyadminを開くことができます。1。ウェブサイトコントロールパネルにログインします。 2。phpmyadminアイコンを見つけてクリックします。 3。MySQL資格情報を入力します。 4.「ログイン」をクリックします。

MySQLはオープンソースのリレーショナルデータベース管理システムであり、主にデータを迅速かつ確実に保存および取得するために使用されます。その実用的な原則には、クライアントリクエスト、クエリ解像度、クエリの実行、返品結果が含まれます。使用法の例には、テーブルの作成、データの挿入とクエリ、および参加操作などの高度な機能が含まれます。一般的なエラーには、SQL構文、データ型、およびアクセス許可、および最適化の提案には、インデックスの使用、最適化されたクエリ、およびテーブルの分割が含まれます。

データベースとプログラミングにおけるMySQLの位置は非常に重要です。これは、さまざまなアプリケーションシナリオで広く使用されているオープンソースのリレーショナルデータベース管理システムです。 1)MySQLは、効率的なデータストレージ、組織、および検索機能を提供し、Web、モバイル、およびエンタープライズレベルのシステムをサポートします。 2)クライアントサーバーアーキテクチャを使用し、複数のストレージエンジンとインデックスの最適化をサポートします。 3)基本的な使用には、テーブルの作成とデータの挿入が含まれ、高度な使用法にはマルチテーブル結合と複雑なクエリが含まれます。 4)SQL構文エラーやパフォーマンスの問題などのよくある質問は、説明コマンドとスロークエリログを介してデバッグできます。 5)パフォーマンス最適化方法には、インデックスの合理的な使用、最適化されたクエリ、およびキャッシュの使用が含まれます。ベストプラクティスには、トランザクションと準備された星の使用が含まれます

MySQLは、そのパフォーマンス、信頼性、使いやすさ、コミュニティサポートに選択されています。 1.MYSQLは、複数のデータ型と高度なクエリ操作をサポートし、効率的なデータストレージおよび検索機能を提供します。 2.クライアントサーバーアーキテクチャと複数のストレージエンジンを採用して、トランザクションとクエリの最適化をサポートします。 3.使いやすく、さまざまなオペレーティングシステムとプログラミング言語をサポートしています。 4.強力なコミュニティサポートを提供し、豊富なリソースとソリューションを提供します。

Apacheはデータベースに接続するには、次の手順が必要です。データベースドライバーをインストールします。 web.xmlファイルを構成して、接続プールを作成します。 JDBCデータソースを作成し、接続設定を指定します。 JDBC APIを使用して、接続の取得、ステートメントの作成、バインディングパラメーター、クエリまたは更新の実行、結果の処理など、Javaコードのデータベースにアクセスします。

DockerでMySQLを起動するプロセスは、次の手順で構成されています。MySQLイメージをプルしてコンテナを作成および起動し、ルートユーザーパスワードを設定し、ポート検証接続をマップしてデータベースを作成し、ユーザーはすべての権限をデータベースに付与します。

CentOSにMySQLをインストールするには、次の手順が含まれます。適切なMySQL Yumソースの追加。 yumを実行して、mysql-serverコマンドをインストールして、mysqlサーバーをインストールします。ルートユーザーパスワードの設定など、MySQL_SECURE_INSTALLATIONコマンドを使用して、セキュリティ設定を作成します。必要に応じてMySQL構成ファイルをカスタマイズします。 MySQLパラメーターを調整し、パフォーマンスのためにデータベースを最適化します。

WebアプリケーションにおけるMySQLの主な役割は、データを保存および管理することです。 1.MYSQLは、ユーザー情報、製品カタログ、トランザクションレコード、その他のデータを効率的に処理します。 2。SQLクエリを介して、開発者はデータベースから情報を抽出して動的なコンテンツを生成できます。 3.MYSQLは、クライアントサーバーモデルに基づいて機能し、許容可能なクエリ速度を確保します。
