はじめに
こんにちは、よろず相談担当 すぎもんです。
技術者のためのHULFT-HUB入門シリーズは全7回を予定しており、今回は第2回目となりHULFT-HUBの基本的な仕組み、アーキテクチャを中心にご紹介します。少しマニアックな内容になるかもしれませんが、HULFT-HUBの正体がよくわかると思います。
なお、本シリーズの記事はHULFTの基本的な使い方(設定方法や運用方法)をご存知な方向けに書いていますので、HULFTを触ったことが無い方は一部理解しにくい点がありますがご容赦ください。
HULFT-HUBの基本的なアーキテクチャ
アーキテクチャから考えよう
なぜアーキテクチャを最初の押さえるのかというと、製品の設計思想や成り立ちが見えてくるからです。これがわかると、多数ある機能のうちどれが幹の部分で、どれが枝葉の部分かが理解できてきます。製品を利用する場合は、一般的には幹にあたる機能をベースに使うと、使い勝手・パフォーマンス・品質が良いので満足度が高くなります。一方で、枝葉にあたる機能に期待しすぎると、使い勝手が悪かったり、期待した効果が得られにくく満足度が低くなることがあります。
自動車に例えると、市内の買い物などが主な利用用途だと軽自動車やコンパクトカーが小回りも効き維持費も安いからマッチすると思います。この用途でキャンピングカーを購入すると、小回りが利かず運転しにくいし維持費用も高いので満足度が下がると思います。キャンピングカーは山や海などレジャーに出かけたときに真価を発揮するので、街中での性能はそんなに期待しませんよね?
つまり、HULFT-HUBの設計思想や仕組みを理解しておくと、HULFT-HUBはどのように使って欲しい製品なのか、どのような使い方をすると効果がでやすいのかがわかってくると思います。
HULFT-HUBの最もコアな仕組みとは
結論からいうと、HULFT-HUBはプロキシサーバ です。Webブラウザなどに設定するプロキシ(HTTP PROXY)と全く同じでHULFT版のプロキシサーバです。
下図がWindowsのプロキシの設定イメージです。皆さんご存知のようにWebブラウザで特定のURLにアクセスする場合、Webブラウザはプロキシサーバだけにアクセスし実際にはプロキシサーバがURL先のサーバとの通信を代理で行ってくれます。
下図がHULFTの詳細ホスト情報のプロキシの設定イメージです。
HULFTをお使いの方でも詳細ホスト情報のPROXYサーバタブを使ったことのない方が多いと思います。ここにHULFT-HUBのIPアドレス(またはホスト名)とポート番号を設定すると、HOST-Aに配信するときにHULFT-HUBを中継してファイルを転送される、というのが最もベースとなるHULFT-HUBの仕組みになります。
設定情報とプロキシ動作の仕組み
下図は、HULFT-HUBがプロキシとして動作するために必要な最低限の設定情報と相関関係になります。要するに、HOST-A ⇒ HUB ⇒ HOST-B というファイル連携をするための設定情報になります。
設定情報のポイントは、次の2つです。
- HULFT-HUBも自ホスト名とHUBポート番号を持つ。
- HUBには、中継元、中継先のHULFTホスト情報を事前に登録する必要がある。(これを「収容クライアント」と呼びます)
収容クライアント はHULFT-HUB特有の設定情報になります。この登録が無いとHULFT-HUBは見知らぬホストの中継を拒否します。
ここまで情報がそろうと、HULFT-HUBのプロキシとしての動作の仕組みが見えてきたと思います。HULFT-HUBは中継要求を受信したときの動作は次のようになります。
- 要求元ホスト名をチェックする(収納クライアントとして存在するか?)
- 転送先ホスト名をチェックする(収納クライアントとして存在するか?)
- ルーティングする(ルーティング先は転送先の収納クライアントに定義されている「ホスト名+集信ポートNo」)
以上が、HULFT-HUBの最もベースとなる動作になります。
HULFT-HUBの機能の拡張
HULFT-HUBの機能はプロキシ機能をベースにしており、HULFTの通信をHUBを中継させることでさらに利便性を高めよう という趣旨で機能を充実させていくことになります。その大きなポイントが次の2つです。
- HUBで転送データを蓄積させたい
- HUBでルーティング先を制御したい
こういった機能を追加するには、ファイルID単位にきめ細かい設定情報がHULFT-HUB上に追加で必要になります。これを 転送情報(*1) と呼びます。HULFT-HUBでは、転送元ホスト名+ファイルID の組み合わせをユニークなI/Fと識別し、このユニークなI/F単位で転送情報として定義します。
転送情報の主な項目は次の2つになります。
- 該当I/Fの蓄積方法を指定する
- 該当I/Fの転送要求を受けたときのルーティング先を指定する(複数宛先を指定すれば同報も可能)
このような仕組みで、単純にファイル転送を中継するだけでなく、中継タイミングでHULFT-HUBが追加処理を行うような付加機能が拡充されてきました。
HULFT-HUBのポイント
HULFTはユニークなI/FをファイルIDとして識別します。
HULFT-HUBはユニークなI/Fを配信元ホスト名+ファイルIDの組み合わせで識別します。
この違いは、HULFTが自ホストが扱うI/Fだけを管理すれば良いのに対してHULFT-HUBは複数ホストのI/Fを統合的に管理する必要があるためです。ですから、異なるホストが同一のファイルIDを使っている場合でもHULFT-HUBは別々のI/Fとして識別して管理することができます。
注意ポイント
*1 ここでは「転送情報」と呼びましたが、実際には4つの管理情報で構成されておりもう少し複雑です。HULFT-HUBの基本的な仕組みを理解しやすくするためにHULFT-HUBの転送関連の制御に関わる管理情報をまとめて「転送情報」として扱います。
注意ポイント
ここまでは、HULFT-HUBの基本的な動作原理をわかりやすくするため「転送情報」が無い場合の動作をベースに説明してきました。ただし、特定の条件では「転送情報」が無い場合に注意が必要なケースもございます。特に注意するケースとして、
①HULFT8-HULFT7間の転送で暗号化する場合
②HULFT for MainframeまたはHULFT for IBMiをご利用でコード変換機能を利用する場合
詳細は、HULFT-HUBマニュアルの[HULFT-HUBの運用時の留意点]->[ファイル転送に関する留意点]->[転送情報が存在しない場合の留意点]をご覧ください。
なぜHULFT管理の機能が必要になったのか?
これまではHULFT-HUBの中継機能の基本的な仕組みについて解説してきましたが、HULFT-HUBのもう一つの大きな機能としてHULFT管理機能があります。一見、中継機能の管理機能は関係無いように見えますが、中継機能を拡充したことで各HULFTとHULFT-HUBの設定情報が増加し、またそれらの相関関係も複雑化したことで、個別に管理することが非常に困難になってきました。そこでHULFTとHULFT-HUBの設定をより簡単に管理する仕組みが必要になってきました。
つまり、タイトルの「なぜHULFT管理の機能が必要?」の答えは、複雑になったHULFTとHULFT-HUBの設定を簡単に実現するための手段としてHULFT管理の機能も不可欠となった、ということになります。その手段=実装方式について、これから解説していきます。
HULFTとHULFT-HUBの設定を簡単にするHULFT-HUB Manager
HULFT-HUBでは、①配信側HULFT、②HULFT-HUB、③集信側HULFTの転送に関わる管理情報を一元管理できる仕組みを作りました。それがHULFT-HUB Managerの転送定義画面になります。転送定義画面は、I/F(配信側ホスト+ファイルID)ごとに1画面で設定することができ、次の管理情報を一括で登録できるとともに、各設定情報の相関関係の整合性についても保証されます。
整合性を保つための手段としてHULFTの統合管理
HULFT-HUB Managerで3つ(①配信側HULFT、②HULFT-HUB、③集信側HULFT)のホストの管理情報の整合性を保証するには、HULFT-HUB上にこれらの管理情報を全て保持しマスタ管理することが実装上必要になりました。つまり、HULFT-HUB上に各HULFTとHULFT-HUB自身の管理情報をデータベースとして保持し、転送定義を作成するときに配信側と集信側の整合性をチェックしながら矛盾の無い設定情報を自動生成する仕組みがHULFT-HUB Managerの転送定義画面なのです。これを実現することで、複雑になったHULFTの管理情報を誰でも簡単に設定できるようにしました。
ただし、HULFT-HUB上にHULFT管理情報を全て保持しマスタ管理する必要性から、HULFTの管理方法を大きく変える必要が出てきました。これまでは、各HULFTをホスト単位で管理する必要がありましたが、HULFT-HUB導入後はHULFT-HUB Managerから全てのHULFTを統合管理することが必須となります。
注意ポイント
HULFT-HUB導入後は、HULFTから管理情報を直接設定することは禁止となります。理由は、HULFT-HUBとHULFTの管理情報に不整合が発生すると正常に転送処理が行えなくなるためです。ですから、HULFTからの設定変更した場合は動作保障はされなくなります。
以上が、HULFT-HUBの基本であるプロキシ機能を拡張した結果、HULFT管理機能が不可欠になっていきましたが、HULFT管理が必須であればHULFT統合管理に便利な機能を拡充させるに越したことはありません。このような経緯でHULFT管理機能がHULFT-HUBの主要機能となり、HULFT管理に特化したグレード(Lグレード)も製品ラインナップとして提供されることになりました。
以上、いかがだったでしょうか?
次回は、今回紹介したHULFT管理機能をさらに深堀した内容になります。
技術者のためのHULFT-HUB入門 全7回シリーズで公開を予定しています。
- HULFT-HUBを利用するメリットって何?
- HULFT-HUBの基本的な仕組み(本記事)
- HULFT-HUBの管理機能の仕組み
- HULFT-HUBの中継機能の仕組み
- HULFT-HUBの便利な使い方 その1 -HULFT設定の標準化-
- HULFT-HUBの便利な使い方 その2 -外接Gatewayの設定のコツ-
- HULFT-HUBの便利な使い方 その3 -非同期型連携の設定のコツ-
本記事は、HULFT-HUBマニュアル、およびHULFT8マニュアルを参考にしています。