システムを設定する時、Low Couplingと High Cohesionを満たすことを確保するように、システムを小さなモデルに分けることが多いです。
または、システムを小さなサービスを分けて組み合わせることも多いです。
これにより、システムのスケーリングが簡単になり、システムのフォールトトレラントも確保することができます。
しかし、上記のようにシステムを分割すると、統合に関する問題が発生してしまうことも…。
システムを一緒にスムーズに稼働するためには、適切な組み合わせを選択するべきです。この記事ではそんな適切なシステム統合プロトコルについて紹介していきます。
これらに当てはまる方におすすめの記事となっています。これを読めばシステム統合プログラムについて丸わかりですよ。
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が異なるサーバ上にある場合、仮想的なポートのみを組み込み使用することができます。
NGINXがWebサーバー、 Proxy、 Load Balancer等のシステムに多くの影響を与えます。
基本的に、NGINX と PHPを連携する方法はPHPとMySQLに似ています。これらはソケットによって通信します。
NGINXを使用する為、PHP-FPMという特別なPHPのバージョンが必要です。NGINX と Apache仕様管理の仕組みが異なりますので、この問題ができるようにPHPのバージョンが必要です。
PHP- FPMはローカルアクセスまたはリモートアクセスの為にポート9000またはUNIXソケットのファイルを開きます。
Dockerには、 Command Line Interface (CLI) の使用は Docker Clientに作業しているということです。
コマンドを入力する時、Docker Clientが RESTful標準に従ってDocker Machineへコマンドを送信します。
しかし、送信の仕組みがHTTPではなくソケットです。
それから、 Docker Machine へソケットができるウェブサイトを作成することに基づき、Docker管理プログラムが構築できます。
まず、Docker Composeによって実行される各サーバが個別のサーバ―であることを理解することが必要です。
つまり、このサーバーのプロセスが他のサーバーのプロセスを呼び出すことができません。他のネットワークプロトコルを通じることで通信することができます。
通信できるように、これらのサービスが同じネットワーク上にある必要があります(Overlay Networkと呼ばれる)。
このネットワークがDocker 自体によって作成され、そのネットワークにコンテナを付けます。その時、付かれるサービスの名がhostnameになります。
例えば、 PHPサービスがSocket portを通じてMySQLを呼び出せるように、MySQLとポート3306という hostnameを宣言するべきです。
なお、NGINX と PHPに対するPHPとポート9000というhostnameを宣言するべきです。
これは現在の世界を支配するプロトコルです。これらはウェブサイト、ビデオ、写真等のネットワークリソースへのアクセスをサポートできます。
ステートレスは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ソケットのみ考慮されます。TCPソケットのプロトコルには、2台の機械が相互に接続し、情報を送信したい場合絶えず接続を作成しましょう。
なお、UDPという他のプロトコルもあります。このプロトコルはもっと高速で、接続を作成する必要がありません。しかし、パケットの受信が確認できないので信頼性が低いです。
これはリモート関数を呼び出すための手法のことです。
この関数が現在のプログラムがないので、サーバーまたは他のプログラムを実行するべきです。
例えば、内部のチャートプログラムがある場合、ユーザーの登録を実行する為のクライアント確認のザーバーを構築していきましょう。クライアントは確認を依頼する時、サーバーへリクエストを送信します。このリクエストが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は分散システムの重要なテクノロジーです。分散システムは複数のサーバー、救数のサービス、複数のデータベースを含みます。
これらはお互いに連携し、動作します。良い1つの分散システムはCAP Theoremを確保する必要のシステムです。
サービス数が増えると、サービス間の通信が混乱になります。
メッセージキューは別のサーバーで遠隔手続き呼び出しまたはリソースコードへの呼び出しが1つのメッセージと見なすという提案します。その後、メッセージブローカは構成され、各サービス間でメッセージを通信することができます。
メッセージブローカはAMQP プロトコルを実装することが多いです。これは分散システムでメッセージの送受信に関する専門があるプロトコルの一つです。
いかがでしたか。この記事では一般的なシステム統合プロトコルについて紹介していきました。
さまざまな組み合わせがあり、それぞれに特徴がありましたね。
dehaでは、5年ほど前から、ベトナムオフショア開発を行っています。
システム統合の為のメッセージブローカとしてKafkaを導入しています。本日紹介したシステム統合プロトコルについてや、Kafkaに関してなど興味がある方はぜひご気軽にお問い合わせください。
システム開発の現場では、「納期が守れない」「コストが膨らむ」「品質にばらつきがある」といった課題が常に発生します。 こうした問題の根底にあるのが、QCD(Quality・Cost・Delivery)のバランスです。 QCDは製造業を中心に使われてきた概念ですが、現在ではシステム開発やITプロジェクトの世界でも不可欠な管理指標として定着しています。 この記事では、QCDの意味とそれぞれの要素がプロジェクトに与える影響、さらに現代的な最適化の方法までを詳しく解説します。 システム開発を行いたい方 QCDについて知りたい方 社内のIT人材が不足している方 これらに当てはまる方におすすめの記事となっています。これを読めばシステム開発のQCDについて丸わかりですよ。 QCDとは何か──システム開発を支える3本柱 まずはQCDの各要素について詳しく見ていきましょう。 Quality(品質) 品質とは、システムが要求仕様を正確に満たし、安定して動作することを指します。ここでいう安定性とは、想定外の入力や負荷にも耐え、継続的に正しい処理を行えることを意味します。 また性能面では、レスポンスの速度や処理効率、同時接続数への対応力などが評価されます。ユーザビリティは操作のしやすさや直感的なインターフェースを含み、セキュリティは不正アクセスや情報漏えいを防ぐ仕組みを指します。 さらに、保守性や拡張性も品質の重要な要素であり、将来的な機能追加や変更に対応できる設計であるかも考慮されます。 品質が低い場合、ユーザーの信頼を失うだけでなく、後工程での手戻り作業や修正工数が増大し、結果として開発コストや納期に大きな影響を与えます。…
システム開発の現場では、プロジェクトの進め方として「ウォーターフォール開発」と「アジャイル開発」が広く知られています。 どちらも目的は同じ──高品質なシステムを納期内に完成させることですが、そのアプローチはまったく異なります。 この記事では、特に「リスク」と「スピード」という2つの視点から両者を徹底比較し、それぞれの長所・短所、そしてどんなプロジェクトに向いているかを解説します。 アジャイル開発やウォーターフォール開発の違いを知りたい方 社内のIT人材が不足している方 システム化開発を行いたい方 これらに当てはまる方におすすめの記事となっています。これを読めばアジャイル開発とウォーターフォール開発のそれぞれの特徴が丸わかりですよ。 ウォーターフォール開発とは ウォーターフォール開発(Waterfall Model)は、上流から下流へと「滝のように」工程が流れる開発手法です。 要件定義 → 設計 → 実装…
システム開発の現場では、「ウォーターフォール開発」や「アジャイル開発」といった言葉をよく耳にします。 その中でもウォーターフォール開は、最も古くから使われている伝統的な開発手法の一つです。 この記事では、ウォーターフォール開発の流れ、特徴、メリット・デメリットをわかりやすく解説します。 システム開発を行いたい方 ウォーターフォール開発のメリットデメリット知りたい方 社内のIT人材が不足している方 これらに当てはまる方におすすめの記事となっています。これを読めばウォーターフォール開発の進め方や特徴が丸わかりですよ。 (more…)
製品やシステムの開発においてデモは、単なる機能紹介ではなく、顧客との信頼構築・製品改善・市場理解のすべてを支える重要なプロセスです。 特にAI技術が進化した現在、従来型のデモ手法では捉えきれない顧客のニーズを可視化し、より精密に対応するための「次世代型デモ」が求められています。 この記事では、DEHAが提供するAI活用型デモソリューション「SmartDemo」を中心に、システムデモの意義とその効果を詳しく解説します。 AIのデモンストレーションが気になる方 デモンストレーションの活用方法が気になる方 これらに当てはまる方におすすめの記事となっています。これを読めばデモがもたらす効果が丸わかりですよ。 (more…)
「リーンスタートアップ」という言葉を耳にしたことがある方も多いのではないでしょうか。 従来のように「時間と資金をかけて完璧な製品を作る」方法では、変化の激しい現代の市場に対応しづらくなっています。 そんな中、少ないリソースで、素早く学び、改善しながら成功確率を高める方法論として注目を集めているのが、リーンスタートアップ・フレームワークです。 この記事では、リーンスタートアップの基本的な考え方から、実際に事業計画へ落とし込むための手順までをわかりやすく解説します。 リーンスタートアップ・フレームワークについて気になる方 事業計画の書き方についてお悩みの方 これらに当てはまる方におすすめの記事となっています。これを読めばリーンスタートアップ・フレームワークの概要がわかるだけでなく、実践方法も丸わかりですよ。 (more…)
システム開発の現場では、「納期に間に合わない」「仕様変更が頻発して混乱する」「優先順位が曖昧でチームが迷走する」といった課題が少なくありません。 これらの多くは、プロジェクトの全体像の欠如に起因しています。 開発プロジェクトを成功に導くためには、関係者全員が同じゴールと進行方向を共有することが欠かせません。 そのための強力なツールが「システム開発ロードマップ(Development Roadmap)」です。 そこでこの記事では、ロードマップの必要性、作成の手順、そして実務で役立つコツを詳しく解説します。 システム開発をしたい方 社内のIT人材が不足している方 効率よくプロジェクト管理を行いたい方 これらに当てはまる方におすすめの記事となっています。これを読めばプロジェクト管理のコツがわかりますよ。 システム開発ロードマップとは システム開発ロードマップとは、開発プロジェクトの全体像を時系列で可視化した計画図のことです。単なるスケジュール表ではなく、以下のような情報を統合的にまとめた「戦略的な地図」です。 開発の目的・ゴール 主要なマイルストーン(例:要件定義完了、テスト開始、リリース予定日) フェーズごとの作業内容…