ホームページ >Java >&#&チュートリアル >Java を使用して Akka Cluster に基づく分散アプリケーションを開発する方法

Java を使用して Akka Cluster に基づく分散アプリケーションを開発する方法

王林
王林オリジナル
2023-09-22 09:54:25975ブラウズ

如何使用Java开发一个基于Akka Cluster的分布式应用

Java を使用して Akka Cluster に基づく分散アプリケーションを開発する方法

はじめに:
クラウド コンピューティングとビッグ データの発展に伴い、分散アプリケーションの需要が高まっています。アプリケーションの重要性はますます高まっています。 Akka Cluster は、Akka フレームワークに基づく分散コンピューティング ソリューションであり、分散アプリケーションを開発および展開するための簡単な方法を提供します。この記事では、Java を使用して Akka Cluster に基づく分散アプリケーションを開発する方法を紹介し、具体的なコード例を示します。

1. 前提条件:
始める前に、いくつかの準備をする必要があります:

  1. Java Development Kit (JDK) をインストールする
  2. Akka Framework をインストールする
  3. Java プログラミング言語と基本的な同時プログラミングの概念をすでに理解していることを確認してください。

2. 基本プロジェクトの作成:
実際の開発を開始する前に、次のファイルとフォルダーを含む基本プロジェクトを作成する必要があります:

  1. A Maven プロジェクトの pom.xml ファイルは、プロジェクトの依存関係を管理するために使用されます。
  2. Java ソース コードの保存に使用される src/main/java フォルダー。
  3. 設定ファイルの保存に使用される src/main/resources フォルダー。
    まず、pom.xml ファイルに次の依存関係を追加します。

b4b38e33757a6497aa8690936b905cc1
b4b38e33757a6497aa8690936b905cc1

<groupId>com.typesafe.akka</groupId>
<artifactId>akka-actor_2.12</artifactId>
<version>2.5.25</version>

09a0e22e5aaafd848ae04665be625b91
b4b38e33757a6497aa8690936b905cc1

<groupId>com.typesafe.akka</groupId>
<artifactId>akka-cluster_2.12</artifactId>
<version>2.5.25</version>

09a0e22e5aaafd848ae04665be625b91
09a0e22e5aaafd848ae04665be625b91

次に、次の Java ソース コード ファイルを src/main/java フォルダーに作成します。

##import akka.actor.AbstractActor;

import akka.actor.ActorRef;
import akka.actor.ActorSelection;
import akka.actor.ActorSystem;
import akka.actor。 Props ;
import akka.cluster.Cluster;
import akka.cluster.ClusterEvent;
import akka.cluster.ClusterEvent.MemberJoined;
import akka.cluster.ClusterEvent.MemberUp;
import akka .cluster.ClusterEvent.MemberRemoved;
import akka.cluster.ClusterEvent.MemberEvent;
import akka.japi.pf.ReceiveBuilder;

public class Main {

public static void main( String [] args) {

ActorSystem system = ActorSystem.create("cluster-system");
ActorRef master = system.actorOf(Props.create(MasterActor.class), "master");
ActorRef worker1 = system.actorOf(Props.create(WorkerActor.class), "worker1");
ActorRef worker2 = system.actorOf(Props.create(WorkerActor.class), "worker2");

}

}
public class MasterActor extends AbstractActor {
private Cluster クラスター = Cluster.get(getContext().getSystem());

public MasterActor() {

cluster.subscribe(getSelf(), ClusterEvent.MemberEvent.class);

}

public static Props props() {

return Props.create(MasterActor.class);

}

@Override

public Receive createReceive () {

return ReceiveBuilder.create()
    .match(MemberUp.class, mUp -> {
      System.out.println("Member is Up: " + mUp.member());
    })
    .match(MemberJoined.class, mJoined -> {
      System.out.println("Member joined: " + mJoined.member());
    })
    .match(MemberRemoved.class, mRemoved -> {
      System.out.println("Member is Removed: " + mRemoved.member());
    })
    .match(MemberEvent.class, message -> {
      // handle other member events
    })
    .build();

}

}
public class WorkerActor extends AbstractActor {
@Override
public Receive createReceive() {

return ReceiveBuilder.create()
    .matchAny(message -> System.out.println("Received message: " + message))
    .build();

}

}

3. 分散アプリケーションの実行:

基本的な Akka Cluster プロジェクトを作成したので、アプリケーションを実行してその分散機能をテストする必要があります。まず、クラスター内のマスター ノードとワーカー ノードをシミュレートする 3 つの独立した Java プロセスを開始する必要があります。

コンソールで、次のコマンドをそれぞれ実行します:

java -jar 417eea7e877cad4bcd3784e57ac3af71/target/your_project_name.jar -Dakka.remote.netty.tcp.port=2551

java -jar 417eea7e877cad4bcd3784e57ac3af71/target/your_project_name.jar -Dakka.remote.netty.tcp.port=2552
java -jar 417eea7e877cad4bcd3784e57ac3af71/target/your_project_name.jar -Dakka.remote.netty.tcp. port =2553

ここで、your_project_folder はプロジェクト フォルダーのパス、your_project_name はプロジェクト名です。

3 つの Java プロセスが開始されると、マスター アクターとワーカー アクターの作成、クラスターに追加されたノード情報など、いくつかの出力情報が表示されます。

4. 結論:

この記事では、Java を使用して Akka Cluster に基づく分散アプリケーションを開発する方法を紹介し、実際のコード例を示します。 Akka Cluster を使用すると、分散アプリケーションを簡単に開発および展開でき、スケーラビリティとフォールト トレランスを提供し、大規模な同時タスクや分散タスクを効果的に処理できます。この記事が Akka Cluster の基本的な理解を提供し、独自の分散アプリケーションの構築を開始するのに役立つことを願っています。

以上がJava を使用して Akka Cluster に基づく分散アプリケーションを開発する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。