From 3ced5309ed788b868282d0fb1401ca655eb3b5ee Mon Sep 17 00:00:00 2001 From: Maria Grimaldi Date: Tue, 26 Nov 2024 11:12:29 +0100 Subject: [PATCH 01/12] docs: explain how the event bus works and how to use it --- docs/Makefile | 3 + docs/_images/event-bus-overview.png | Bin 0 -> 214308 bytes docs/_images/event-bus-workflow-service-a.png | Bin 0 -> 32750 bytes docs/_images/event-bus-workflow-service-b.png | Bin 0 -> 30284 bytes docs/concepts/event-bus.rst | 91 ++++++++++++++++++ docs/concepts/index.rst | 1 + docs/concepts/openedx-events.rst | 2 + docs/conf.py | 7 ++ docs/how-tos/adding-events-to-event-bus.rst | 42 -------- docs/how-tos/index.rst | 2 +- docs/how-tos/using-the-event-bus.rst | 79 +++++++++++++++ docs/reference/glossary.rst | 25 ++--- docs/reference/real-life-use-cases.rst | 4 +- openedx_events/event_bus/__init__.py | 10 ++ 14 files changed, 209 insertions(+), 57 deletions(-) create mode 100644 docs/_images/event-bus-overview.png create mode 100644 docs/_images/event-bus-workflow-service-a.png create mode 100644 docs/_images/event-bus-workflow-service-b.png create mode 100644 docs/concepts/event-bus.rst delete mode 100644 docs/how-tos/adding-events-to-event-bus.rst create mode 100644 docs/how-tos/using-the-event-bus.rst diff --git a/docs/Makefile b/docs/Makefile index d4bb2cbb..115749bf 100644 --- a/docs/Makefile +++ b/docs/Makefile @@ -18,3 +18,6 @@ help: # "make mode" option. $(O) is meant as a shortcut for $(SPHINXOPTS). %: Makefile @$(SPHINXBUILD) -M $@ "$(SOURCEDIR)" "$(BUILDDIR)" $(SPHINXOPTS) $(O) + +serve_docs: ## serve the built docs locally to preview the site in the browser + sphinx-autobuild . $(BUILDDIR)/html diff --git a/docs/_images/event-bus-overview.png b/docs/_images/event-bus-overview.png new file mode 100644 index 0000000000000000000000000000000000000000..f3e20b2a4d755f8eac00172cc8c405dc14c63f5a GIT binary patch literal 214308 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

