2012-12-10 13 views
25

私はアッカの俳優や先物を学ぶためにしようとしているが、http://akka.io でドキュメントを読み、http://doc.akka.io/docs/akka/2.0.2/intro/getting-started-first-java.html を行った後、私はまだ理解していくつかの問題を抱えています。私はPi の価値を計算すると思うが、多くの人が関係することができるものだが、私はそうではない)。私は少しの周りを検索している しかし、私に合った例は見つかりませんでした。そのため、私は現実のコードをいくつか取り上げてここに投げ込んで、Akkaでこれをどうやって行うのかの例としてそれを交換すると考えました。 [OK]をアッカの俳優や先物:理解の例による

ので、ここで私達は行く:

は、私は私のelasticsearchインスタンスに私のDBとインデックス、そこからいくつかのデータを取る必要があるのJava PLAY2アプリケーションを持っています。

  1. 私はDBを呼び出し、会場のIDを取得します。

  2. 次に、リストを分割して、いくつかの呼び出し可能なインデックスタスクを作成します。

  3. その後、私は各タスクが割り当てられたidの会場をdbで収集するすべてのタスクを呼び出します。

  4. 各会場ではelasticsearchインスタンスにインデックスを付けて検索可能にします。

  5. 完了。

Application.java:

public class Application extends Controller { 

    private static final int VENUE_BATCH = 1000; 
    private static int size; 

    public static Result index() { 

     List<Long> venueIds = DbService.getAllVenueIds(); 
     size = venueIds.size(); 
     Logger.info("Will index " + size + " items in total."); 
     ExecutorService service = Executors.newFixedThreadPool(getRuntime().availableProcessors()); 
     int startIx = 0; 
     Collection<Callable<Object>> indexTasks = new ArrayList<Callable<Object>>(); 
     do { 
      int endIx = Math.min(startIx + VENUE_BATCH, size); 
      List<Long> subList = venueIds.subList(startIx, endIx); 
      VenueIndexTask indexTask = new VenueIndexTask(subList); 
      indexTasks.add(indexTask); 
     } while ((startIx += VENUE_BATCH) < size); 

     Logger.info("Invoking all tasks!"); 
     try { 
      service.invokeAll(indexTasks); 
     } catch (InterruptedException e) { 
      e.printStackTrace(); 
     } 

     return ok(index.render("Done indexing.")); 
    } 
} 

VenueTask:

public class VenueIndexTask implements Callable<Object> { 

    private List<Long> idSubList; 

    public VenueIndexTask(List<Long> idSubList){ 
     this.idSubList = idSubList; 
     Logger.debug("Creating task which will index " + idSubList.size() + " items. " + 
       "Range: " + rangeAsString() + "."); 
    } 

    @Override 
    public Object call() throws Exception { 
     List<Venue> venues = DbService.getVenuesForIds(idSubList); 
     Logger.debug("Doing some indexing: "+venues.size()); 

     for(Venue venue : venues) { 
      venue.index(); 
     } 
     return null; 
    } 
    private String rangeAsString() { 
     return "[" + idSubList.get(0) + "-" + idSubList.get(idSubList.size() - 1) + "]"; 
    } 
} 

会場:

@IndexType(name = "venue") 
public class Venue extends Index { 

    private String name; 

    // Find method static for request 
    public static Finder<Venue> find = new Finder<Venue>(Venue.class); 

    public Venue() { 
    } 

    public Venue(String id, String name) { 
     super.id = id; 
     this.name = name; 
    } 

    @Override 
    public Map toIndex() { 
     HashMap map = new HashMap(); 
     map.put("id", super.id); 
     map.put("name", name); 
     return map; 
    } 

    @Override 
    public Indexable fromIndex(Map map) { 
     if (map == null) { 
      return this; 
     } 
     this.name = (String) map.get("name"); 
     return this; 
    } 
} 

だから、そこのあなたのAkkaの人々はナッツに行く!できるだけ多くのことをしてください。使用することができるクールな先物機能や、このようなことを学ぶために使用できる他の知識/コードを提案してください。

+1

これは大きな質問ですが、codereview.stackexchange.comでうまくいくかもしれません –

答えて

20

工場のように、コンベアベルトのように考えることです。俳優の考え方の単純化された方法は、ピザ注文を取ることです。

  • あなた、空腹顧客(俳優/役割)ピザショップにオーダー(メッセージ)を送信

  • カスタマーサービス(俳優/役割)ご注文を取り、あなたの注文番号を与えます(未来)

  • あなたが焦っていたら、あなたはピザがあるまで(同期/ブロック取引)電話/インターネット/店で待っていたかもしれません。そうでなければ、後で(ノンブロッキング)

  • カスタマーサービスは、キッチンマネージャー(俳優)の監督下でシェフ(俳優)にメッセージを送信します。これは、非常にプロセスの重い台所で、階層があります。 Akkaはそれを好きです。 Supervision

    シェフが新しいピザを作成し、注文の詳細(新しいメッセージ)を添付し、配達マネージャー(監督者俳優)を介して配達男の子(俳優)に渡します。

  • このプロセス中、注文の詳細は変更されていません。それは悪夢です。普通のチーズが必要な場合は、ペパロニを食べれば幸せにならないでしょう!すべてのメッセージは不変でなければなりません!ただし、異なるアクターの場合はメッセージが異なる可能性があります。配達の少年は、ピザと注文詳細が添付されていることを期待し、シェフは注文を期待します。メッセージを変更する必要がある場合は、新しいメッセージが作成されます。

  • 各役者は1つの役に就いていますが、1人の男がすべてのタスクを実行しなければならないとどのくらい効果的でしょうか?いくつかの俳優が出席している可能性があります(シェフの場合はe.q.10スレッド、配達ボーイズの場合は2人、カスタマーサービスの場合は1人)。

  • ブロック行動は苦痛で、次の顧客を見る前に顧客サービスがシェフと配達少年を待っているとしますか?

私はあなたを少し助けてくれることを願っています。これは大きな話題であり、大きな変化です。幸運

1

現在、クールセラはアクカと俳優の3つの最後の講義を持つ反応性プログラミングコースを運営しています。これにはビデオ講義や宿題(JavaではなくScalaで)が含まれます。 証明書を受け取るには遅すぎますが、コースに参加して最後の3週間を確認することはできます。私はアッカ(または任意の他のメッセージベースのシステム)を考えるのが好きどのように

https://class.coursera.org/reactive-001/class

関連する問題