380 likes | 551 Views
Actor Frameworks for the JVM Platform. Rajesh Karmani*, Amin Shali, Gul Agha University of Illinois at Urbana-Champaign 08/27/2009. Multi-core, many-core programming. Erlang E Axum Stackless Python Theron (C++) RevActor (Ruby) … still growing. and on the JVM. Scala Actors
E N D
Actor Frameworks for the JVM Platform Rajesh Karmani*, Amin Shali, Gul Agha University of Illinois at Urbana-Champaign 08/27/2009
Multi-core, many-core programming • Erlang • E • Axum • Stackless Python • Theron (C++) • RevActor (Ruby) • … still growing
and on the JVM • Scala Actors • ActorFoundry • SALSA • Kilim • Jetlang • Actor’s Guild • Clojure • Fan • Jsasb • … still growing
Actor model of programming • Autonomous, concurrent actors Inherently concurrent model of programming • No shared state No data races • Asynchronous message-passing Uniform, high-level primitive for both data exchange and synchronization “Actors: A Model of Concurrent Computation in Distributed Systems," Gul Agha. MIT Press,1986.
Actor anatomy Actors = encapsulated state + behavior + independent control + mailbox Object
Standard Actor Semantics • Encapsulation • Fairness • Location Transparency • Mobility
Actor Encapsulation • There is no shared state among actors • Local (private) state • Access another actor’s state only by sending messages • Messages have send-by-value semantics • Implementation can be relaxed on shared memory platforms, if “safe”
Why Encapsulation? • Reasoning about safety properties becomes “easier” • JVM memory safety is not sufficient for Actor semantics • Libraries like Scala and Kilim impose conventions instead of enforcement • Makes it easier to make mistakes
Fairness – even the playing field • Permanently Disabled Actor: An actor which is executing an infinite loop, blocked on a external call, or in a deadlock • Enabled Actor: An actor that • Is not permanently disabled, AND • Has a pending message • Scheduling fairness: An enabled actor is eventually scheduled
Fairness – even the playing field • Non-cooperating actors can occupy a native thread indefinitely • I/O and System calls, Infinite loops • Non-cooperating actors can starve enabled actors, in the absence of scheduling fairness • Fairness specially critical in libraries for existing languages • Interaction with existing code-base, plug-ins, 3rd party components
Why Location Transparent Naming? • Enables certain load-balancing and fault-tolerance mechanisms • Run-time can exploit resources available on cluster, grid or scalable multicores (distributed memory) • Potentially better performance • Uniform model for multicore and distributed programming
Why Mobility? • Weak mobility • Allow system to run-time to move actors around based on run-time conditions (also system mobility) • Previous work has shown good performance improvement when augmented with dynamic load balancing techniques1 • Strong mobility • Allow programmers to exploit heterogeneous resources declaratively (also programmer mobility) • Privacy of data • Large amounts of data • Note: Requires encapsulation for efficiency 1 “Efficient Support for Location Transparency in Concurrent Object-Oriented Programming Languages”, Kim et al., SC 1995.
ActorFoundry • Off-the-web library for Actor programming • Major goals: Usability and Extensibility • Other goals: Reasonable performance • Supports standard Actor semantics
Actor Anatomy (Encapsulation) Actor Name Actor Name Actor Name Actor Name Actor Name Actor Control send create Actor Mailbox dequeue and invoke
ActorFoundry – Programming Model • Actors are like objects • Implicit ‘receive’ • Run-time provides fetch-decode loop • One-to-one correspondence between message and Java method • Primitives for asynchronous (send) as well as synchronous (call) messages • Wraps standard IO objects as actors (stdout, stdin, stderr actors)
ActorFoundry - basic API • create(node, class, params) • Locally or at remote nodes • send(actor, method, params) • call(actor, method, params) • Request-reply messages • destroy(reason) • Explicit memory management
ActorFoundry - Implementation • Maps each actor onto a Java thread • Actor = Java Object + Java Thread + Mailbox + ActorName • ActorName provides encapsulation as well as location transparency • Message contents are deep copied • Fairness: Reliable delivery (but unordered messages) and fair scheduling • Support for distribution and actor migration
ActorFoundry - Architecture TCP, UDP Broker, Shell
Motivation Revisited – Why ActorFoundry? • Extensibility • Modular and hence extensible • Usability • Actors as objects + small set of library calls • Leverage Java libraries and expertise • Performance • Let’s check…
Great Language Shootout • Ported ActorFoundry to Java6 • The Computer Language Benchmarks Game [2] • Implemented a concurrent benchmark in ActorFoundry: Thread-ring • Thread-ring: Pass a token around 503 concurrent entities 107 times [2] http://shootout.alioth.debian.org/
and now in a Chart Coarse-grained actors + Support for standard semantics Intel Core2 Duo, 2.4GHz, 4GB RAM, Java Heapsize: 256M
The quest for Continuations • Kilim - Actor library2 for Java • Consists of a run-time and a “Weaver” (bytecode post-processor) for CPS transform • With a custom continuations based scheduler • M:N architecture • Credit to the extensible architecture • Threadring performance: ~ 7 minutes 2 http://kilim.malhar.net
M:N Runtime Architecture Worker Threads Run-time (+ Scheduler) JVM OS 1 2 3 4 5 6 Cores
M:N Runtime Architecture Worker Threads Run-time (+ Scheduler) JVM OS 1 2 3 4 5 6 Cores
M:N Runtime Architecture Worker Threads Run-time (+ Scheduler) JVM OS 1 2 3 4 5 6 Cores
To copy or not to copy? • Another major bottleneck: deep copying of message contents • By serializing/de-serializing object
To copy or not to copy? • Exclude immutable types • Introduced new run-time functions: • sendByRef (actor, method, params) • callByRef (actor, method, params) • Threadring performance: ~ 30s • Scala, Kilim provide zero-copy messages • Onus on programmers to copy contents, if needed • Breaks encapsulation, infeasible in general
Fairness – ActorFoundry approach • Scheduler thread periodically monitors “progress” of worker threads • Progress means executing an actor from schedule queue • If no progress has been made by any worker thread => possible starvation • Launch a new worker thread • Conservative but not incorrect
Performance – crude comparison Threadring benchmark on Intel Core2 Duo, 2.4GHz, 4GB RAM, Heapsize: 256M
Performance – crude comparison Chameneos-redux benchmark on Intel Core2 Duo, 2.4GHz, 4GB RAM, Heapsize: 256M
Actor Foundry - Discussion • Elegant, object-like syntax and implicit control • Leverage existing Java code and libraries • Zero-copy as well as by-copy message passing • Reasonably efficient run-time • With encapsulation and fair scheduling • Support for distributed actors, migration • Modular and extensible
Using Actor Foundry • Download binary distribution3 • Win32, Solaris, Linux, MacOS • Bundled with a bunch of example programs • Ant build.xml file included • Launch foundry node manager • Specify the first actor and first message • Launch ashell for command-line interaction with foundry node (optional) 3 http://osl.cs.uiuc.edu/af
Performance - Can we do better? • Possibly, with a locality-aware scheduler • Distribute shared memory among worker threads • ..each with a separate scheduling queue • Reduces contention and improves locality • Augment with migration logic for dynamic load-balancing
Proposed Runtime Architecture Worker Threads Run-time (+ Scheduler) JVM OS OS 1 2 3 4 5 6 Cores
Promise for scalable performance? • Over-decompose application into fine-grained actors • As the number of cores increase, spread out the actors • Of course, speed-up is constrained by parallelism in application • Parallelism is bounded by # of actors
Other Future Directions • Garbage collection • Debugging • Automated testing • Model checking • Type-checking messages • Support for ad-hoc actor definitions
References [1] Gul Agha. Actors: a model of concurrent computation in distributed systems. MIT Press, Cambridge, MA, USA, 1986. [2] Rajesh K. Karmani, Amin Shali, and Gul Agha. Actor frameworks for the JVM platform: a comparative analysis. In PPPJ ’09: Proceedings of the 7th International Conference on Principles and Practice of Programming in Java, 2009. ACM. [3] Gul Agha, Ian A. Mason, Scott Smith, and Carolyn Talcott. A Foundation for Actor Computation. Journal of Functional Programming, 1997. [4] Rajendra Panwar and Gul Agha. A methodology for programming scalable architectures. In Journal of Parallel and Distributed Computing, 1994.