Akka配置Dispatcher(二)

Akka配置Dispatcher(二)

Akka中有四种Dispatcher,请看这里http://my.oschina.net/xinxingegeya/blog/367320

下面是一个示例配置文件,名字是akka默认加载的位于classpath下的文件:application.conf,如下,

MyDispatcherExample {
  defaultDispatcher {
    type = Dispatcher
    executor = "fork-join-executor"
    fork-join-executor {
      parallelism-min = 2
      parallelism-factor = 2.0
      parallelism-max = 6
    }
  }

  defaultDispatcher1 {
    type = Dispatcher
    executor = "thread-pool-executor"
    thread-pool-executor {
      core-pool-size-min = 1
      core-pool-size-factor = 2.0
      core-pool-size-max = 6
    }
  }
  pinnedDispatcher {
    type = PinnedDispatcher
    executor = "thread-pool-executor"
    thread-pool-executor {
      core-pool-size-min = 2
      core-pool-size-factor = 2.0
      core-pool-size-max = 10
    }
    throughput = 5
  }
  balancingDispatcher {
    type = BalancingDispatcher
    executor = "thread-pool-executor"
    thread-pool-executor {
      core-pool-size-min = 1
      core-pool-size-factor = 2.0
      core-pool-size-max = 2
    }
    throughput = 5
  }
  balancingDispatcher1 {
    type = BalancingDispatcher
    executor = "fork-join-executor"
    fork-join-executor {
      parallelism-min = 2
      parallelism-factor = 2.0
      parallelism-max = 6
    }
    throughput = 5
  }
  CallingThreadDispatcher {
    type = akka.testkit.CallingThreadDispatcherConfigurator
  }
}


关于fork-join-executor,也就是Fork/Join并发框架,在这里

http://my.oschina.net/xinxingegeya/blog/370716

如何加载这个配置,如下代码,

/**
 * Hello world!
 */
public class Example1 {
    public static void main(String[] args) {

        /**
         * MyDispatcherExample节点下的配置项
         */
        ActorSystem _system = ActorSystem.create("default-dispatcher",
                ConfigFactory.load().getConfig("MyDispatcherExample"));

        /**
         * 加载defaultDispatcher下的配置项
         */
        ActorRef actor = _system.actorOf(new Props(MsgEchoActor.class)
                .withDispatcher("defaultDispatcher").withRouter(
                        new RoundRobinRouter(5)));

        for (int i = 0; i < 25; i++) {
            actor.tell(i);
        }

        _system.shutdown();
    }
}

=================END=================

转载于:https://my.oschina.net/xinxingegeya/blog/370781

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值