XN?UP#L8e-D@q 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 kxO?&qHio9U);2FpE&h2DM#4Y>0079; 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 literal 0 HcmV?d00001 diff --git a/docs/concepts/event-bus.rst b/docs/concepts/event-bus.rst new file mode 100644 index 00000000..142ec715 --- /dev/null +++ b/docs/concepts/event-bus.rst @@ -0,0 +1,91 @@ +Open edX Event Bus +================== + +Overview +-------- + +The suggested strategy for cross-service communication in the Open edX ecosystem is through an event-based architecture implemented via the event bus. This functionality used for asynchronous communication between services is built on top of sending Open edX Events (Open edX-specific Django signals) within a service. + +What is the Open edX Event Bus? +------------------------------- + +The event bus implements an event-driven architecture that enables asynchronous communication between services using the `publish/subscribe messaging pattern`_ (pub/sub). In the Open edX ecosystem, the event bus is used to broadcast Open edX Events to multiple services, allowing them to react to changes or actions in the system. The event bus is a key component of the Open edX architecture, enabling services to communicate without direct dependencies on each other. + +.. image:: ../_images/event-bus-overview.png + :alt: Open edX Event Bus Overview + :align: center + +Why use the Open edX Event Bus? +------------------------------- + +The event bus can help us achieve loose coupling between services, replacing blocking requests between services and large sync jobs, leading to a faster, more reliable, and more extensible system. See event messaging architectural goals highlighted in :doc:`openedx-proposals:architectural-decisions/oep-0041-arch-async-server-event-messaging` to read more about its benefits. Here's a brief summary of some key points: + +* **Eliminate Blocking, Synchronous Requests**: reduce site outages when services become overloaded with requests by replacing synchronous calls with asynchronous communication. +* **Eliminate Expensive, Delayed, Batch Synchronization**: replace expensive batch processing with near real-time data updates. +* **Reduce the need for Plugins**: reduce the computational load for plugins that don't need to run in the same process by allowing cross-service communication of lifecycle events. + +How Does the Open edX Event Bus Work? +------------------------------------- + +The Open edX platform uses the ``OpenEdxPublicSignals`` (Open edX-specific Django Signals) to send events within a service. The event bus extends these signals, allowing them to be broadcast and handled across multiple services. That's how Open edX Events are used for internal and external communication. For more details on how these Open edX-specific Django Signals are used by the event bus, refer to the :doc:`../decisions/0004-external-event-bus-and-django-signal-events` Architectural Decision Record (ADR). + +Open edX Events provides an abstract implementation of the `publish/subscribe messaging pattern`_ (pub/sub) which is the chosen pattern for the event bus implementation as explained in :doc:`openedx-proposals:architectural-decisions/oep-0052-arch-event-bus-architecture`. It implements two abstract classes, `EventProducer`_ and `EventConsumer`_ which allow concrete implementations of the event bus based on different message brokers, such as Pulsar. + +This abstraction allows for developers to implement their own concrete implementations of the event bus in their own plugins, there are currently two implementations of the event bus, Redis (`event-bus-redis`_) and Kafka (`event-bus-kafka`_). Redis streams is a data structure that acts like an append-only log, and Kafka is a distributed event streaming application. Both implementations handle event production and consumption with technology specific methods. + +Architectural Diagram +********************* + +These diagrams show what happens when an event is sent to the event bus. The event sending workflow follows the same steps as explained in :ref:`events-architecture`, with a key difference: when configured, the event bus recognizes events and publish them to the message broker for consumption by other services. + +Components +~~~~~~~~~~ + +* **Service A (Producer)**: The service that emits the event. Developers may have emitted this event in a key section of the application logic, signaling that a specific action has occurred. +* **Service B (Consumer)**: The service that listens for the event and executes custom logic in response. +* **OpenEdxPublicSignal**: The class that implements all methods used to manage sending the event. This class inherits from Django's Signals class and adds Open edX-specific metadata and behaviors. +* **Event Producer**: The component that sends events to the event bus. The producer serializes the event data and enriches it with relevant metadata for the consumer. +* **Event Consumer**: The component that receives events from the event bus. The consumer deserializes the message and re-emits it as an event with the data that was transmitted. +* **Message Broker**: The technology that manages the message queue and ensures that messages are delivered to the correct consumers. The message broker is responsible for storing and delivering messages between the producer and consumer. +* **Event Bus Plugin**: The concrete implementation of the event bus based on a specific message broker, such as Pulsar. The plugin handles event production and consumption with technology-specific methods. + +Workflow +~~~~~~~~ + +.. image:: ../_images/event-bus-workflow-service-a.png + :alt: Open edX Event Bus Workflow (Service A) + :align: center + +**From Service A (Producer)** + +1. When the event is sent, a registered event receiver `general_signal_handler`_ is called to send the event to the event bus. This receiver is registered by the Django Signal mechanism when the ``openedx-events`` app is installed, and it listens for all Open edX Events. +2. The receiver checks the ``EVENT_BUS_PRODUCER_CONFIG`` to look for the ``event_type`` of the event that was sent. +3. If the event type is found and it's enabled for publishing in the configuration, the receiver obtains the configured producer class (``EventProducer``) from the concrete event bus implementation. For example, the producer class for Redis or Kafka implemented in their respective plugins. +4. The ``EventProducer`` serializes the event data and enriches it with relevant metadata for the consumer. +5. The producer uses its technology-specific ``send`` method to publish a message to the configured broker (e.g., Redis or Kafka). + +.. image:: ../_images/event-bus-workflow-service-b.png + :alt: Open edX Event Bus Workflow (Service B) + :align: center + +**From Service B (Consumer)** + +1. A worker process in Service B runs indefinitely, checking the broker for new messages. +2. When a new message is found, the ``EventConsumer`` deserializes the message and re-emits it as an event with the data that was transmitted. +3. The event sending and processing workflow repeats in Service B. + +This approach of producing events via settings with the generic handler was chosen to allow for flexibility in the event bus implementation. It allows developers to choose the event bus implementation that best fits their needs, and to easily switch between implementations if necessary. See more details in the :doc:`../decisions/0012-producing-to-event-bus-via-settings` Architectural Decision Record (ADR). + +How is the Open edX Event Bus Used? +----------------------------------- + +The event bus is used to broadcast Open edX Events to multiple services, allowing them to react to changes or actions in the system. The event bus is a key component of the Open edX architecture, enabling services to communicate without direct dependencies on each other. + +We encourage you to review the :doc:`../reference/real-life-use-cases` page for examples of how the event bus can be used in the Open edX ecosystem. Also, see the :doc:`../how-tos/using-the-event-bus` guide to get start sending events to the event bus. + +.. _general_signal_handler: https://github.com/openedx/openedx-events/blob/main/openedx_events/apps.py#L16-L44 +.. _EventProducer: https://github.com/openedx/openedx-events/blob/main/openedx_events/event_bus/__init__.py#L71-L91 +.. _EventConsumer: https://github.com/openedx/openedx-events/blob/main/openedx_events/event_bus/__init__.py#L128-L139 +.. _publish/subscribe messaging pattern: https://en.wikipedia.org/wiki/Publish%E2%80%93subscribe_pattern +.. _event-bus-redis: https://github.com/openedx/event-bus-redis/ +.. _event-bus-kafka: https://github.com/openedx/event-bus-kafka/ diff --git a/docs/concepts/index.rst b/docs/concepts/index.rst index 25dc09c9..2eec03d9 100644 --- a/docs/concepts/index.rst +++ b/docs/concepts/index.rst @@ -6,3 +6,4 @@ Concepts :caption: Contents: openedx-events + event-bus diff --git a/docs/concepts/openedx-events.rst b/docs/concepts/openedx-events.rst index 43a07004..0135c169 100644 --- a/docs/concepts/openedx-events.rst +++ b/docs/concepts/openedx-events.rst @@ -22,6 +22,8 @@ How do Open edX Events work? Open edX Events are implemented by a class called `OpenEdxPublicSignal`_, which inherits from `Django's Signals class` and adds behaviors specific to the Open edX ecosystem. Thanks to this design, ``OpenEdxPublicSignal`` leverages the functionality of Django signals, allowing developers to apply their existing knowledge of the Django framework. +.. _events-architecture: + Architectural Diagram ********************* diff --git a/docs/conf.py b/docs/conf.py index 27cffd79..77ad5adc 100644 --- a/docs/conf.py +++ b/docs/conf.py @@ -38,6 +38,7 @@ 'sphinxcontrib.mermaid', 'code_annotations.contrib.sphinx.extensions.openedx_events', 'sphinx.ext.intersphinx', + 'code_annotations.contrib.sphinx.extensions.settings', ] # Add any paths that contain templates here, relative to this directory. @@ -131,4 +132,10 @@ f"https://docs.openedx.org/{rtd_language}/{rtd_version}", None, ), + "openedx-proposals": ( + # Not setting the version on purpose because we always want the latest version + # of OEPs + f"https://docs.openedx.org/projects/openedx-proposals/{rtd_language}/latest", + None, + ), } diff --git a/docs/how-tos/adding-events-to-event-bus.rst b/docs/how-tos/adding-events-to-event-bus.rst deleted file mode 100644 index 89e45da1..00000000 --- a/docs/how-tos/adding-events-to-event-bus.rst +++ /dev/null @@ -1,42 +0,0 @@ -Using the Open edX Event bus -============================ - -After creating a new Open edX Event, you might need to send it across services -instead of just within the same process. For this kind of use-cases, you might want -to use the Open edX Event Bus. Here, we list useful information about -adding a new event to the event bus: - -- `How to start using the Event Bus`_ - - -.. _How to start using the Event Bus: https://openedx.atlassian.net/wiki/spaces/AC/pages/3508699151/How+to+start+using+the+Event+Bus - - -Producing to event bus -^^^^^^^^^^^^^^^^^^^^^^ - -In the producing/host application, include ``openedx_events`` in ``INSTALLED_APPS`` settings and add ``EVENT_BUS_PRODUCER_CONFIG`` setting. For example, below snippet is to push ``XBLOCK_PUBLISHED`` to two different topics and ``XBLOCK_DELETED`` signal to one topic in event bus. - -.. code-block:: python - - # .. setting_name: EVENT_BUS_PRODUCER_CONFIG - # .. setting_default: {} - # .. setting_description: Dictionary of event_types to dictionaries for topic-related configuration. - # Each topic configuration dictionary uses the topic as a key and contains: - # * A flag called `enabled` denoting whether the event will be published. - # * The `event_key_field` which is a period-delimited string path to event data field to use as event key. - # Note: The topic names should not include environment prefix as it will be dynamically added based on - # EVENT_BUS_TOPIC_PREFIX setting. - EVENT_BUS_PRODUCER_CONFIG = { - 'org.openedx.content_authoring.xblock.published.v1': { - 'content-authoring-xblock-lifecycle': {'event_key_field': 'xblock_info.usage_key', 'enabled': True}, - 'content-authoring-xblock-published': {'event_key_field': 'xblock_info.usage_key', 'enabled': True} - }, - 'org.openedx.content_authoring.xblock.deleted.v1': { - 'content-authoring-xblock-lifecycle': {'event_key_field': 'xblock_info.usage_key', 'enabled': True}, - }, - } - -The ``EVENT_BUS_PRODUCER_CONFIG`` is read by openedx_events and a handler is -attached which does the leg work of reading the configuration again and pushing -to appropriate handlers. diff --git a/docs/how-tos/index.rst b/docs/how-tos/index.rst index 3c210b0c..45b871bf 100644 --- a/docs/how-tos/index.rst +++ b/docs/how-tos/index.rst @@ -7,6 +7,6 @@ How-tos creating-new-events adding-events-to-a-service - adding-events-to-event-bus using-events + using-the-event-bus add-new-event-bus-concrete-implementation diff --git a/docs/how-tos/using-the-event-bus.rst b/docs/how-tos/using-the-event-bus.rst new file mode 100644 index 00000000..925d5226 --- /dev/null +++ b/docs/how-tos/using-the-event-bus.rst @@ -0,0 +1,79 @@ +Using the Open edX Event Bus +============================ + +After creating a new Open edX Event, you might need to send it across services instead of just within the same process. For this kind of use-cases, you might want to use the Open edX Event Bus. Here :doc:`../concepts/event-bus` you can find useful information about the event bus. + +The Open edX Event Bus is a key component of the Open edX architecture, enabling services to communicate without direct dependencies on each other. This guide provides an overview of how to use the event bus to broadcast Open edX Events to multiple services, allowing them to react to changes or actions in the system. + +Prerequisites +------------- + +Before you start using the event bus, you need to have the following: + +- A service that will consume the event +- A service that will produce the event +- The Open edX Event Bus concrete implementation (Django plugin) installed in both services +- The message broker (e.g., Kafka or Redis) set up +- The Open edX Event Bus configuration set up in both services + +Configurations +-------------- + +Here are the available configurations for the event bus we'll be using: + +.. settings:: + :folder_path: openedx_events/event_bus + +Setup +----- + +To start producing and consuming events using the Open edX Event Bus, follow these steps: + +#. **Produce the event** + +In the producing/host application, include ``openedx_events`` in ``INSTALLED_APPS`` settings and add ``EVENT_BUS_PRODUCER_CONFIG`` setting. This setting is a dictionary of event_types to dictionaries for topic-related configuration. Each topic configuration dictionary uses the topic as a key and contains: + +- A flag called ``enabled`` denoting whether the event will be published. +- The ``event_key_field`` which is a period-delimited string path to event data field to use as event key. + +.. note:: The topic names should not include environment prefix as it will be dynamically added based on ``EVENT_BUS_TOPIC_PREFIX`` setting. + +Here's an example of the producer configuration: + +.. code-block:: python + + EVENT_BUS_PRODUCER_CONFIG = { + 'org.openedx.content_authoring.xblock.published.v1': { + 'content-authoring-xblock-lifecycle': {'event_key_field': 'xblock_info.usage_key', 'enabled': True}, + 'content-authoring-xblock-published': {'event_key_field': 'xblock_info.usage_key', 'enabled': True} + }, + 'org.openedx.content_authoring.xblock.deleted.v1': { + 'content-authoring-xblock-lifecycle': {'event_key_field': 'xblock_info.usage_key', 'enabled': True}, + }, + } + +The ``EVENT_BUS_PRODUCER_CONFIG`` is read by ``openedx_events`` and a handler is attached which does the leg work of reading the configuration again and pushing to appropriate handlers. + +To let the openedx-events know about which event bus implementation to use (e.g., Kafka or Redis), you need to set the ``EVENT_BUS_PRODUCER`` setting. This setting should be the dotted path to the concrete implementation class. + +#. **Consume the Event** + +In the consuming service, include ``openedx_events`` in ``INSTALLED_APPS`` settings and add ``EVENT_BUS_CONSUMER_CONFIG`` setting. Then, you should implement a receiver for the event type you are interested in. + + + .. code-block:: python + + @receiver(XBLOCK_DELETED) + def update_some_data(sender, **kwargs): + ... do things with the data in kwargs ... + ... log the event for debugging purposes ... + +To let the openedx-events know about which event bus implementation to use (e.g., Kafka or Redis), you need to set the ``EVENT_BUS_CONSUMER`` setting. This setting should be the dotted path to the concrete implementation class. + +#. **Run the consumer**: Run the consumer process in the consuming service to listen for events. + +#. **Send the event**: Send the event from the producing service. + +#. **Check the consumer**: Check the consumer logs to see if the event was received. + +.. TODO: add more details about how to run the consumer and send the event. https://github.com/openedx/openedx-events/blob/main/openedx_events/management/commands/consume_events.py diff --git a/docs/reference/glossary.rst b/docs/reference/glossary.rst index 44f2b593..6c118c19 100644 --- a/docs/reference/glossary.rst +++ b/docs/reference/glossary.rst @@ -21,21 +21,24 @@ An event has multiple components that are used to define, trigger, and handle th An event is a signal that is emitted when a specific action occurs in the platform. The event definition is the instantiation of the ``OpenEdxPublicSignal`` class that defines the structure and metadata of an event. This definition includes information such as the event name, description, payload, and version. Event definitions are used to create events which are later imported into the services and are triggered by using the ``send_event`` method. Event Bus - To be added soon. + Code that handles asynchronous message transfer between services. - Event Bus Producer - To be added soon. + Message + A unit of information sent from one service to another via a message broker. - Event Bus Consumer - To be added soon. + Message Broker + A service that receives, organizes, and stores messages so other services can query and retrieve them. - Event Bus Topic - To be added soon. + Worker + A machine or process that runs service code without hosting the web application. Workers are used to process messages from the message broker. - Event Bus Producer Config - To be added soon. + Producer + A service that sends events to the event bus. The producer serializes the event data and enriches it with relevant metadata for the consumer. - Event Bus Settings - To be added soon. + Consumer + A service that receives events from the event bus. The consumer deserializes the message and re-emits it as an event with the data that was transmitted. + + Topic + How the event bus implementation groups related events, such as streams in Redis. Producers publish events to topics, and consumers subscribe to topics to receive events. .. _Events Payload ADR: :doc: `/decisions/0003-events-payload` diff --git a/docs/reference/real-life-use-cases.rst b/docs/reference/real-life-use-cases.rst index 7c1a1ff4..5da283b6 100644 --- a/docs/reference/real-life-use-cases.rst +++ b/docs/reference/real-life-use-cases.rst @@ -16,9 +16,7 @@ The following list of real-life use cases showcases the different ways Open edX Cross-services communication **************************** -The suggested strategy for cross-service communication efficiently in the Open edX ecosystem is through an event-based architecture implemented via the Event Bus. This functionality used for asynchronous communication between services is built on top of sending Open edX Events (Open edX-specific Django signals) within a service. The Event Bus extends these signals, allowing them to be broadcast and handled across multiple services. For more details on the Event Bus, please see `How to Start Using the Event Bus`_. - -.. TODO: replace event bus confluence page with native docs +As mentioned in :doc:`../concepts/event-bus`, the suggested strategy for cross-service communication in the Open edX ecosystem is through an event-based architecture implemented via the Event Bus. This functionality used for asynchronous communication between services is built on top of sending Open edX Events (Open edX-specific Django signals) within a service. For more details on the Event Bus, please see :doc:`../how-tos/using-the-event-bus`. Here are some examples of how the Event Bus can be used to facilitate communication between IDAs: diff --git a/openedx_events/event_bus/__init__.py b/openedx_events/event_bus/__init__.py index e0fcc332..3f07e3cd 100644 --- a/openedx_events/event_bus/__init__.py +++ b/openedx_events/event_bus/__init__.py @@ -186,6 +186,16 @@ def _reset_state(sender, **kwargs): # pylint: disable=unused-argument get_producer.cache_clear() +# .. setting_name: EVENT_BUS_PRODUCER_CONFIG +# .. setting_default: {} +# .. setting_description: Dictionary of event_types to lists of dictionaries for topic related configuration. +# Each topic configuration dictionary contains a flag called `enabled` denoting whether the event will be +# published to the topic, topic/stream name called `topic` where the event will be pushed to, +# `event_key_field` which is a period-delimited string path to event data field to use as event key. +# The topic names should not include environment prefix as it will be dynamically added based on +# EVENT_BUS_TOPIC_PREFIX setting. See 0012-producing-to-event-bus-via-settings for more details. + + def merge_producer_configs(producer_config_original, producer_config_overrides): """ Merge two EVENT_BUS_PRODUCER_CONFIG maps. From 1db044e178c02d7c39aa9a93fd07e3e824eee37e Mon Sep 17 00:00:00 2001 From: Maria Grimaldi Date: Fri, 29 Nov 2024 15:04:47 +0100 Subject: [PATCH 02/12] refactor: move configurations to reference and improve formatting --- docs/how-tos/using-the-event-bus.rst | 85 +++++++++++---------- docs/reference/event-bus-configurations.rst | 7 ++ docs/reference/index.rst | 1 + 3 files changed, 52 insertions(+), 41 deletions(-) create mode 100644 docs/reference/event-bus-configurations.rst diff --git a/docs/how-tos/using-the-event-bus.rst b/docs/how-tos/using-the-event-bus.rst index 925d5226..98073400 100644 --- a/docs/how-tos/using-the-event-bus.rst +++ b/docs/how-tos/using-the-event-bus.rst @@ -5,31 +5,34 @@ After creating a new Open edX Event, you might need to send it across services i The Open edX Event Bus is a key component of the Open edX architecture, enabling services to communicate without direct dependencies on each other. This guide provides an overview of how to use the event bus to broadcast Open edX Events to multiple services, allowing them to react to changes or actions in the system. -Prerequisites -------------- +Setup +----- -Before you start using the event bus, you need to have the following: +To start producing and consuming events using the Open edX Event Bus, follow these steps: -- A service that will consume the event -- A service that will produce the event -- The Open edX Event Bus concrete implementation (Django plugin) installed in both services -- The message broker (e.g., Kafka or Redis) set up -- The Open edX Event Bus configuration set up in both services +Install the Open edX Event Bus Plugin +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ -Configurations --------------- +First, you need to install the Open edX Event Bus plugin in both the producing and consuming services. The plugin is a Django app that provides the necessary tools and configurations to produce and consume events. You could install the Redis plugin by running: -Here are the available configurations for the event bus we'll be using: +.. code-block:: bash -.. settings:: - :folder_path: openedx_events/event_bus + pip install edx-event-bus-redis -Setup ------ +Configure the Event Bus +~~~~~~~~~~~~~~~~~~~~~~~ -To start producing and consuming events using the Open edX Event Bus, follow these steps: +In :doc:`../reference/event-bus-configurations`, you can find the available configurations for the event bus that are used to set up the event bus in the Open edX platform. + +In both the producing and consuming services, you need to configure the event bus. This includes setting up the event types, topics, and other configurations for the event bus. In this step, you should configure the producer and consumer classes for the event bus implementation you are using: -#. **Produce the event** +- In the producing service, configure the producer class by setting the ``EVENT_BUS_PRODUCER`` setting. E.g., ``edx_event_bus_redis.create_producer``. +- In the consuming service, configure the consumer class by setting the ``EVENT_BUS_CONSUMER`` setting. E.g., ``edx_event_bus_redis.RedisEventConsumer``. + +By configuring these settings, you are telling Open edX Events which concrete implementation to use for producing and consuming events. + +Produce the Event +~~~~~~~~~~~~~~~~~ In the producing/host application, include ``openedx_events`` in ``INSTALLED_APPS`` settings and add ``EVENT_BUS_PRODUCER_CONFIG`` setting. This setting is a dictionary of event_types to dictionaries for topic-related configuration. Each topic configuration dictionary uses the topic as a key and contains: @@ -38,42 +41,42 @@ In the producing/host application, include ``openedx_events`` in ``INSTALLED_APP .. note:: The topic names should not include environment prefix as it will be dynamically added based on ``EVENT_BUS_TOPIC_PREFIX`` setting. -Here's an example of the producer configuration: +Here's an example of the producer configuration which will publish events for XBlock published and deleted events to the specified topics: .. code-block:: python EVENT_BUS_PRODUCER_CONFIG = { - 'org.openedx.content_authoring.xblock.published.v1': { - 'content-authoring-xblock-lifecycle': {'event_key_field': 'xblock_info.usage_key', 'enabled': True}, - 'content-authoring-xblock-published': {'event_key_field': 'xblock_info.usage_key', 'enabled': True} - }, - 'org.openedx.content_authoring.xblock.deleted.v1': { - 'content-authoring-xblock-lifecycle': {'event_key_field': 'xblock_info.usage_key', 'enabled': True}, - }, + 'org.openedx.content_authoring.xblock.published.v1': { + 'content-authoring-xblock-lifecycle': {'event_key_field': 'xblock_info.usage_key', 'enabled': True}, + 'content-authoring-xblock-published': {'event_key_field': 'xblock_info.usage_key', 'enabled': True} + }, + 'org.openedx.content_authoring.xblock.deleted.v1': { + 'content-authoring-xblock-lifecycle': {'event_key_field': 'xblock_info.usage_key', 'enabled': True}, + }, } The ``EVENT_BUS_PRODUCER_CONFIG`` is read by ``openedx_events`` and a handler is attached which does the leg work of reading the configuration again and pushing to appropriate handlers. -To let the openedx-events know about which event bus implementation to use (e.g., Kafka or Redis), you need to set the ``EVENT_BUS_PRODUCER`` setting. This setting should be the dotted path to the concrete implementation class. - -#. **Consume the Event** +Consume the Event +~~~~~~~~~~~~~~~~~ -In the consuming service, include ``openedx_events`` in ``INSTALLED_APPS`` settings and add ``EVENT_BUS_CONSUMER_CONFIG`` setting. Then, you should implement a receiver for the event type you are interested in. +In the consuming service, include ``openedx_events`` in ``INSTALLED_APPS`` settings and add ``EVENT_BUS_CONSUMER_CONFIG`` setting. Then, you should implement a receiver for the event type you are interested in. In this example, we are interested in the XBlock deleted event: +.. code-block:: python - .. code-block:: python - - @receiver(XBLOCK_DELETED) - def update_some_data(sender, **kwargs): - ... do things with the data in kwargs ... - ... log the event for debugging purposes ... - -To let the openedx-events know about which event bus implementation to use (e.g., Kafka or Redis), you need to set the ``EVENT_BUS_CONSUMER`` setting. This setting should be the dotted path to the concrete implementation class. + @receiver(XBLOCK_DELETED) + def update_some_data(sender, **kwargs): + ... do things with the data in kwargs ... + ... log the event for debugging purposes ... -#. **Run the consumer**: Run the consumer process in the consuming service to listen for events. +Run the Consumer +~~~~~~~~~~~~~~~~ -#. **Send the event**: Send the event from the producing service. +To consume events, Open edX Events provides a management command called `consume_events`_ which can be called from the command line, how to run this command will depend on your deployment strategy. This command will start a process that listens to the message broker for new messages, processes them and emits the event. -#. **Check the consumer**: Check the consumer logs to see if the event was received. +You can find more a concrete example of how to produce and consume events in the `event-bus-redis`_ documentation. -.. TODO: add more details about how to run the consumer and send the event. https://github.com/openedx/openedx-events/blob/main/openedx_events/management/commands/consume_events.py +.. _consume_events: https://github.com/openedx/openedx-events/blob/main/openedx_events/management/commands/consume_events.py +.. _event-bus-redis: https://github.com/openedx/event-bus-redis +.. _run the consumer locally without tutor: https://github.com/openedx/event-bus-redis/?tab=readme-ov-file#testing-locally +.. _run the consumer locally with tutor: https://github.com/openedx/event-bus-redis/blob/main/docs/tutor_installation.rst#setup-example-with-openedx-course-discovery-and-tutor diff --git a/docs/reference/event-bus-configurations.rst b/docs/reference/event-bus-configurations.rst new file mode 100644 index 00000000..c5313f3c --- /dev/null +++ b/docs/reference/event-bus-configurations.rst @@ -0,0 +1,7 @@ +Event Bus Configuration +======================= + +Here are the available configurations for the event bus that are used to setup the event bus in the Open edX platform. + +.. settings:: + :folder_path: openedx_events/event_bus diff --git a/docs/reference/index.rst b/docs/reference/index.rst index 0a1895ab..b7167d78 100644 --- a/docs/reference/index.rst +++ b/docs/reference/index.rst @@ -7,6 +7,7 @@ References events glossary + event-bus-configurations oeps architecture-subdomains real-life-use-cases From 3619687368c0404c7261109c3680c0a1b9a4aa36 Mon Sep 17 00:00:00 2001 From: Maria Grimaldi Date: Mon, 2 Dec 2024 15:06:16 +0100 Subject: [PATCH 03/12] refactor: drop references to confluence event bus page --- docs/concepts/openedx-events.rst | 1 - docs/reference/real-life-use-cases.rst | 3 +-- 2 files changed, 1 insertion(+), 3 deletions(-) diff --git a/docs/concepts/openedx-events.rst b/docs/concepts/openedx-events.rst index 0135c169..c883aceb 100644 --- a/docs/concepts/openedx-events.rst +++ b/docs/concepts/openedx-events.rst @@ -80,7 +80,6 @@ For more information on using Open edX Events, refer to the :doc:`../how-tos/usi .. _Django Signals Documentation: https://docs.djangoproject.com/en/4.2/topics/signals/ .. _triggering the COURSE_ENROLLMENT_CREATED event: https://github.com/openedx/edx-platform/blob/master/common/djangoapps/student/models/course_enrollment.py#L777-L795 .. _course_enrollment_post_save receiver: https://github.com/openedx/edx-platform/blob/master/openedx/core/djangoapps/notifications/handlers.py#L38-L53 -.. _Event Bus technology: https://openedx.atlassian.net/wiki/spaces/AC/pages/3508699151/How+to+start+using+the+Event+Bus .. _Django signals registry mechanism: https://docs.djangoproject.com/en/4.2/topics/signals/#listening-to-signals .. _signal receivers in their plugins: https://edx.readthedocs.io/projects/edx-django-utils/en/latest/edx_django_utils.plugins.html#edx_django_utils.plugins.constants.PluginSignals .. _Open edX Django plugins: https://edx.readthedocs.io/projects/edx-django-utils/en/latest/plugins/readme.html diff --git a/docs/reference/real-life-use-cases.rst b/docs/reference/real-life-use-cases.rst index 5da283b6..10eeebb7 100644 --- a/docs/reference/real-life-use-cases.rst +++ b/docs/reference/real-life-use-cases.rst @@ -16,7 +16,7 @@ The following list of real-life use cases showcases the different ways Open edX Cross-services communication **************************** -As mentioned in :doc:`../concepts/event-bus`, the suggested strategy for cross-service communication in the Open edX ecosystem is through an event-based architecture implemented via the Event Bus. This functionality used for asynchronous communication between services is built on top of sending Open edX Events (Open edX-specific Django signals) within a service. For more details on the Event Bus, please see :doc:`../how-tos/using-the-event-bus`. +As mentioned in :doc:`../concepts/event-bus`, the suggested strategy for cross-service communication in the Open edX ecosystem is through an event-based architecture implemented via the :doc:`../concepts/event-bus`. This functionality used for asynchronous communication between services is built on top of sending Open edX Events (Open edX-specific Django signals) within a service. For more details on the Event Bus, please see :doc:`../how-tos/using-the-event-bus`. Here are some examples of how the Event Bus can be used to facilitate communication between IDAs: @@ -130,7 +130,6 @@ Here are some additional use cases that can be implemented using Open edX Events .. note:: If you have implemented a solution using Open edX Events and would like to share it with the community, please submit a pull request to add it to this list! -.. _How to Start Using the Event Bus: https://openedx.atlassian.net/wiki/spaces/AC/pages/3508699151/How+to+start+using+the+Event+Bus .. _edx-exams: https://github.com/edx/edx-exams .. _edx-proctoring: https://github.com/openedx/edx-proctoring .. _ADR Implementation of Event Driven Architecture for Exam Downstream Effects: https://github.com/edx/edx-exams/blob/main/docs/decisions/0004-downstream-effect-events.rst From be4da06c911e44f2f52cdd6707f2e3a86bcdf843 Mon Sep 17 00:00:00 2001 From: Maria Grimaldi Date: Mon, 2 Dec 2024 17:09:54 +0100 Subject: [PATCH 04/12] refactor: reference terms in glossary --- docs/_images/event-bus-workflow-service-b.png | Bin 30284 -> 29677 bytes docs/concepts/event-bus.rst | 26 +++++++++--------- docs/how-tos/using-the-event-bus.rst | 20 ++++++++------ 3 files changed, 24 insertions(+), 22 deletions(-) diff --git a/docs/_images/event-bus-workflow-service-b.png b/docs/_images/event-bus-workflow-service-b.png index 15f4d690eaee9a7e69ca2407df9f402bd24806d8..91393f12ba58921eb3848bbe6c41b3ff12a92df4 100644 GIT binary patch literal 29677 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 YAN~7d^8IYEdmAJtttgc#asSDG0gfbob^rhX literal 30284 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 diff --git a/docs/concepts/event-bus.rst b/docs/concepts/event-bus.rst index 142ec715..d49d244a 100644 --- a/docs/concepts/event-bus.rst +++ b/docs/concepts/event-bus.rst @@ -4,12 +4,12 @@ Open edX Event Bus Overview -------- -The suggested strategy for cross-service communication in the Open edX ecosystem is through an event-based architecture implemented via the event bus. This functionality used for asynchronous communication between services is built on top of sending Open edX Events (Open edX-specific Django signals) within a service. +The suggested strategy for cross-service communication in the Open edX ecosystem is through an event-based architecture implemented via the :term:`Event Bus`. This functionality used for asynchronous communication between services is built on top of sending Open edX Events (Open edX-specific Django signals) within a service. What is the Open edX Event Bus? ------------------------------- -The event bus implements an event-driven architecture that enables asynchronous communication between services using the `publish/subscribe messaging pattern`_ (pub/sub). In the Open edX ecosystem, the event bus is used to broadcast Open edX Events to multiple services, allowing them to react to changes or actions in the system. The event bus is a key component of the Open edX architecture, enabling services to communicate without direct dependencies on each other. +The :term:`Event Bus` implements an event-driven architecture that enables asynchronous communication between services using the `publish/subscribe messaging pattern`_ (pub/sub). In the Open edX ecosystem, the event bus is used to broadcast Open edX Events to multiple services, allowing them to react to changes or actions in the system. The event bus is a key component of the Open edX architecture, enabling services to communicate without direct dependencies on each other. .. image:: ../_images/event-bus-overview.png :alt: Open edX Event Bus Overview @@ -18,7 +18,7 @@ The event bus implements an event-driven architecture that enables asynchronous Why use the Open edX Event Bus? ------------------------------- -The event bus can help us achieve loose coupling between services, replacing blocking requests between services and large sync jobs, leading to a faster, more reliable, and more extensible system. See event messaging architectural goals highlighted in :doc:`openedx-proposals:architectural-decisions/oep-0041-arch-async-server-event-messaging` to read more about its benefits. Here's a brief summary of some key points: +The :term:`Event Bus` can help us achieve loose coupling between services, replacing blocking requests between services and large sync jobs, leading to a faster, more reliable, and more extensible system. See event messaging architectural goals highlighted in :doc:`openedx-proposals:architectural-decisions/oep-0041-arch-async-server-event-messaging` to read more about its benefits. Here's a brief summary of some key points: * **Eliminate Blocking, Synchronous Requests**: reduce site outages when services become overloaded with requests by replacing synchronous calls with asynchronous communication. * **Eliminate Expensive, Delayed, Batch Synchronization**: replace expensive batch processing with near real-time data updates. @@ -27,11 +27,11 @@ The event bus can help us achieve loose coupling between services, replacing blo How Does the Open edX Event Bus Work? ------------------------------------- -The Open edX platform uses the ``OpenEdxPublicSignals`` (Open edX-specific Django Signals) to send events within a service. The event bus extends these signals, allowing them to be broadcast and handled across multiple services. That's how Open edX Events are used for internal and external communication. For more details on how these Open edX-specific Django Signals are used by the event bus, refer to the :doc:`../decisions/0004-external-event-bus-and-django-signal-events` Architectural Decision Record (ADR). +The Open edX platform uses the ``OpenEdxPublicSignals`` (Open edX-specific Django Signals) to send events within a service. The event bus extends these signals, allowing them to be broadcasted and handled across multiple services. That's how Open edX Events are used for internal and external communication. For more details on how these Open edX-specific Django Signals are used by the event bus, refer to the :doc:`../decisions/0004-external-event-bus-and-django-signal-events` Architectural Decision Record (ADR). Open edX Events provides an abstract implementation of the `publish/subscribe messaging pattern`_ (pub/sub) which is the chosen pattern for the event bus implementation as explained in :doc:`openedx-proposals:architectural-decisions/oep-0052-arch-event-bus-architecture`. It implements two abstract classes, `EventProducer`_ and `EventConsumer`_ which allow concrete implementations of the event bus based on different message brokers, such as Pulsar. -This abstraction allows for developers to implement their own concrete implementations of the event bus in their own plugins, there are currently two implementations of the event bus, Redis (`event-bus-redis`_) and Kafka (`event-bus-kafka`_). Redis streams is a data structure that acts like an append-only log, and Kafka is a distributed event streaming application. Both implementations handle event production and consumption with technology specific methods. +This abstraction allows for developers to implement their own concrete implementations of the event bus in their own plugins. There are currently two implementations of the event bus, Redis (`event-bus-redis`_) and Kafka (`event-bus-kafka`_). Redis streams is a data structure that acts like an append-only log, and Kafka is a distributed event streaming application. Both implementations handle event production and consumption with technology specific methods. Architectural Diagram ********************* @@ -44,10 +44,10 @@ Components * **Service A (Producer)**: The service that emits the event. Developers may have emitted this event in a key section of the application logic, signaling that a specific action has occurred. * **Service B (Consumer)**: The service that listens for the event and executes custom logic in response. * **OpenEdxPublicSignal**: The class that implements all methods used to manage sending the event. This class inherits from Django's Signals class and adds Open edX-specific metadata and behaviors. -* **Event Producer**: The component that sends events to the event bus. The producer serializes the event data and enriches it with relevant metadata for the consumer. -* **Event Consumer**: The component that receives events from the event bus. The consumer deserializes the message and re-emits it as an event with the data that was transmitted. -* **Message Broker**: The technology that manages the message queue and ensures that messages are delivered to the correct consumers. The message broker is responsible for storing and delivering messages between the producer and consumer. -* **Event Bus Plugin**: The concrete implementation of the event bus based on a specific message broker, such as Pulsar. The plugin handles event production and consumption with technology-specific methods. +* **Event Producer**: The class in the :term:`Producer` service that sends events to the event bus. The producer serializes the event data and enriches it with relevant metadata for the consumer. +* **Event Consumer**: The class in the :term:`Consumer` service that receives events from the event bus. The consumer deserializes the :term:`message ` and re-emits it as an event with the data that was transmitted. +* **Message Broker**: The :term:`message broker ` is responsible for storing and delivering messages between the producer and consumer. +* **Event Bus Plugin**: The concrete implementation of the event bus (EventProducer and EventConsumer) based on a specific :term:`message broker `, such as Pulsar. The plugin handles event production and consumption with technology-specific methods. Workflow ~~~~~~~~ @@ -61,7 +61,7 @@ Workflow 1. When the event is sent, a registered event receiver `general_signal_handler`_ is called to send the event to the event bus. This receiver is registered by the Django Signal mechanism when the ``openedx-events`` app is installed, and it listens for all Open edX Events. 2. The receiver checks the ``EVENT_BUS_PRODUCER_CONFIG`` to look for the ``event_type`` of the event that was sent. 3. If the event type is found and it's enabled for publishing in the configuration, the receiver obtains the configured producer class (``EventProducer``) from the concrete event bus implementation. For example, the producer class for Redis or Kafka implemented in their respective plugins. -4. The ``EventProducer`` serializes the event data and enriches it with relevant metadata for the consumer. +4. The ``EventProducer`` serializes the event data and enriches it with relevant metadata, and then transforms it into a message that can be transmitted. 5. The producer uses its technology-specific ``send`` method to publish a message to the configured broker (e.g., Redis or Kafka). .. image:: ../_images/event-bus-workflow-service-b.png @@ -70,7 +70,7 @@ Workflow **From Service B (Consumer)** -1. A worker process in Service B runs indefinitely, checking the broker for new messages. +1. A :term:`Worker` process in Service B runs indefinitely, checking the broker for new messages. 2. When a new message is found, the ``EventConsumer`` deserializes the message and re-emits it as an event with the data that was transmitted. 3. The event sending and processing workflow repeats in Service B. @@ -79,9 +79,9 @@ This approach of producing events via settings with the generic handler was chos How is the Open edX Event Bus Used? ----------------------------------- -The event bus is used to broadcast Open edX Events to multiple services, allowing them to react to changes or actions in the system. The event bus is a key component of the Open edX architecture, enabling services to communicate without direct dependencies on each other. +The event bus is used to broadcast Open edX Events to multiple services, allowing them to react to changes or actions in the system. -We encourage you to review the :doc:`../reference/real-life-use-cases` page for examples of how the event bus can be used in the Open edX ecosystem. Also, see the :doc:`../how-tos/using-the-event-bus` guide to get start sending events to the event bus. +We encourage you to review the :doc:`../reference/real-life-use-cases` page for examples of how the event bus is used in the Open edX ecosystem by the community. Also, see the :doc:`../how-tos/using-the-event-bus` guide to get start sending events to the event bus. .. _general_signal_handler: https://github.com/openedx/openedx-events/blob/main/openedx_events/apps.py#L16-L44 .. _EventProducer: https://github.com/openedx/openedx-events/blob/main/openedx_events/event_bus/__init__.py#L71-L91 diff --git a/docs/how-tos/using-the-event-bus.rst b/docs/how-tos/using-the-event-bus.rst index 98073400..39814028 100644 --- a/docs/how-tos/using-the-event-bus.rst +++ b/docs/how-tos/using-the-event-bus.rst @@ -1,7 +1,7 @@ Using the Open edX Event Bus ============================ -After creating a new Open edX Event, you might need to send it across services instead of just within the same process. For this kind of use-cases, you might want to use the Open edX Event Bus. Here :doc:`../concepts/event-bus` you can find useful information about the event bus. +After creating a new Open edX Event, you might need to send it across services instead of just within the same process. For this kind of use-cases, you might want to use the Open edX Event Bus. Here :doc:`../concepts/event-bus`, you can find useful information to start getting familiar with the Open edX Event Bus. The Open edX Event Bus is a key component of the Open edX architecture, enabling services to communicate without direct dependencies on each other. This guide provides an overview of how to use the event bus to broadcast Open edX Events to multiple services, allowing them to react to changes or actions in the system. @@ -24,24 +24,24 @@ Configure the Event Bus In :doc:`../reference/event-bus-configurations`, you can find the available configurations for the event bus that are used to set up the event bus in the Open edX platform. -In both the producing and consuming services, you need to configure the event bus. This includes setting up the event types, topics, and other configurations for the event bus. In this step, you should configure the producer and consumer classes for the event bus implementation you are using: +In both the producing and consuming services, you need to configure the event bus. This includes setting up the :term:`event types `, :term:`topics `, and other configurations for the :term:`Event Bus` to work with. In this step, you should configure the producer and consumer classes for the event bus implementation you are using: -- In the producing service, configure the producer class by setting the ``EVENT_BUS_PRODUCER`` setting. E.g., ``edx_event_bus_redis.create_producer``. -- In the consuming service, configure the consumer class by setting the ``EVENT_BUS_CONSUMER`` setting. E.g., ``edx_event_bus_redis.RedisEventConsumer``. +- In the :term:`producing ` service, configure the producer class by setting the ``EVENT_BUS_PRODUCER`` setting. E.g., ``edx_event_bus_redis.create_producer``. +- In the :term:`consuming ` service, configure the consumer class by setting the ``EVENT_BUS_CONSUMER`` setting. E.g., ``edx_event_bus_redis.RedisEventConsumer``. By configuring these settings, you are telling Open edX Events which concrete implementation to use for producing and consuming events. Produce the Event ~~~~~~~~~~~~~~~~~ -In the producing/host application, include ``openedx_events`` in ``INSTALLED_APPS`` settings and add ``EVENT_BUS_PRODUCER_CONFIG`` setting. This setting is a dictionary of event_types to dictionaries for topic-related configuration. Each topic configuration dictionary uses the topic as a key and contains: +In the producing/host application, include ``openedx_events`` in ``INSTALLED_APPS`` settings if necessary and add ``EVENT_BUS_PRODUCER_CONFIG`` setting. This setting is a dictionary of :term:`event types ` to dictionaries for :term:`Topic` related configuration. Each :term:`Topic` configuration dictionary uses the topic as a key and contains: - A flag called ``enabled`` denoting whether the event will be published. - The ``event_key_field`` which is a period-delimited string path to event data field to use as event key. .. note:: The topic names should not include environment prefix as it will be dynamically added based on ``EVENT_BUS_TOPIC_PREFIX`` setting. -Here's an example of the producer configuration which will publish events for XBlock published and deleted events to the specified topics: +Here's an example of the producer configuration which will publish events for XBlock published and deleted events to the specified :term:`Topic`: .. code-block:: python @@ -55,12 +55,12 @@ Here's an example of the producer configuration which will publish events for XB }, } -The ``EVENT_BUS_PRODUCER_CONFIG`` is read by ``openedx_events`` and a handler is attached which does the leg work of reading the configuration again and pushing to appropriate handlers. +The ``EVENT_BUS_PRODUCER_CONFIG`` is read by ``openedx_events`` and a handler (`general_signal_handler`_) is attached which does the leg work of reading the configuration again and pushing to appropriate handlers. Consume the Event ~~~~~~~~~~~~~~~~~ -In the consuming service, include ``openedx_events`` in ``INSTALLED_APPS`` settings and add ``EVENT_BUS_CONSUMER_CONFIG`` setting. Then, you should implement a receiver for the event type you are interested in. In this example, we are interested in the XBlock deleted event: +In the consuming service, include ``openedx_events`` in ``INSTALLED_APPS`` settings if necessary and add ``EVENT_BUS_CONSUMER_CONFIG`` setting. Then, you should implement a receiver for the event type you are interested in. In this example, we are interested in the XBlock deleted event: .. code-block:: python @@ -72,7 +72,7 @@ In the consuming service, include ``openedx_events`` in ``INSTALLED_APPS`` setti Run the Consumer ~~~~~~~~~~~~~~~~ -To consume events, Open edX Events provides a management command called `consume_events`_ which can be called from the command line, how to run this command will depend on your deployment strategy. This command will start a process that listens to the message broker for new messages, processes them and emits the event. +To consume events, Open edX Events provides a management command called `consume_events`_ which can be called from the command line, how to run this command will depend on your deployment strategy. This command will start a process that listens to the message broker for new messages, processes them and emits the event. Here is an example using of a `consumer using Tutor hosted in Kubernetes`_. You can find more a concrete example of how to produce and consume events in the `event-bus-redis`_ documentation. @@ -80,3 +80,5 @@ You can find more a concrete example of how to produce and consume events in the .. _event-bus-redis: https://github.com/openedx/event-bus-redis .. _run the consumer locally without tutor: https://github.com/openedx/event-bus-redis/?tab=readme-ov-file#testing-locally .. _run the consumer locally with tutor: https://github.com/openedx/event-bus-redis/blob/main/docs/tutor_installation.rst#setup-example-with-openedx-course-discovery-and-tutor +.. _general_signal_handler: https://github.com/openedx/openedx-events/blob/main/openedx_events/apps.py#L16-L44 +.. _consumer using Tutor hosted in Kubernetes: https://github.com/openedx/tutor-contrib-aspects/blob/master/tutoraspects/patches/k8s-deployments#L535-L588 From 2b24bcf633215c732d6f67b955b16840d9b13c89 Mon Sep 17 00:00:00 2001 From: Maria Grimaldi Date: Thu, 5 Dec 2024 00:16:52 +0100 Subject: [PATCH 05/12] refactor: add comparison between the event bus and async tasks --- .../event-bus-vs-asynchronous-tasks.png | Bin 0 -> 10573 bytes docs/concepts/event-bus.rst | 38 ++++++++++++++++++ 2 files changed, 38 insertions(+) create mode 100644 docs/_images/event-bus-vs-asynchronous-tasks.png diff --git a/docs/_images/event-bus-vs-asynchronous-tasks.png b/docs/_images/event-bus-vs-asynchronous-tasks.png new file mode 100644 index 0000000000000000000000000000000000000000..5e1ac69771327d5fb1b8e0de508f647f7b5becab GIT binary patch literal 10573 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 OMxrRECX19d5BfLoC{}g= literal 0 HcmV?d00001 diff --git a/docs/concepts/event-bus.rst b/docs/concepts/event-bus.rst index d49d244a..a6d68434 100644 --- a/docs/concepts/event-bus.rst +++ b/docs/concepts/event-bus.rst @@ -76,6 +76,44 @@ Workflow This approach of producing events via settings with the generic handler was chosen to allow for flexibility in the event bus implementation. It allows developers to choose the event bus implementation that best fits their needs, and to easily switch between implementations if necessary. See more details in the :doc:`../decisions/0012-producing-to-event-bus-via-settings` Architectural Decision Record (ADR). +Event Bus vs Asynchronous Tasks +------------------------------- + +Asynchronous tasks are used for long-running, resource-intensive operations that should not block the main thread of a service. The event bus is used for broadcasting messages to multiple services, allowing them to react to changes or actions in the system. Both can be used for asynchronous communication, they serve different purposes and have different workflows. + +In this diagram, you can see the difference between the two when it comes to asynchronous communication: + +.. image:: ../_images/event-bus-vs-asynchronous-tasks.png + :alt: Open edX Event Bus vs Asynchronous Tasks + :align: center + +In the upper part of the diagram, we have Service A and Service B. Service A is the producer of the event, and a :term:`Worker` of Service B is the consumer. This is the event bus workflow which allows asynchronous non-blocking communication between services: + +- Service A sends the event as a message to the event bus and continues its execution, as we previously explained. +- Service B polls the message broker for new messages and processes them. +- Service B re-emits the event with the data that was transmitted. +- Service C can also listen to the event and react to it. + +In the lower part of the diagram, we have the asynchronous tasks workflow: + +- A worker of Service A picks up a task which communicates with Service B via a request-response mechanism, such as HTTP. +- The worker of Service A sends a request to Service B and waits for a response. +- Service B processes the request and sends a response back to the worker. +- The worker receives the response and continues with the next step in its processing. + +If we were to introduce a Service C in this scenario, it would need to wait for the worker of Service A to finish processing the response from Service B and receive a response before it could continue. + +This is an example of an asynchronous approach (from the producer point of view) to send messages to another services but with a blocking nature. + +Use the Open edX Event bus instead of asynchronous tasks when: + +- You want to send a message but don't need a response. +- You need to send a high volume of messages to services. +- You want to broadcast messages to multiple services. +- You want to decouple services and avoid direct dependencies. + +When you need to send a message to a particular service and wait their response for further processing, use asynchronous tasks. + How is the Open edX Event Bus Used? ----------------------------------- From 68314560ee38cf928997d62fe4faf95c8c95c839 Mon Sep 17 00:00:00 2001 From: Maria Grimaldi Date: Thu, 5 Dec 2024 00:17:29 +0100 Subject: [PATCH 06/12] refactor: add note about redis being the community supported solution --- docs/how-tos/using-the-event-bus.rst | 22 ++++++++++++---------- 1 file changed, 12 insertions(+), 10 deletions(-) diff --git a/docs/how-tos/using-the-event-bus.rst b/docs/how-tos/using-the-event-bus.rst index 39814028..7be6174c 100644 --- a/docs/how-tos/using-the-event-bus.rst +++ b/docs/how-tos/using-the-event-bus.rst @@ -10,8 +10,8 @@ Setup To start producing and consuming events using the Open edX Event Bus, follow these steps: -Install the Open edX Event Bus Plugin -~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ +Step 1: Install the Open edX Event Bus Plugin +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ First, you need to install the Open edX Event Bus plugin in both the producing and consuming services. The plugin is a Django app that provides the necessary tools and configurations to produce and consume events. You could install the Redis plugin by running: @@ -19,8 +19,10 @@ First, you need to install the Open edX Event Bus plugin in both the producing a pip install edx-event-bus-redis -Configure the Event Bus -~~~~~~~~~~~~~~~~~~~~~~~ +.. note:: Redis is the community-supported plugin for the Open edX Event Bus and is the recommended plugin to use. You can find more information about the Redis plugin in the `event-bus-redis`_ repository. However, you can also implement your own plugin with your preferred message broker by following the :doc:`../how-tos/add-new-event-bus-concrete-implementation` documentation. + +Step 2: Configure the Event Bus +~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ In :doc:`../reference/event-bus-configurations`, you can find the available configurations for the event bus that are used to set up the event bus in the Open edX platform. @@ -31,8 +33,8 @@ In both the producing and consuming services, you need to configure the event bu By configuring these settings, you are telling Open edX Events which concrete implementation to use for producing and consuming events. -Produce the Event -~~~~~~~~~~~~~~~~~ +Step 3: Produce the Event +~~~~~~~~~~~~~~~~~~~~~~~~~ In the producing/host application, include ``openedx_events`` in ``INSTALLED_APPS`` settings if necessary and add ``EVENT_BUS_PRODUCER_CONFIG`` setting. This setting is a dictionary of :term:`event types ` to dictionaries for :term:`Topic` related configuration. Each :term:`Topic` configuration dictionary uses the topic as a key and contains: @@ -57,8 +59,8 @@ Here's an example of the producer configuration which will publish events for XB The ``EVENT_BUS_PRODUCER_CONFIG`` is read by ``openedx_events`` and a handler (`general_signal_handler`_) is attached which does the leg work of reading the configuration again and pushing to appropriate handlers. -Consume the Event -~~~~~~~~~~~~~~~~~ +Step 4: Consume the Event +~~~~~~~~~~~~~~~~~~~~~~~~~ In the consuming service, include ``openedx_events`` in ``INSTALLED_APPS`` settings if necessary and add ``EVENT_BUS_CONSUMER_CONFIG`` setting. Then, you should implement a receiver for the event type you are interested in. In this example, we are interested in the XBlock deleted event: @@ -69,8 +71,8 @@ In the consuming service, include ``openedx_events`` in ``INSTALLED_APPS`` setti ... do things with the data in kwargs ... ... log the event for debugging purposes ... -Run the Consumer -~~~~~~~~~~~~~~~~ +Step 5: Run the Consumer +~~~~~~~~~~~~~~~~~~~~~~~~ To consume events, Open edX Events provides a management command called `consume_events`_ which can be called from the command line, how to run this command will depend on your deployment strategy. This command will start a process that listens to the message broker for new messages, processes them and emits the event. Here is an example using of a `consumer using Tutor hosted in Kubernetes`_. From 5433d78eb7146cf7a8f48c1cf9379c51366a8b57 Mon Sep 17 00:00:00 2001 From: Maria Grimaldi Date: Thu, 5 Dec 2024 19:58:02 +0100 Subject: [PATCH 07/12] refactor: make clear that service converts messages into signals --- docs/concepts/event-bus.rst | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/concepts/event-bus.rst b/docs/concepts/event-bus.rst index a6d68434..67c50e5a 100644 --- a/docs/concepts/event-bus.rst +++ b/docs/concepts/event-bus.rst @@ -90,8 +90,8 @@ In this diagram, you can see the difference between the two when it comes to asy In the upper part of the diagram, we have Service A and Service B. Service A is the producer of the event, and a :term:`Worker` of Service B is the consumer. This is the event bus workflow which allows asynchronous non-blocking communication between services: - Service A sends the event as a message to the event bus and continues its execution, as we previously explained. -- Service B polls the message broker for new messages and processes them. -- Service B re-emits the event with the data that was transmitted. +- Service B polls the message broker for new messages and converts them into ``OpenEdxPublicSignal``. +- Service B emits the event locally and registered Django Signal receivers can react to it. - Service C can also listen to the event and react to it. In the lower part of the diagram, we have the asynchronous tasks workflow: From 531e910d4eebd40e2f342e4864e1b5066810b222 Mon Sep 17 00:00:00 2001 From: Maria Grimaldi Date: Thu, 5 Dec 2024 20:19:17 +0100 Subject: [PATCH 08/12] refactor: mention that external services can also consume events --- docs/concepts/event-bus.rst | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/docs/concepts/event-bus.rst b/docs/concepts/event-bus.rst index 67c50e5a..1e582da3 100644 --- a/docs/concepts/event-bus.rst +++ b/docs/concepts/event-bus.rst @@ -107,10 +107,10 @@ This is an example of an asynchronous approach (from the producer point of view) Use the Open edX Event bus instead of asynchronous tasks when: -- You want to send a message but don't need a response. -- You need to send a high volume of messages to services. -- You want to broadcast messages to multiple services. +- You want to send a message but don't need a response. For example, notifying other services of an event that occurred. +- You need to send a high volume of messages to a single or multiple services. For example, notifying when users visit a unit in a course or watch a video. - You want to decouple services and avoid direct dependencies. +- You want to send events out of the Open edX ecosystem. For example, external databases or services that can consume events to update their own state. When you need to send a message to a particular service and wait their response for further processing, use asynchronous tasks. From 0615ccd465e5a5527e8d185c1b4458fa6edb52a7 Mon Sep 17 00:00:00 2001 From: Maria Grimaldi Date: Thu, 5 Dec 2024 20:33:43 +0100 Subject: [PATCH 09/12] refactor: make a note about redis and kafka being both community supported --- docs/how-tos/using-the-event-bus.rst | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/docs/how-tos/using-the-event-bus.rst b/docs/how-tos/using-the-event-bus.rst index 7be6174c..45098c33 100644 --- a/docs/how-tos/using-the-event-bus.rst +++ b/docs/how-tos/using-the-event-bus.rst @@ -19,7 +19,7 @@ First, you need to install the Open edX Event Bus plugin in both the producing a pip install edx-event-bus-redis -.. note:: Redis is the community-supported plugin for the Open edX Event Bus and is the recommended plugin to use. You can find more information about the Redis plugin in the `event-bus-redis`_ repository. However, you can also implement your own plugin with your preferred message broker by following the :doc:`../how-tos/add-new-event-bus-concrete-implementation` documentation. +.. note:: There are currently two community-supported concrete implementations of the Open edX Events Bus, Redis (`event-bus-redis`_) and Kafka (`event-bus-kafka`_). Redis is the default plugin for the Open edX Event Bus, but you can also use Kafka depending on your requirements. If none of these implementations meet your needs, you can implement your own plugin by following the :doc:`../how-tos/add-new-event-bus-concrete-implementation` documentation. Step 2: Configure the Event Bus ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ @@ -80,6 +80,7 @@ You can find more a concrete example of how to produce and consume events in the .. _consume_events: https://github.com/openedx/openedx-events/blob/main/openedx_events/management/commands/consume_events.py .. _event-bus-redis: https://github.com/openedx/event-bus-redis +.. _event-bus-kafka: https://github.com/openedx/event-bus-kafka .. _run the consumer locally without tutor: https://github.com/openedx/event-bus-redis/?tab=readme-ov-file#testing-locally .. _run the consumer locally with tutor: https://github.com/openedx/event-bus-redis/blob/main/docs/tutor_installation.rst#setup-example-with-openedx-course-discovery-and-tutor .. _general_signal_handler: https://github.com/openedx/openedx-events/blob/main/openedx_events/apps.py#L16-L44 From dc5d29e43d1e1d87504b649a8ea55e812ddc322e Mon Sep 17 00:00:00 2001 From: Maria Grimaldi Date: Thu, 5 Dec 2024 20:36:10 +0100 Subject: [PATCH 10/12] fix: remove trailing spaces --- docs/how-tos/using-the-event-bus.rst | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/how-tos/using-the-event-bus.rst b/docs/how-tos/using-the-event-bus.rst index 45098c33..17a9256d 100644 --- a/docs/how-tos/using-the-event-bus.rst +++ b/docs/how-tos/using-the-event-bus.rst @@ -19,7 +19,7 @@ First, you need to install the Open edX Event Bus plugin in both the producing a pip install edx-event-bus-redis -.. note:: There are currently two community-supported concrete implementations of the Open edX Events Bus, Redis (`event-bus-redis`_) and Kafka (`event-bus-kafka`_). Redis is the default plugin for the Open edX Event Bus, but you can also use Kafka depending on your requirements. If none of these implementations meet your needs, you can implement your own plugin by following the :doc:`../how-tos/add-new-event-bus-concrete-implementation` documentation. +.. note:: There are currently two community-supported concrete implementations of the Open edX Events Bus, Redis (`event-bus-redis`_) and Kafka (`event-bus-kafka`_). Redis is the default plugin for the Open edX Event Bus, but you can also use Kafka depending on your requirements. If none of these implementations meet your needs, you can implement your own plugin by following the :doc:`../how-tos/add-new-event-bus-concrete-implementation` documentation. Step 2: Configure the Event Bus ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ From 7e091e916e756172ca7aeceda49797c45f4a9106 Mon Sep 17 00:00:00 2001 From: Maria Grimaldi Date: Mon, 9 Dec 2024 12:12:43 +0100 Subject: [PATCH 11/12] fix: use references to the local event bus docs --- docs/concepts/openedx-events.rst | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/docs/concepts/openedx-events.rst b/docs/concepts/openedx-events.rst index c883aceb..350dcea4 100644 --- a/docs/concepts/openedx-events.rst +++ b/docs/concepts/openedx-events.rst @@ -15,7 +15,7 @@ These events are built on top of Django signals, inheriting their behavior while Django includes a "signal dispatcher" which helps decoupled applications get notified when actions occur elsewhere in the framework. In a nutshell, signals allow certain senders to notify a set of receivers that some action has taken place. They're especially useful when many pieces of code may be interested in the same events. -Events are primarily used as a communication method between internal services by leveraging Django Signals and external services using the `Event Bus technology`_, making them the standard communication mechanism within the Open edX ecosystem. +Events are primarily used as a communication method between internal services by leveraging Django Signals and external services using the :doc:`../concepts/event-bus`, making them the standard communication mechanism within the Open edX ecosystem. How do Open edX Events work? ---------------------------- @@ -73,7 +73,7 @@ The `Django Signals Documentation`_ provides a more detailed explanation of how How are Open edX Events used? ----------------------------- -As mentioned previously, developers can listen to Open edX Events by registering signal receivers from their Open edX Django plugins that respond to the emitted events or by using the `Event Bus technology`_ to send events to external services. +As mentioned previously, developers can listen to Open edX Events by registering signal receivers from their Open edX Django plugins that respond to the emitted events or by using the :doc:`../concepts/event-bus` to send events to external services. For more information on using Open edX Events, refer to the :doc:`../how-tos/using-events` how-to guide. We also encourage you to explore the :doc:`../reference/real-life-use-cases` section for real-life examples of how Open edX Events are used by the community. From 99ffa529850f9282581df7b6e9327809749b0eda Mon Sep 17 00:00:00 2001 From: Maria Grimaldi Date: Tue, 10 Dec 2024 11:35:02 +0100 Subject: [PATCH 12/12] docs: add missing connector to sentence --- docs/concepts/event-bus.rst | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/concepts/event-bus.rst b/docs/concepts/event-bus.rst index 1e582da3..9c84cceb 100644 --- a/docs/concepts/event-bus.rst +++ b/docs/concepts/event-bus.rst @@ -79,7 +79,7 @@ This approach of producing events via settings with the generic handler was chos Event Bus vs Asynchronous Tasks ------------------------------- -Asynchronous tasks are used for long-running, resource-intensive operations that should not block the main thread of a service. The event bus is used for broadcasting messages to multiple services, allowing them to react to changes or actions in the system. Both can be used for asynchronous communication, they serve different purposes and have different workflows. +Asynchronous tasks are used for long-running, resource-intensive operations that should not block the main thread of a service. The event bus is used for broadcasting messages to multiple services, allowing them to react to changes or actions in the system. Both can be used for asynchronous communication, but they serve different purposes and have different workflows. In this diagram, you can see the difference between the two when it comes to asynchronous communication: