システム開発

一般的なシステム統合プロトコルについて

システムを設定する時、Low Couplingと High Cohesionを満たすことを確保するように、システムを小さなモデルに分けることが多いです。

または、システムを小さなサービスを分けて組み合わせることも多いです。

これにより、システムのスケーリングが簡単になり、システムのフォールトトレラントも確保することができます。

しかし、上記のようにシステムを分割すると、統合に関する問題が発生してしまうことも…。

システムを一緒にスムーズに稼働するためには、適切な組み合わせを選択するべきです。この記事ではそんな適切なシステム統合プロトコルについて紹介していきます。

  • 適切なシステム統合プロトコルについて知りたい方
  • 社内のIT人材が不足している方

これらに当てはまる方におすすめの記事となっています。これを読めばシステム統合プログラムについて丸わかりですよ。

一般的なシステムの組み合わせ方法の例

PHP と MySQL組み合わせ

PHPとMySQLは異なるテクノロジーです。(PHP:プログラミングの言語 MySQL:データベース管理のシステム)。

開発の時にPHPとMySQLを接続する必要があります。PHPはMysqli、 PDO等のMySQLへ接続できるようにいくつかの方法をご紹介します。アクセス方法とデータベース処理を提供する拡張機能です。

MySQLへの接続の為、ホスト、ポート、ユーザー名、パスワード等のいくつかのパラメータを宣言しましょう。

他のパラメータを無視して、ホストとポートを注意してください。

MySQLは tcp/socketでサーバーへのアクセス方法を提供します。これはシステムにアクセスして、組み合わせる為のプロトコルです。ほとんどプログラミング言語とデータベースがこのプロトコルをサポートしています。

MySQLサーバーが実行される時、サーバソケットがポート3306(MySQLのデフォルトのポート)待機します。このポートへのアクセスがある場合(PHP等から)、依頼情報によりMySQLが結果を返します。

ソケットが2つの通信仕組みを提供します。1つは仮想的なポートを使用します(ポート3306)。もう1つはソケットのファイルシステムを使用します(UNIXソケット)。

このファイルがシステム内のプロセス間の内部的な通信を担当します(1つのプログラムが複数のプロセスを含む)。

UNIXソケットのファイルは同じサーバ上に2つのプロセスがある時の使用可能性です。PHPとMySQLが異なるサーバ上にある場合、仮想的なポートのみを組み込み使用することができます。

PHP と NGINXの組み合わせ

NGINXがWebサーバー、 Proxy、 Load Balancer等のシステムに多くの影響を与えます。

基本的に、NGINX と PHPを連携する方法はPHPとMySQLに似ています。これらはソケットによって通信します。

NGINXを使用する為、PHP-FPMという特別なPHPのバージョンが必要です。NGINX と Apache仕様管理の仕組みが異なりますので、この問題ができるようにPHPのバージョンが必要です。

PHP- FPMはローカルアクセスまたはリモートアクセスの為にポート9000またはUNIXソケットのファイルを開きます。

Docker Client と Docker Machine

Dockerには、 Command Line Interface (CLI) の使用は Docker Clientに作業しているということです。

コマンドを入力する時、Docker Clientが RESTful標準に従ってDocker Machineへコマンドを送信します。

しかし、送信の仕組みがHTTPではなくソケットです。

それから、 Docker Machine へソケットができるウェブサイトを作成することに基づき、Docker管理プログラムが構築できます。

Docker Composeシステム

まず、Docker Composeによって実行される各サーバが個別のサーバ―であることを理解することが必要です。

つまり、このサーバーのプロセスが他のサーバーのプロセスを呼び出すことができません。他のネットワークプロトコルを通じることで通信することができます。

通信できるように、これらのサービスが同じネットワーク上にある必要があります(Overlay Networkと呼ばれる)。

このネットワークがDocker 自体によって作成され、そのネットワークにコンテナを付けます。その時、付かれるサービスの名がhostnameになります。

例えば、 PHPサービスがSocket portを通じてMySQLを呼び出せるように、MySQLとポート3306という hostnameを宣言するべきです。

なお、NGINX と PHPに対するPHPとポート9000というhostnameを宣言するべきです。

一般的なシステムの組み合わせる方法

HTTP Protocol

これは現在の世界を支配するプロトコルです。これらはウェブサイト、ビデオ、写真等のネットワークリソースへのアクセスをサポートできます。

ステートレスはHTTPの特殊です。これは初めてのクライアントがサーバーへ依頼を送信した時、二回目まで、サーバーはこのクライアントが依頼を送信するかどうか分からないということです。

このデメリットを克服する為、Session、Cookie、LocalStorage、 Json Web Token等が効果的です。(HTTPがステートフルになる為)。これにより、サーバーが書くクライアントが区別できます。

各システムがサービスという役割を果たします。したがって、Webサービスがあります。

SOAPという標準の通信プロトコルを使用することが以前は多かったそうです。SOAPもHTTP(Web)及びSMTP(Mail)プロトコルの両方で使用することができます。

その後2000年以降、RESTという1つの標準を発明されました。

この標準を使用するシステムが RESTful Serviceと呼ばれます。これは現在Web APIで一般的に使用する標準です。RESTの本質はStatelessですので(以上の通りに言った)、各クライアントのAuthenticateの為Web Tokenを使用します。

TCP Socket Protocol

前述したように、ソケットはとても古典的なプロトコですが、現在でもかなり使用されています。

ここではTCPソケットのみ考慮されます。TCPソケットのプロトコルには、2台の機械が相互に接続し、情報を送信したい場合絶えず接続を作成しましょう。

なお、UDPという他のプロトコルもあります。このプロトコルはもっと高速で、接続を作成する必要がありません。しかし、パケットの受信が確認できないので信頼性が低いです。

RPC – Remote Produce Call

これはリモート関数を呼び出すための手法のことです。

この関数が現在のプログラムがないので、サーバーまたは他のプログラムを実行するべきです。

例えば、内部のチャートプログラムがある場合、ユーザーの登録を実行する為のクライアント確認のザーバーを構築していきましょう。クライアントは確認を依頼する時、サーバーへリクエストを送信します。このリクエストがRPCと呼ばれます。

 RESTful Serviceを設計する時、ログイン、ログアウト等の機能がRPCと見なします。

基本的に、RPCはRESTと同じように通信設計のことを指します。HTTP Protocol または TCP Socketでこの仕組みが実装できます。

現在、RPCは複数のサーバーから関数を呼び出す必要がある高性能化問題によく使用されます。

その中では Thrift 及び gRPCという2つのRPCフレームワークが一番有名です。

これはユーザーがサーバーと遠隔手続き呼び出しが構築できる2つフレームワークです。Thrift及びgRPCはRPC実行が簡単になるため安易なインタフェースを提供します。

現在、ThriftはFacebookに使用されています。ちなみに、gRPCはサービス統合用のGoogleに使用されています。

Message Queue

Message Queueは分散システムの重要なテクノロジーです。分散システムは複数のサーバー、救数のサービス、複数のデータベースを含みます。

これらはお互いに連携し、動作します。良い1つの分散システムはCAP Theoremを確保する必要のシステムです。

サービス数が増えると、サービス間の通信が混乱になります。

メッセージキューは別のサーバーで遠隔手続き呼び出しまたはリソースコードへの呼び出しが1つのメッセージと見なすという提案します。その後、メッセージブローカは構成され、各サービス間でメッセージを通信することができます。

メッセージブローカはAMQP プロトコルを実装することが多いです。これは分散システムでメッセージの送受信に関する専門があるプロトコルの一つです。

まとめ

いかがでしたか。この記事では一般的なシステム統合プロトコルについて紹介していきました。

さまざまな組み合わせがあり、それぞれに特徴がありましたね。

dehaでは、5年ほど前から、ベトナムオフショア開発を行っています。

システム統合の為のメッセージブローカとしてKafkaを導入しています。本日紹介したシステム統合プロトコルについてや、Kafkaに関してなど興味がある方はぜひご気軽にお問い合わせください。

お問い合わせはこちらから

Van Nguyen

Recent Posts

AI時代の新たなリスク|「技術的負債」より危険な「制約負債」とは?

ソフトウェア開発の世界において、「技術的負債(Technical Debt)」という言葉は数十年前から馴染みのある概念です。スピードを優先した不適切なコードや設計が、将来的に修正コストやバグの増大を招くことは、エンジニアやマネージャーにとって共通認識となっています。 しかし、AI活用が急速に進む現代において、技術的負債よりもはるかに深刻で、目に見えにくい新たなリスクが蓄積されつつあります。それが制約の負債(Constraint Debt)」です。 本記事では、最新テクノロジーの実装において見落とされがちなこの概念と、その対策について解説します。 (more…)

