pony - PowerPoint PPT Presentation

About This Presentation
Title:

pony

Description:

pony The occam-p. Network Environment. A Unified Model for Inter- and ... The basic communication primitive between occam-p processes in pony are channel-types ... – PowerPoint PPT presentation

Number of Views:63
Avg rating:3.0/5.0
Slides: 41
Provided by: mariosch
Category:
Tags: pony

less

Transcript and Presenter's Notes

Title: pony


1
pony The occam-pNetwork EnvironmentA Unified
Model for Inter- andIntra-processor Concurrency
  • Mario Schweigler
  • Computing Laboratory, University of Kent
  • Canterbury, UK

2
Contents
  • What is pony?
  • Why do we need a unified concurrency model?
  • Using pony
  • Implementation of pony
  • Conclusions and future work

3
What is pony?
  • Network environment for occam-p
  • (Name anagram of occam, pi, network, y)
  • (Formerly known as KRoC.net)
  • Allows a unified approach for inter- and
    intra-processor concurrency

4
The Need for a Unified Concurrency Model
  • It should be possible to distribute applications
    across several processors (or back to a single
    processor) without having to change the
    components
  • This transparency should not damage the
    performance
  • The underlying system should apply the overheads
    of networking only if needed in a concrete
    situation this should be determined dynamically
    at runtime

5
pony Applications
  • A pony application consists of several nodes
  • There are master and slave nodes each
    application has one master node and any number of
    slave nodes
  • Applications are administrated by an Application
    Name Server (ANS) which stores the network
    location of a master for a given application-name
    and allows slave nodes to look up the master

6
Network-channel-types
  • The basic communication primitive between occam-p
    processes in pony are channel-types
  • A network-channel-type (NCT) is the networked
    version of an occam-p channel-type
  • It is transparent to the programmer whether a
    given channel-type is an intra-processor
    channel-type or an NCT

7
Network-channel-types
  • NCTs have the same semantics and usage as normal
    channel-types
  • Bundle of channels
  • Two ends, each of which may be shared
  • Ends are mobile
  • Ends may reside on different nodes, and may be
    moved to other nodes

8
Transparency in pony
  • Semantic transparency
  • All occam-p PROTOCOLs can be communicated over
    NCTs
  • Semantics of communicated items are preserved,
    including MOBILE semantics
  • Handling of NCTs is transparent to the programmer
  • NCT-ends may be shared, like any other
    channel-type-end
  • NCT-ends are mobile, like any other
    channel-type-end, and can be communicated across
    distributed applications in the same way as
    between processes on the same node

9
Transparency in pony
  • Pragmatic transparency
  • pony infrastructure is set up dynamically when
    needed
  • If sender and receiver are on the same node,
    communication only involves traditional
    channel-word access
  • If they are on different nodes, communication
    goes through the pony infrastructure (and the
    network)

10
NCTs and CTBs
  • A network-channel-type (NCT) is a logical
    construct that comprises an entire networked
    channel-type
  • Has a unique ID (and a unique name if allocated
    explicitly) across a pony application
  • A channel-type-block (CTB) is the memory block of
    a channel-type on an individual node
  • Either the only CTB of an intra-processor
    channel-type
  • Or one of possibly many CTBs of an NCT

11
Using pony
  • There are a number of public processes for
  • Starting pony
  • Explicit allocation of NCT-ends
  • Shutting down pony
  • Error-handling
  • Message-handling

12
Starting pony
  • Startup processes
  • pony.startup.(us)nh.(us)eh.iep.mh
  • Returns
  • A (possibly shared) network-handle
  • Used for allocation and shutdown
  • A (possibly shared) error-handle if required
  • Used for error-handling
  • A message-handle if required
  • Used for message-handling

13
Starting pony
  • Startup process contacts the ANS
  • If our node is the master, its location is stored
    by the ANS
  • If our node is a slave
  • Startup process gets location of master from ANS
  • Connects to master
  • On success, startup process starts pony kernel
    and returns the requested handles
  • Otherwise returns error

