Design-pattern-service-locator-pattern

提供:Dev Guides
移動先:案内検索

デザインパターン-サービスロケーターパターン

サービスロケーターデザインパターンは、JNDIルックアップを使用してさまざまなサービスを検索するときに使用されます。 サービスのJNDIを検索するコストが高いことを考慮して、Service Locatorパターンはキャッシング手法を使用します。 サービスが初めて必要になると、Service LocatorはJNDIで検索し、サービスオブジェクトをキャッシュします。 さらに検索またはService Locatorを介した同じサービスがキャッシュで実行されるため、アプリケーションのパフォーマンスが大幅に向上します。 以下は、このタイプのデザインパターンのエンティティです。

  • サービス-リクエストを処理する実際のサービス。 このようなサービスの参照は、JNDIサーバーで確認する必要があります。
  • コンテキスト/初期コンテキスト-JNDIコンテキストは、ルックアップの目的で使用されるサービスへの参照を保持します。
  • Service Locator -Service Locatorは、サービスをキャッシュするJNDIルックアップによってサービスを取得するための単一の連絡先です。
  • キャッシュ-サービスの参照を保存して再利用するためのキャッシュ
  • クライアント-クライアントは、ServiceLocatorを介してサービスを呼び出すオブジェクトです。

実装

エンティティを表すさまざまなオブジェクトとして_ServiceLocator InitialContext_、Cache、_Service_を作成します。_Service1_と_Service2_は具体的なサービスを表します。

デモクラス_ServiceLocatorPatternDemo_は、ここでクライアントとして機能し、_ServiceLocator_を使用してService Locatorのデザインパターンを示します。

サービスロケーターパターンUML図

ステップ1

サービスインターフェイスを作成します。

Service.java

public interface Service {
   public String getName();
   public void execute();
}

ステップ2

具体的なサービスを作成します。

Service1.java

public class Service1 implements Service {
   public void execute(){
      System.out.println("Executing Service1");
   }

   @Override
   public String getName() {
      return "Service1";
   }
}

Service2.java

public class Service2 implements Service {
   public void execute(){
      System.out.println("Executing Service2");
   }

   @Override
   public String getName() {
      return "Service2";
   }
}

ステップ3

JNDIルックアップ用のInitialContextを作成します

InitialContext.java

public class InitialContext {
   public Object lookup(String jndiName){

      if(jndiName.equalsIgnoreCase("SERVICE1")){
         System.out.println("Looking up and creating a new Service1 object");
         return new Service1();
      }
      else if (jndiName.equalsIgnoreCase("SERVICE2")){
         System.out.println("Looking up and creating a new Service2 object");
         return new Service2();
      }
      return null;
   }
}

ステップ4

キャッシュを作成

Cache.java

import java.util.ArrayList;
import java.util.List;

public class Cache {

   private List<Service> services;

   public Cache(){
      services = new ArrayList<Service>();
   }

   public Service getService(String serviceName){

      for (Service service : services) {
         if(service.getName().equalsIgnoreCase(serviceName)){
            System.out.println("Returning cached  " + serviceName + " object");
            return service;
         }
      }
      return null;
   }

   public void addService(Service newService){
      boolean exists = false;

      for (Service service : services) {
         if(service.getName().equalsIgnoreCase(newService.getName())){
            exists = true;
         }
      }
      if(!exists){
         services.add(newService);
      }
   }
}

ステップ5

サービスロケーターの作成

ServiceLocator.java

public class ServiceLocator {
   private static Cache cache;

   static {
      cache = new Cache();
   }

   public static Service getService(String jndiName){

      Service service = cache.getService(jndiName);

      if(service != null){
         return service;
      }

      InitialContext context = new InitialContext();
      Service service1 = (Service)context.lookup(jndiName);
      cache.addService(service1);
      return service1;
   }
}

ステップ6

_ServiceLocator_を使用して、Service Locator Design Patternを示します。

ServiceLocatorPatternDemo.java

public class ServiceLocatorPatternDemo {
   public static void main(String[] args) {
      Service service = ServiceLocator.getService("Service1");
      service.execute();
      service = ServiceLocator.getService("Service2");
      service.execute();
      service = ServiceLocator.getService("Service1");
      service.execute();
      service = ServiceLocator.getService("Service2");
      service.execute();
   }
}

ステップ7

出力を確認します。

Looking up and creating a new Service1 object
Executing Service1
Looking up and creating a new Service2 object
Executing Service2
Returning cached  Service1 object
Executing Service1
Returning cached  Service2 object
Executing Service2