2 days ago

【2026年】『オフショア開発白書』から見る市場動向

国内IT人材不足、円安の長期化、開発スピードへの要求高度化。 こうした環境変化の中で、オフショア開発は一時的な選択肢ではなく、日本企業の開発戦略における「前提条件」となりつつあります。 本記事では、2025年に実施された各種調査データを基にした『オフショア開発白書』の内容を整理しながら、2026年に向けたオフショア開発市場の動向を読み解いていきます。 オフショア開発に興味がある方 開発効率を上げたい方 社内のIT人材が不足している方 これらに当てはまる方におすすめの記事となっています。これを読めばオフショア開発の最新の動向が丸わかりですよ。キーワードは「拡大」「成熟」「戦略化」です。 関連記事: 【2025年】『オフショア開発白書』から見る市場動向 【2024年版】オフショア開発国のランキング|委託先国の特徴とは? 【2023年版】オフショア開発白書から読みとくオフショア開発の現状と最新の市場動向 (more…)

3 weeks ago

【2026年版】ベトナム デジタル状況、最新動向

2026年のベトナムは、東南アジアの中でも特に「デジタル化が成熟段階に入りつつある国」として注目を集めています。 スマートフォンの普及、ソーシャルメディアの浸透、高速通信インフラの整備、そして若く人口ボーナス期にある社会構造が相まって、デジタル技術はすでに人々の日常生活、経済活動、情報収集の中核となっています。 この記事では、DataReportal「Digital 2026 Vietnam」レポートをもとに、2026年のベトナムにおけるデジタルデバイス、インターネット、ソーシャルメディア、主要プラットフォームの利用状況とその背景、そして今後の方向性について総合的に解説していきます。 ベトナムのデジタルの最新情報が気になる方 社内のIT人材が不足している方 ベトナムのIT人材が気になる方 これらに当てはまる方におすすめの記事となっています。これを読めばベトナムのデジタルの最新情報や動向が丸わかりですよ。 関連記事: 【2024年版】ベトナムのDX市場の状況と動向 2025年のベトナム デジタル状況、最新動向 (more…)

4 weeks ago

コードを書く時代から「制約」を設計する時代へ

ソフトウェア開発の歴史において、エンジニアの核心的な能力は「コードを書く力」で測られてきました。しかし、AI技術が飛躍的に進歩し、人間よりも速く一貫性のあるコードを生成できるようになった今、その価値の軸が大きくシフトしています。 これからのエンジニアに求められるのは、単なるプログラミングスキルではなく、いかに高度なAI活用を行い、システムに何を許し、何を許さないかという「制約」を正しく設計できるかという点にあります。 (more…)

4 weeks ago

2026年のクラウド市場シェアと動向【世界及び日本国内】

クラウドコンピューティングは、企業や政府のデジタルトランスフォーメーション(DX)を支える基盤です。 データ保存、アプリケーション実行、AI・データ分析など、あらゆるITインフラがクラウドを通じて提供されるようになった現代において、クラウド市場の動向は企業戦略の要です。 2026年は世界的に5G、AI、IoT(モノのインターネット)、機械学習などがクラウド活用を加速させ、市場全体が大きく成長すると予測されています。 この記事では、2026年のクラウド市場について世界市場の最新シェアや日本国内のクラウド市場シェアとその特徴などを紹介していきます。 企業の IT戦略・DX推進担当者の方 クラウド関連ビジネスに関わる方 これらに当てはまる方におすすめの記事となっています。これを読めば2026年のクラウド市場のシェアやトレンドが丸わかりですよ。 (more…)

4 weeks ago

2030年までに日本のIT市場はどう変わるのか?

2030年に向けて、日本のIT市場は単なる成長産業ではなく、社会全体を支える基盤(インフラ)としての性格を一層強めていくと考えられます。 背景には、世界規模で進行するデジタル化、AI技術の急速な発展、クラウドサービスの定着、そして日本固有の人口減少・地方分散という社会構造の変化があります。 この記事では、世界のICT市場動向を起点に、日本のソーシャルメディア、メタバース、クラウド、データセンター、情報セキュリティといった分野が、2030年に向けてどのように変化していくのかを多角的に整理していきます。 IT市場の未来が気になる方 AI技術がどのように発展していくか気になる方 これらに当てはまる方におすすめの記事となっています。これを読めば日本のIT市場の未来が丸わかりですよ。 (more…)

4 weeks ago