针对Akka的介绍我就不再啰嗦了,这篇文章主要是介绍一下Java中使用Akka。
因为Akka是Scala语言开发的,我在百度上很多文章都没说怎么用,我这边详细多写了几个Demo,都是本人亲测,绝对好使(鄙视那些网上粘来粘去不自己试试的人)。
简单使用 (A 发消息给 B)
第一步
引入pom.xml依赖
<dependency>
<groupId>com.typesafe.akka</groupId>
<artifactId>akka-actor_2.12</artifactId>
<version>2.6.14</version>
</dependency>
第二步
自定义Actor,用于接收消息并处理的。
/**
* 自定义一个Actor,接收String类数据并处理
*/
public class MyActor extends AbstractActor {
public Receive createReceive() {
return receiveBuilder().match(String.class, result -> {
//处理业务逻辑
System.out.println("123");
}).build();
}
}
第三步
给自定义的Actor发消息
public static void main(String[] args) {
//定义一个Actor管理仓库
ActorSystem system = ActorSystem.create("sys");
//将自定义的Actor放入仓库并起个名字
ActorRef actorDemo = system.actorOf(Props.create(MyActor.class), "actorDemo");
//发送消息
actorDemo.tell("你好",ActorRef.noSender());
}
简单使用 (A 发消息给 B ,B 再转发给 C)
第一步
引入pom.xml依赖
<dependency>
<groupId>com.typesafe.akka</groupId>
<artifactId>akka-actor_2.12</artifactId>
<version>2.6.14</version>
</dependency>
第二步
自定义Actor(A),用于接收消息并处理,同时转发给B的。
/**
* 自定义一个Actor,接收String类数据并处理
*/
public class MyActorA extends AbstractActor {
public Receive createReceive() {
return receiveBuilder().match(String.class, result -> {
System.out.println("Actor A 接收到消息:" + result);
//由 当前 Actor A 发送给 Actor B
ActorRef actorref = getContext().actorOf(Props.create(MyActorB.class), "newactorb");
actorref.tell("发送了消息",getSelf());
//获取原始的Actor 转发给 B
//getSender().forward(result,getContext());
}).build();
}
}
自定义Actor(B),用于接收消息并处理。
/**
* 自定义一个Actor,接收String类数据并处理
*/
public class MyActorB extends AbstractActor {
@Override
public Receive createReceive() {
return receiveBuilder().match(String.class,result->{
System.out.println("Actor B 接收到消息:" + result);
}).build();
}
}
第三步
给自定义的Actor发消息
public static void main(String[] args) {
//定义一个Actor管理仓库
ActorSystem system = ActorSystem.create("sys");
//将自定义的Actor放入仓库并起个名字
ActorRef actorDemo = system.actorOf(Props.create(MyActorA.class), "actorDemo");
//发送消息
actorDemo.tell("你好",ActorRef.noSender());
}
远程调用
可以通过Actor的地址调用。
public static void main(String[] args) {
ActorSystem actorSystem = ActorSystem.create("actorsystem");
ActorRef actorRef = actorSystem.actorOf(Props.create(Actor1.class));
System.out.println(actorRef);
//actorRef = akka://actorsystem/user/$a#424346408
//远程调用
ActorSelection actorSelection = actorSystem.actorSelection("akka://actorsystem/user/actorsystem");
//支持通配符
//ActorSelection actorSelection = actorSystem.actorSelection("akka://actorsystem/user/actorsystem*");
actorSelection.tell("Message",ActorRef.noSender());
}
版权声明:本文为u014386444原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。