MultiJav: A distributed shared memory system based on multiple Java virtual machinesReservation-based totally ordered multicasting