Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
梦境迷离
Cs Summary Reflection
提交
e1de7d2d
C
Cs Summary Reflection
项目概览
梦境迷离
/
Cs Summary Reflection
11 个月 前同步成功
通知
4
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
C
Cs Summary Reflection
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
e1de7d2d
编写于
10月 24, 2019
作者:
梦境迷离
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix Akka的信箱,时间:2019-10-24 22:27:37
上级
ac1d21df
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
5 addition
and
19 deletion
+5
-19
docs/_posts/2019-10-22-Akka-Actor的调度器.md
docs/_posts/2019-10-22-Akka-Actor的调度器.md
+5
-19
未找到文件。
docs/_posts/2019-10-22-Akka-Actor的调度器.md
浏览文件 @
e1de7d2d
...
...
@@ -102,7 +102,7 @@ val myActor =
*
可共享性:不受限
*
邮箱:任意,为每个actor创建一个
*
使用场景:默认分派器,bulkheading
*
底层实现:
`java.util.concurrent.executorService`
。使用“fork join executor”、“fork-join-executor”或
`akka.dispatcher.ExecutorServiceConfigurator`
的FQCN指定使用“executor”。
*
底层实现:
java.util.concurrent.executorService。使用“fork join executor”、“fork-join-executor”或akka.dispatcher.ExecutorServiceConfigurator
的FQCN指定使用“executor”。
*
PinnedDispatcher
这个Dispatcher为使用它的每个actor指定了一个唯一的线程;也就是说,每个actor都将有自己的线程池,其中只有一个线程在池中。
*
可共享性:无
...
...
@@ -204,7 +204,7 @@ val myActor =
注意:根据上面的my-thread-pool-dispatcher示例,thread-pool-executor配置是不适用的。这是因为当使用PinnedDispatcher时,每个actor都会有自己的线程池,而这个线程池只有一个线程。
不能保证随着时间的推移使用相同的线程,因为PinnedDispatcher有超时设置,以便在空闲actor的情况下减少资源使用。要始终使用相同的线程,您需要向PinnedDispatcher的配置中添加
`thread-pool-executor.allow-core-timeout=off`
。
不能保证随着时间的推移使用相同的线程,因为PinnedDispatcher有超时设置,以便在空闲actor的情况下减少资源使用。要始终使用相同的线程,您需要向PinnedDispatcher的配置中添加
thread-pool-executor.allow-core-timeout=off
。
### 小心处理阻塞
...
...
@@ -272,7 +272,7 @@ for (i <- 1 to 100) {
}
```
在这里,应用程序向BlockingFutureActor和PrintActor发送100条消息,大量
`akka.actor.default-dispatcher`
线程正在处理请求。当您运行上述代码时,可能会看到整个应用程序被阻塞在这样的地方:
在这里,应用程序向BlockingFutureActor和PrintActor发送100条消息,大量
akka.actor.default-dispatcher
线程正在处理请求。当您运行上述代码时,可能会看到整个应用程序被阻塞在这样的地方:
```
> PrintActor: 44
...
...
@@ -328,19 +328,4 @@ class SeparateDispatcherFutureActor extends Actor {
* 在Future中执行阻塞调用,为线程池提供一个线程数量上限,这个上限适合于运行应用程序的硬件,如本节中详细解释的那样。
* 指定一个线程来管理一组阻塞资源(例如,NIO选择器驱动多个通道),并在actor消息出现时分派事件。
第一种可能性特别适合于具有单线程性质的资源,比如数据库句柄,传统上只能一次执行一个未执行的查询,并使用内部同步来确保这一点。一个常见的模式是为N个actor创建一个路由器,每个actor封装一个DB连接并处理发送给路由器的查询。然后,必须对数字N进行调优,以获得最大吞吐量,这取决于部署在哪个硬件上的DBMS。
第一种可能性特别适合于具有单线程性质的资源,比如数据库句柄,传统上只能一次执行一个未执行的查询,并使用内部同步来确保这一点。一个常见的模式是为N个actor创建一个路由器,每个actor封装一个DB连接并处理发送给路由器的查询。然后,必须对数字N进行调优,以获得最大吞吐量,这取决于部署在哪个硬件上的DBMS。
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录