14
Explicit Allocation of NCT-ends
  • Allocation processes
  • pony.alloc.(us)(cs)
  • The ends of an NCT may be allocated on different
    nodes at any given time
  • Allocation process communicates with pony kernel
    via network-handle
  • Versions for unshared/shared client-ends/server-en
    ds
  • An explicitly allocated NCT is identified by a
    unique NCT-name stored by the master node

15
Explicit Allocation of NCT-ends
  • If parameters are valid, allocation process
    allocates and returns the NCT-end
  • Allocation process returns error if there is a
    mismatch with previously allocated ends of the
    same name, regarding
  • Type of the channel-type
  • Shared/unshared properties of its ends

16
Implicit Allocation by Moving
  • Any channel-type-end, including NCT-ends, may be
    moved along a channel
  • If an end of a locally declared channel-type is
    moved to another node (along a channel of an NCT)
    for the first time, this channel-type is
    implicitly allocated by the pony kernel
  • That channel-type automatically becomes an NCT
  • Programmer does not need to take any action
    himself
  • Does not even need to be aware whether the end is
    sent to a process on the same or on a remote node

17
Implicit Allocation by Moving
  • If an end of an NCT arrives at a node for the
    first time, an new CTB for that NCT is allocated
    on the receiving node
  • Again, this is transparent for the occam-p
    programmer the process receiving the end does
    not need to be aware whether it is coming from a
    process on the same node or on a remote node

18
Shutting down pony
  • Shutdown process
  • pony.shutdown
  • Shutdown process communicates with pony kernel
    via network-handle
  • Must be called after all activity on (possibly)
    networked channel-types has ceased
  • If node is master, pony kernel notifies the ANS
    about the shutdown
  • pony kernel shuts down its internal components

19
Error-handling
  • Used for the detection of networking errors
    during the operation of pony applications
    (logical errors are handled by suitable results
    returned by the public pony processes, see above)
  • Not transparent because there is currently no
    built-in error-handling or fault-tolerance
    mechanism in occam-p on which ponys
    error-handling could be built

20
Error-handling
  • Programmer can
  • Either do it the traditional occam-p way,
    namely trust that there will be no errors and
    live with the consequences otherwise
  • Or use ponys (non-transparent) error-handling
    mechanism to detect possible networking errors

21
Error-handling
  • If an error-handle was requested from the startup
    process, the pony kernel has started an
    error-handler
  • Error-handler stores networking errors that occur
  • Error-handling processes
  • pony.err.
  • They use the error-handle to communicate with the
    error-handler

22
Error-handling
  • Error-handling mechanism
  • Set error-point before an operation (an initial
    error-point may be returned by the startup
    process)
  • Do operation, wait for it to complete (maybe set
    a timeout this is up to the programmer and not
    part of pony)
  • If needed (maybe after a timeout has expired),
    check for errors that happened after a given
    error-point

23
Error-handling
  • pony errors are records containing information
    about the type of error, as well as about the
    remote node involved
  • Programmer can find out about the current remote
    node of a given NCT and only check for errors
    that involve that particular node

24
Message-handling
  • Used for outputting messages from the pony kernel
  • Status messages
  • Error messages
  • If a message-handle was requested from the
    startup process, the pony kernel has started a
    message-handler
  • Message-handler stores messages from the pony
    kernel

25
Message-handling
  • Message-outputters
  • pony.msg.out.(us)(o.(us)ee)
  • They use the message-handle to communicate with
    the message-handler
  • Run in parallel with everything else
  • Status messages are outputted to a (possibly
    shared) output channel (typically stdout)
  • Error messages are outputted to a (possibly
    shared) error channel (typically stderr)

26
Configuration
  • Done via simple configuration files
  • Used to configure
  • Network location of a node
  • Network location of the ANS
  • All settings may be omitted
  • In this case either defaults are used or the
    correct setting is detected automatically

27
Implementation of pony
  • Internal components of pony
  • Main kernel
  • Protocol-converters
  • Decode-handler and encode-handler
  • CTB-handler and CTB-manager
  • NCT-handler and NCT-manager
  • Link-handler and link-manager
  • Error-handler
  • Message-handler

