The RMI architecture is based on one significant principle: the definition of behavior and the execution of that behavior are separate concepts. RMI allows the code that describes the behavior and the code that executes the behavior to remain separate and to run on split JVMs.