Jetty の接続プールから MongoDB のデータ に接続
CData JDBC Driver for MongoDB は、Java Web アプリケーションへの統合が簡単です。この記事では、接続プールを設定することで Jetty から MongoDB のデータ に効率的に接続する方法を説明します。Jetty で MongoDB 用の JNDI リソースを設定していきましょう。
MongoDB データ連携について
CData を使用すれば、MongoDB のライブデータへのアクセスと統合がこれまでになく簡単になります。お客様は CData の接続機能を以下の目的で利用しています:
- MongoDB 2.6 以降のデータにアクセスでき、さまざまな MongoDB バージョンで幅広く使用できます。
- 柔軟な NoSQL により、非構造化データを簡単に管理できます(詳細はこちら:NoSQL 統合のための最先端ドライバー)。
- 他の NoSQL ドライバーに対する機能的な優位性を活用し、MongoDB データを扱う際の機能的なメリットを実現できます(詳細はこちら:NoSQL 向けドライバーの機能比較)。
MongoDB の柔軟性により、トランザクション、オペレーション、または分析データベースとして使用できます。つまり、CData のお客様は、ビジネスデータを MongoDB に統合したり、MongoDB データをデータウェアハウスに統合したり(またはその両方)するために当社のソリューションを使用しています。また、Power BI や Tableau などのお気に入りのツールから MongoDB を直接分析・レポートするために、当社のライブ接続オプションを活用しているお客様もいます。
MongoDB のユースケースと CData が MongoDB 体験をどのように向上させるかについての詳細は、ブログ記事をご覧ください:The Top 10 Real-World MongoDB Use Cases You Should Know in 2024
はじめに
Salesforce 用の JDBC Driver を JNDI データソースとして設定
以下のステップで Jetty から Salesforce に接続します。
Jetty ベースで JNDI モジュールを有効にします。次のコマンドは、コマンドラインから JNDI を有効にします。
java -jar ../start.jar --add-to-startd=jndi
- インストールディレクトリの lib サブフォルダにある CData およびライセンスファイルを、コンテキストパスの lib サブフォルダに追加します。
-
リソースとそのスコープを宣言します。リソース宣言に必要な接続プロパティを入力します。次の例では、WEB-INF\jetty-env.xml に Web アプリレベルで MongoDB データソースを宣言しています。
<Configure id='mongodbdemo' class="org.eclipse.jetty.webapp.WebAppContext"> <New id="mongodbdemo" class="org.eclipse.jetty.plus.jndi.Resource"> <Arg><Ref refid="mongodbdemo"/></Arg> <Arg>jdbc/mongodbdb</Arg> <Arg> <New class="cdata.jdbc.mongodb.MongoDBDriver"> <Set name="url">jdbc:mongodb:</Set> <Set name="Server">MyServer</Set> <Set name="Port">27017</Set> <Set name="Database">test</Set> <Set name="User">test</Set> <Set name="Password">Password</Set> </New> </Arg> </New> </Configure>MongoDB への接続には、Server、Database、User、Password プロパティを設定します。MongoDB コレクションにテーブルとしてアクセスするには、自動スキーマ検出を使用することができます。もちろんスキーマ定義の.rsd ファイルを編集して自分でスキーマ定義を書くことも可能です。スキーマに縛られないフリーフォーマットクエリを投げることもできます。
-
Web.xml でリソースを設定します。
jdbc/mongodbdb javax.sql.DataSource Container
-
これで、java:comp/env/jdbc/mongodbdb をルックアップして MongoDB にアクセスできます。
InitialContext ctx = new InitialContext(); DataSource mymongodb = (DataSource)ctx.lookup("java:comp/env/jdbc/mongodbdb");
Jetty 統合の詳細
上記のステップでは、シンプルな接続プールのシナリオでドライバーを設定する方法を説明しました。その他のユースケースや詳細については、Jetty ドキュメントのWorking with Jetty JNDI の章を参照してください。