Skip to main content

Event Driven Routing Infrastructure

Project description

Event Driven Routing Infrastructure (EDRI)

EDRI is a framework designed to simplify the development of parallel and distributed applications. It allows developers to efficiently run code across multiple threads, processes, or even machines by leveraging an event-driven architecture. EDRI emphasizes flexibility and scalability, enabling the development of systems that can handle complex workflows with ease.

The framework is ideal for applications that require high throughput, low latency, and the ability to scale horizontally across distributed systems. It is designed to handle dynamic, real-time data processing and communication through the use of well-defined events.

Key Features

  • Event-Driven Architecture: EDRI uses events as data packets to enable communication between multiple senders and recipients. Events can be notifications, requests, or tunnels, each serving a specific communication purpose.

  • Routing Infrastructure: The exchange and delivery of events are managed similarly to TCP/IP in computer networks. The router directs events to appropriate recipients based on event types, ensuring efficient communication.

  • Scalable Architecture: The framework supports running tasks as methods, threads, and processes, allowing for scalable and parallel execution of tasks across multiple computing nodes.

  • Flexible Components: EDRI includes various components such as Router, Manager, Worker, Scheduler, and Key-Value Store, each designed to handle specific responsibilities within the system.

Components

Event

Events are data packets created using Python data classes to enable communication between multiple senders and recipients. They serve as the core communication mechanism within EDRI and can be categorized into:

  • Notifications: Events that announce actions or changes in the system.
  • Requests: Events that solicit a response or action from another component.
  • Tunnels: Events that facilitate continuous data transfer between components.

Events are strictly defined to ensure clarity and consistency across the system. They can carry responses or simply announce actions, depending on their type.

Router

The Router is the central component responsible for forwarding events between different parts of the framework, typically managers. It ensures that events are delivered to the appropriate recipients based on their event types.

Key responsibilities of the Router include:

  • Directing events to the appropriate managers or workers.
  • Managing connections to external systems via the Connector.
  • Caching connections to handle short-term network outages without disrupting operations.

Connector

The Connector is a specialized part of the Router that manages the connection between the Router and external systems (referred to as the Switch). It handles:

  • Bridging internal communication with external networks using TCP/IP sockets.
  • Distributing routed events to other routers and vice versa.
  • Ensuring continuity of events to prevent loss or duplication during connection interruptions.

Manager

The Manager distributes tasks contained in the transmitted events to individual workers. It supports running tasks in various modes:

  • Methods: Tasks executed as regular function calls within the same process.
  • Threads: Tasks executed in separate threads for parallelism within the same process.
  • Processes: Tasks executed in separate processes for true parallelism across CPU cores.

The Manager also handles data transfer for tunnels and subscribes to the event types it needs to receive.

Scheduler

The Scheduler is a special type of Manager used for time-defined event sending. It enables scheduling tasks or events at specific times, such as:

  • Performing backups during off-peak hours.
  • Sending regular updates or heartbeat signals.

Key-Value Store

The Key-Value Store is another specialized Manager that provides a built-in storage mechanism for caching and retrieving data. It is useful for:

  • Caching data during processes like data downloads.
  • Periodically updating stored data using the Scheduler.
  • Sharing state or configuration data between components.

Worker

Workers are classes defined by the programmer to perform specific tasks or operations. They are the execution units in the EDRI framework and can be customized to handle a wide range of functionalities.

API

The API serves as the interface between clients and the EDRI system. It handles:

  • Converting incoming client requests into events.
  • Processing events through the system.
  • Returning responses back to the clients.

Features of the API include:

  • Support for dynamic content generation.
  • Management of event-based interactions, including both request-type and notification-type events.
  • Real-time communication capabilities between the server and clients.

Use Cases

EDRI is suitable for applications that require:

  • High Throughput and Low Latency: Efficient handling of a large number of events with minimal delay.
  • Real-Time Data Processing: Immediate processing and response to incoming data.
  • Horizontal Scalability: Ability to scale across multiple machines or nodes.
  • Complex Workflows: Management of intricate processes that benefit from an event-driven approach.

Getting Started

To start using EDRI:

  1. Define Your Events: Use Python data classes to define the events that will be used for communication between components.

  2. Set Up Your Router and Managers: Initialize the Router and any necessary Managers (including Scheduler and Key-Value Store if needed).

  3. Implement Your Workers: Create Worker classes that perform the specific tasks required by your application.

  4. Use the API: Utilize the API to interact with the system, handle client requests, and facilitate communication.

  5. Run and Monitor Your Application: Execute your application and monitor the event flow to ensure everything operates as expected.

Conclusion

EDRI provides a robust framework for developing scalable, parallel, and distributed applications using an event-driven architecture. By abstracting the complexities of inter-process and network communication, it allows developers to focus on implementing the core logic of their applications.

Whether you're building a real-time data processing system, a distributed service, or any application that benefits from parallel execution, EDRI offers the tools and structure to make development more manageable and efficient.

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

edri-2025.4.5.tar.gz (88.8 kB view details)

Uploaded Source

Built Distribution

edri-2025.4.5-py3-none-any.whl (117.3 kB view details)

Uploaded Python 3

File details

Details for the file edri-2025.4.5.tar.gz.

File metadata

  • Download URL: edri-2025.4.5.tar.gz
  • Upload date:
  • Size: 88.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for edri-2025.4.5.tar.gz
Algorithm Hash digest
SHA256 ae2dae59df45518844e4c226f443e187cd1cf20b436ec8199688624e4bef2228
MD5 b3660600ef2c6dae41e0c93749720431
BLAKE2b-256 32528fec6c31bd4e5d3ee610e728960826e59d96f623c2da7adc8fa1f000728f

See more details on using hashes here.

File details

Details for the file edri-2025.4.5-py3-none-any.whl.

File metadata

  • Download URL: edri-2025.4.5-py3-none-any.whl
  • Upload date:
  • Size: 117.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for edri-2025.4.5-py3-none-any.whl
Algorithm Hash digest
SHA256 fe53e9393014e0f09dbefcab746d331b74d1e368d1fec0d7c7d2fcb70e36528e
MD5 b305f9c735465477d32f089c72d77530
BLAKE2b-256 3fdd0073cad5353089c7e62a22f69ed72e89ef54cf95f08066bd17cc7bbf125b

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page