28
Main pony Kernel
  • Interface between the public processes and the
    internal pony components
  • Deals with
  • Explicit allocation of NCT-ends
  • Shutdown

29
Protocol-converters
  • Protocol-decoder and protocol-encoder
  • Implemented in C using the occam-pC interface
    (CIF)
  • Interface between the occam-p world and pony
  • Service one individual channel of a CTB
  • Provide PROTOCOL transparency by decoding any
    given occam-p PROTOCOL to a format used
    internally by pony, and reverse

30
Decode-handler andEncode-handler
  • Interface between the protocol-converters and the
    CTB-handler
  • Deal with
  • Efficient handling of networked communications
    over a channel of an NCT
  • Movement of NCT-ends
  • Implicit allocation of NCT-ends if applicable
    (see above)

31
CTB-handler and CTB-manager
  • CTB-handler deals with
  • Claiming and releasing ends of an individual CTB
  • Communication over its channels
  • CTB-manager
  • Manages CTB-handlers on a node
  • Creates new ones if a new networked CTB appears
    on a node (explicitly or implicitly)

32
NCT-handler and NCT-manager
  • Reside on master node
  • NCT-handler
  • Deals with claiming and releasing NCT-ends
  • Keeps queues of nodes that have claimed the
    client-end or the server-end of an NCT
  • Equivalent of the client- and server-semaphores
    of an intra-processor CTB
  • NCT-manager
  • Manages NCT-handlers
  • Creates new ones if a new NCT is allocated
    (explicitly or implicitly)

33
Link-handler and Link-manager
  • Link-handler
  • Handles a link between two nodes
  • All network communication between these two nodes
    is multiplexed over that link
  • Link-manager
  • Manages link-handlers
  • Creates new ones if a new link is established to
    another node

34
Modular Design of pony
  • Link-handler, link-manager and ANS are specific
    for a particular network-type
  • Currently supported TCP/IP
  • All other components of pony are not
    network-type-specific
  • Supporting other network-types only requires
    rewriting the network-type-specific components
  • They communicate with the non-network-type-specifi
    c components of pony via the same interface

35
Error-handler andMessage-handler
  • Error-handler
  • Stores networking errors
  • Interface between internal pony components and
    public error-handling processes
  • Message-handler
  • Stores status and error messages
  • Interface between internal pony components and
    message-outputters

36
Conclusions
  • pony and occam-p provide a unified concurrency
    model for inter- and intra-processor applications
  • Achieving semantic and pragmatic transparency
  • Simple handling of pony for the occam-p
    programmer
  • Minimum number of public processes for basic
    operations (startup, explicit allocation, etc.)
  • Runtime operation handled automatically and
    transparently by the pony kernel
  • Simple (mostly automatic) configuration

37
Future Work
  • Adding support for new occam-p features (which
    are added to occam-p currently or in the future)
  • Mobile processes
  • Mobile barriers
  • Enhancing ponys error-handling (making it
    transparent) by supporting proposed built-in
    occam-p fault-tolerance mechanisms

38
Future Work
  • Enhancing performance
  • Enhancing network latency by supporting proposed
    occam-p features such as BUFFERED channels and
    behaviour patterns (for ping-pong style
    communication)
  • Supporting the proposed GATE/HOLE mechanism in
    occam-p by not setting up the internal pony
    components for a networked CTB until one of its
    ends is used for communication (i.e. not if an
    NCT-end is just passing through a node)

39
Future Work
  • Enhancing performance
  • Adding a new LOCAL keyword to occam-p to allow
    the declaration of non-networkable
    channel-type-ends without the overheads that are
    necessary for networkable ones
  • Integrating pony into RMoX
  • Due to ponys modular design, only the
    network-type-specific components need to be
    adapted

40
Future Work
  • Other things
  • Adding support for networked plain channels
    fairly straightforward, using anonymous
    channel-types similar to the SHARED CHAN
    approach
  • Support for platforms with different endianisms
  • Support for security, encryption
  • Support for launching nodes automatically(e.g.
    by using Grid-style cluster management)
  • Support for Zeroconf-style setup on local
    clusters(i.e. without the need for the ANS)
Write a Comment
User Comments (0)
About PowerShow.com