Jolie (programming language) explained

Jolie
Paradigms:Microservices, SOA
Designer:
  • Claudio Guidi
  • Fabrizio Montesi
Developer:Fabrizio Montesi
Latest Release Version:1.11.0
Programming Language:Java
Platform:Java
License:LGPLv2
File Ext:.ol, .iol, .jap
File Formats:-->

Jolie (Java Orchestration Language Interpreter Engine[1]) is an open-source[2] programming language for developing distributed applications based on microservices. In the programming paradigm proposed with Jolie, each program is a service that can communicate with other programs by sending and receiving messages over a network. Jolie supports an abstraction layer that allows services to communicate using different mediums, ranging from TCP/IP sockets to local in-memory communications between processes.[3] [4]

Jolie is currently supported by an interpreter implemented in the Java language, which can be run in multiple operating systems including Linux-based operating systems, OS X, and Windows.[5] The language comes with formal semantics, meaning that the execution of Jolie programs is mathematically defined. For this reason, Jolie is used in research for the investigation of language-based techniques for the development of distributed systems,[6] and it is also used for teaching at some universities.[7]

The Jolie open source project was started by Fabrizio Montesi in 2006, as part of his studies at the University of Bologna. The project initially began as an implementation of the SOCK process calculus, a formal model proposed by Claudio Guidi et al. at the University of Bologna[8] [9] inspired by the CCS process calculus and the WS-BPEL programming language. Jolie extends SOCK with support for, e.g., tree-like data structures (inspired by XML, but with a syntax resembling that of C and Java), message types, typed session programming, integration with Java and JavaScript, code mobility, application containment, and web programming.[10] [11] A complete list of the project contributors is available at.[12]

The project is currently maintained by Fabrizio Montesi and its evolution is driven by Fabrizio Montesi and Claudio Guidi.

Since it supports the orchestration of web services, Jolie is an alternative to XML-based orchestration languages such as WS-BPEL as it offers a concise (C-like) syntax for accessing XML-like data structures.

Notes and References

  1. Montesi . Fabrizio . Guidi . Claudio . Lucchi . Roberto . Zavattaro . Gianluigi . JOLIE: a Java Orchestration Language Interpreter Engine . . 181 . 2007 . 19–33 . 1571-0661 . 10.1016/j.entcs.2007.01.051 . 10.1.1.408.2052.
  2. Web site: Jolie Project . SourceForge.
  3. Montesi . Fabrizio . Jolie: a Service-oriented Programming Language . 2010 . .
  4. Book: Montesi . Fabrizio . Guidi . Claudio . Zavattaro . Gianluigi . Service-Oriented Programming with Jolie . 2014 . Bouguettaya . Athman . Sheng . Quan Z. . Daniel . Florian . Web Services Foundations . 81–107 . 10.1007/978-1-4614-7518-7_4 . 978-1-4614-7517-0.
  5. Web site: Jolie Programming Language .
  6. Web site: Chor Programming Language .
  7. Web site: Jolie Programming Language - Academia .
  8. Guidi . Claudio . Lucchi . Roberto . Gorrieri . Roberto . Busi . Nadia . Zavattaro . Gianluigi . SOCK: A Calculus for Service Oriented Computing . ICSOC'06 . . 4294 . 2006 . 327–338 . 0302-9743 . 10.1007/11948148_27 . 10.1.1.102.6297.
  9. Guidi . Claudio . 2007 . Formalizing languages for service oriented computing . 10.6092/unibo/amsdottorato/373.
  10. Montesi . Fabrizio . Process-aware web programming with Jolie . 2013 . SAC'13 . 761–763 . 10.1145/2480362.2480507 . 1410.3712.
  11. Montesi. Fabrizio. Process-aware Web Programming with Jolie. Science of Computer Programming. 2016. 130. 69–96. 1410.3712. 10.1016/j.scico.2016.05.002.
  12. Web site: Jolie Programming Language - About Jolie .