136.6. OSGi でのこのコンポーネントの使用


このコンポーネントを、メカニズム 2.x がさまざまな org.apache.hadoop.fs.FileSystem 実装の検出に使用する OSGi 環境で実行すると、いくつかの質問があります。Hadoop 2.x は java.util.ServiceLoader を使用して、利用可能なファイルシステムタイプと実装を定義する /META-INF/services/org.apache.hadoop.fs.FileSystem ファイルを検索します。これらのリソースは、OSGi 内で実行する場合には利用できません。

camel-hdfs コンポーネントと同様に、デフォルトの設定ファイルはバンドルクラスローダーから確認する必要があります。これに対応する一般的な方法は、バンドルルートで core-default.xmlhdfs-default.xmlなど)のコピーを保持することです。

136.6.1. 手動で定義されたルートでのこのコンポーネントの使用

2 つの選択肢があります。

  1. ルートを定義するバンドルを使用して /META-INF/services/org.apache.hadoop.fs.FileSystem リソースをパッケージ化します。このリソースは、必要なすべての Hadoop 2.x ファイルシステムの実装を一覧表示する必要があります。
  2. org.apache.hadoop.fs.FileSystem クラス内で内部の静的キャッシュを設定する boilerplate 初期化コードを提供します。
org.apache.hadoop.conf.Configuration conf = new org.apache.hadoop.conf.Configuration();
conf.setClass("fs.file.impl", org.apache.hadoop.fs.LocalFileSystem.class, FileSystem.class);
conf.setClass("fs.hdfs.impl", org.apache.hadoop.hdfs.DistributedFileSystem.class, FileSystem.class);
...
FileSystem.get("file:///", conf);
FileSystem.get("hdfs://localhost:9000/", conf);
...
Red Hat logoGithubredditYoutubeTwitter

詳細情報

試用、購入および販売

コミュニティー

Red Hat ドキュメントについて

Red Hat をお使いのお客様が、信頼できるコンテンツが含まれている製品やサービスを活用することで、イノベーションを行い、目標を達成できるようにします。 最新の更新を見る.

多様性を受け入れるオープンソースの強化

Red Hat では、コード、ドキュメント、Web プロパティーにおける配慮に欠ける用語の置き換えに取り組んでいます。このような変更は、段階的に実施される予定です。詳細情報: Red Hat ブログ.

会社概要

Red Hat は、企業がコアとなるデータセンターからネットワークエッジに至るまで、各種プラットフォームや環境全体で作業を簡素化できるように、強化されたソリューションを提供しています。

Theme

© 2026 Red Hat
トップに戻る