actor 模型 锁 java_Java Actor简介

▲▲▲

Actor就是一个工人,能够不停的接受任务(消息),处理任务,任务结束以后以 消息的形式通知给别的actor。

用一个餐厅的场景来描述:

4bc2742f9716a33f9ea95a85fd384a06.png

假设餐厅只有三个人,客人、服务员、厨师。我们把这三个人描述为三个actor,

其中服务员和厨师都有自己的工作信箱,他们的工作交互流程概述如下:

❶ 客人选好菜下单,把新订单消息发送到服务员的信箱中。

❷ 服务员收到消息,有新的订单,获取订单信息,然后确认用户的订单,挑选出需要厨师烹饪的菜,然后把烹饪菜肴的订单消息发送到厨师的信箱中。

❸ 厨师收到消息,有新的烹饪消息,获取订单信息,根据客户的需求烹饪完成之后,发送食物准备好了的消息发送给服务员。

❹ 服务员收到消息,获取订单信息,发现是上菜的订单,服务员去厨房取出食物,然后交给客人。

从以上的交互看出,每个actor都是独立的,只关心自己的状态和任务列表,按照自己速度有序的处理工作任务,这样整个系统就能并行的完成任务。

假设餐厅的客人越来越多,一个厨师无法快速的烹饪所有的菜肴,我们可以根据实际情况,增加厨师的个数,厨师之间按照某种规则来分摊订单的请求。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Dapr 是一个分布式应用程序运行时,它提供了一组构建微服务应用程序所需的基本功能。其中之一是 Actor,它是一种用于构建高度可伸缩和高可用性的分布式应用程序的编程模型。在 Java 中,您可以使用 Dapr Java SDK 来编写 Actor 应用程序。 以下是使用 Dapr Java SDK 编写 Actor 应用程序的步骤: 1. 添加 Dapr 依赖项 在 Maven 或 Gradle 项目中,您需要添加以下依赖项: Maven: ```xml <dependency> <groupId>io.dapr</groupId> <artifactId>dapr-sdk</artifactId> <version>0.30.0</version> </dependency> ``` Gradle: ```groovy implementation 'io.dapr:dapr-sdk:0.30.0' ``` 2. 创建 Actor 接口 创建一个 Java 接口,它将作为 Actor 的契约。例如: ```java public interface MyActor { CompletableFuture<String> sayHello(String name); } ``` 3. 实现 Actor 接口 创建一个实现 Actor 接口的 Java 类。例如: ```java public class MyActorImpl implements MyActor { @Override public CompletableFuture<String> sayHello(String name) { return CompletableFuture.completedFuture("Hello, " + name + "!"); } } ``` 4. 注册 Actor 在应用程序启动时,使用 Dapr Java SDK 将 Actor 注册到 Dapr 中。例如: ```java public class MyApp { private static final String APP_ID = "myapp"; private static final String ACTOR_TYPE = "myactor"; public static void main(String[] args) throws Exception { MyActorImpl actor = new MyActorImpl(); ActorRuntime.getInstance().registerActor(actor, ActorRegistration.newBuilder() .withActorType(ACTOR_TYPE) .withActorIdProvider(new RandomActorIdProvider()) .build()); // Wait for shutdown signal ActorRuntime.getInstance().waitForShutdown(); } } ``` 在上面的代码中,我们将 `MyActorImpl` 类注册为 Actor,并指定 Actor 的类型为 `myactor`。我们还指定了一个随机的 Actor ID 提供程序,以便在创建 Actor 时为其分配唯一的 ID。 5. 调用 Actor 使用 Dapr Java SDK 调用 Actor。例如: ```java public class MyAppClient { private static final String APP_ID = "myapp"; private static final String ACTOR_TYPE = "myactor"; private static final String ACTOR_ID = "actor1"; public static void main(String[] args) throws Exception { MyActor myActor = ActorBuilder .actorFor(MyActor.class, new URI("http://localhost:3500"), ACTOR_TYPE, ACTOR_ID) .build(); String result = myActor.sayHello("World").get(); System.out.println(result); } } ``` 在上面的代码中,我们使用 `ActorBuilder` 创建一个 `MyActor` 类型的 Actor,并指定 Actor 的类型为 `myactor`,Actor ID 为 `actor1`。然后我们调用 `sayHello` 方法,并等待返回结果。 这就是使用 Dapr Java SDK 编写 Actor 应用程序的基本步骤。在实际应用中,您可能需要使用更多的 Dapr 功能来管理 Actor 的生命周期、持久性、状态等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值