iluwatar / java-design-patterns

Design patterns implemented in Java
https://java-design-patterns.com
Other
92.03k stars 27.04k forks source link

Microservice pattern: Remote procedure invocation #2680

Open iluwatar opened 1 year ago

iluwatar commented 1 year ago

Description

The Microservices - Remote Procedure Invocation (RPI) design pattern is crucial for enabling microservices to communicate effectively in a distributed system. This pattern allows a program to cause a procedure to execute in another address space (commonly on another physical machine). The procedure call is abstracted to appear as a local function call, though it is executed remotely.

Main Elements of the Pattern:

  1. Service Definition: Defines the methods and parameters that can be called remotely.
  2. Client Proxy: Acts as a local representative for the remote service. It abstracts the complexity of remote communication.
  3. Network Protocol: Handles the transmission of requests and responses between client and server.
  4. Server Stub: Unpacks the requests, executes the corresponding service methods, and packs the results to be sent back to the client.
  5. Serialization/Deserialization: Transforms data structures or objects into a format that can be easily transmitted and reconstructed.
  6. Error Handling: Manages issues like network failures, timeouts, and service unavailability.

References

Acceptance Criteria

  1. Implement a basic example of the RPI design pattern demonstrating remote communication between microservices.
  2. Include comprehensive unit and integration tests to ensure reliable communication and proper error handling.
  3. Update the project documentation to include an explanation of the RPI pattern, its implementation details, and usage instructions.
CoderSleek commented 8 months ago

Hey @iluwatar , I would like to take up this issue.

stale[bot] commented 6 months ago

This issue has been automatically marked as stale because it has not had recent activity. The issue will be unassigned if no further activity occurs. Thank you for your contributions.

CoderSleek commented 6 months ago

still working on it, the stale label can be removed

github-actions[bot] commented 4 months ago

This issue is stale because it has been open 60 days with no activity.

CoderSleek commented 3 months ago

Hey @iluwatar, apologies for the long time I took to raise the PR it was work in progress. I have attached a PR that closes the issue, would like to request review

Help wanted label can be removed and can be assigned back to me!

github-actions[bot] commented 1 month ago

This issue is stale because it has been open 60 days with no activity.