|
Akka/Scala example source code file (FactorialBackend.scala)
The FactorialBackend.scala Akka example source codepackage sample.cluster.factorial import scala.annotation.tailrec import scala.concurrent.Future import com.typesafe.config.ConfigFactory import akka.actor.Actor import akka.actor.ActorLogging import akka.actor.ActorSystem import akka.actor.Props import akka.pattern.pipe //#backend class FactorialBackend extends Actor with ActorLogging { import context.dispatcher def receive = { case (n: Int) => Future(factorial(n)) map { result => (n, result) } pipeTo sender() } def factorial(n: Int): BigInt = { @tailrec def factorialAcc(acc: BigInt, n: Int): BigInt = { if (n <= 1) acc else factorialAcc(acc * n, n - 1) } factorialAcc(BigInt(1), n) } } //#backend object FactorialBackend { def main(args: Array[String]): Unit = { // Override the configuration of the port when specified as program argument val port = if (args.isEmpty) "0" else args(0) val config = ConfigFactory.parseString(s"akka.remote.netty.tcp.port=$port"). withFallback(ConfigFactory.parseString("akka.cluster.roles = [backend]")). withFallback(ConfigFactory.load("factorial")) val system = ActorSystem("ClusterSystem", config) system.actorOf(Props[FactorialBackend], name = "factorialBackend") system.actorOf(Props[MetricsListener], name = "metricsListener") } } Other Akka source code examplesHere is a short list of links related to this Akka FactorialBackend.scala source code file: |
... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2024 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.