Skip to main content
Redhat Developers  Logo
  • AI

    Get started with AI

    • Red Hat AI
      Accelerate the development and deployment of enterprise AI solutions.
    • AI learning hub
      Explore learning materials and tools, organized by task.
    • AI interactive demos
      Click through scenarios with Red Hat AI, including training LLMs and more.
    • AI/ML learning paths
      Expand your OpenShift AI knowledge using these learning resources.
    • AI quickstarts
      Focused AI use cases designed for fast deployment on Red Hat AI platforms.
    • No-cost AI training
      Foundational Red Hat AI training.

    Featured resources

    • OpenShift AI learning
    • Open source AI for developers
    • AI product application development
    • Open source-powered AI/ML for hybrid cloud
    • AI and Node.js cheat sheet

    Red Hat AI Factory with NVIDIA

    • Red Hat AI Factory with NVIDIA is a co-engineered, enterprise-grade AI solution for building, deploying, and managing AI at scale across hybrid cloud environments.
    • Explore the solution
  • Learn

    Self-guided

    • Documentation
      Find answers, get step-by-step guidance, and learn how to use Red Hat products.
    • Learning paths
      Explore curated walkthroughs for common development tasks.
    • See all learning

    Hands-on

    • Developer Sandbox
      Spin up Red Hat's products and technologies without setup or configuration.
    • Interactive labs
      Learn by doing in these hands-on, browser-based experiences.
    • Interactive demos
      Click through product features in these guided tours.

    Browse by topic

    • AI/ML
    • Automation
    • Java
    • Kubernetes
    • Linux
    • See all topics

    Training & certifications

    • Courses and exams
    • Certifications
    • Skills assessments
    • Red Hat Academy
    • Learning subscription
    • Explore training
  • Build

    Get started

    • Red Hat build of Podman Desktop
      A downloadable, local development hub to experiment with our products and builds.
    • Developer Sandbox
      Spin up Red Hat's products and technologies without setup or configuration.

    Download products

    • Access product downloads to start building and testing right away.
    • Red Hat Enterprise Linux
    • Red Hat AI
    • Red Hat OpenShift
    • Red Hat Ansible Automation Platform
    • See all products

    Featured

    • Red Hat build of OpenJDK
    • Red Hat JBoss Enterprise Application Platform
    • Red Hat OpenShift Dev Spaces
    • Red Hat Developer Toolset

    References

    • E-books
    • Documentation
    • Cheat sheets
    • Architecture center
  • Community

    Get involved

    • Events
    • Live AI events
    • Red Hat Summit
    • Red Hat Accelerators
    • Community discussions

    Follow along

    • Articles & blogs
    • Developer newsletter
    • Videos
    • Github

    Get help

    • Customer service
    • Customer support
    • Regional contacts
    • Find a partner

    Join the Red Hat Developer program

    • Download Red Hat products and project builds, access support documentation, learning content, and more.
    • Explore the benefits

Processing CloudEvents with Eclipse Vert.x

<p>&nbsp;</p> <quillbot-extension-portal></quillbot-extension-portal>

December 11, 2018
Matthias Wessendorf
Related topics:
Event-drivenJavaKubernetesServerless
Related products:
Red Hat build of Eclipse Vert.x

    Our connected world is full of events that are triggered or received by different software services. One of the big issues is that event publishers tend to describe events differently and in ways that are mostly incompatible with each other.

    To address this, the Serverless Working Group from the Cloud Native Computing Foundation (CNCF) recently announced version 0.2 of the CloudEvents specification. The specification aims to describe event data in a common, standardized way. To some degree, a CloudEvent is an abstract envelope with some specified attributes that describe a concrete event and its data.

    Working with CloudEvents is simple. This article shows how to use the powerful JVM toolkit provided by Vert.x to either generate or receive and process CloudEvents.

    SDKs for working with CloudEvents

    In addition to the specification, the CloudEvents team from the Serverless Working Group is working on different SDKs for various platforms, such as JavaScript, Golang, C Sharp, Java, and Python. This article will give a quick overview of the Java SDK and how it can be used inside an application built with Eclipse Vert.x.

    The API is very simple and contains a generic CloudEvent class as well as a builder to create an instance of a CloudEvent:

    final CloudEvent<MyCustomEvent> cloudEvent = new CloudEventBuilder<MyCustomEvent>()
        .data(new MyCustomEvent(...))
        .type("My.Cloud.Event.Type")
        .id(UUID.randomUUID().toString();)
        .source(URI.create("/trigger");)
        .build();

    Above, we use the CloudEventBuilder to create a very simple CloudEvent instance. However, in isolation, the API does not show its strength.

    Eclipse Vert.x

    Eclipse Vert.x is a toolkit for building reactive applications on the JVM. It is event-driven and nonblocking, which means applications can handle a lot of concurrency using a small number of kernel threads. See the resources below for more info on Vert.x. Fortun

    Fortunately, support for Eclipse Vert.x is included in the CloudEvents Java SDK:

    <dependency>
        <groupId>io.cloudevents</groupId>
        <artifactId>http-vertx</artifactId>
        <version>0.2.0</version>
    </dependency>

    Sending a CloudEvent to a remote service

    Now that we have our CloudEvent object, capturing our event data, we want to send it to a remote cloud service, which will then process it:

    final HttpClientRequest request = vertx.createHttpClient().post(8080, "localhost", "/");
    
    // add a client response handler
    request.handler(resp -> {
        // react on the server response
    });
    
    // write the CloudEvent to the given HTTP Post request object
    VertxCloudEvents.create().writeToHttpClientRequest(cloudEvent, request);
    request.end();
    

    After creating an HTTP Post request, we set up an async handler to deal with the future response of the server. Finally, the writeToHttpClientRequest of our VertxCloudEvents utility is used to serialize the actual CloudEvent object to the given HttpClientRequest.

    Receiving CloudEvents with Vert.x

    The VertxCloudEvents utility also contains a different function to receive a CloudEvent inside an Eclipse Vert.x HTTP server application:

    import io.cloudevents.http.reactivex.vertx.VertxCloudEvents;
    import io.vertx.core.http.HttpHeaders;
    import io.vertx.reactivex.core.AbstractVerticle;
    
    public class CloudEventVerticle extends AbstractVerticle {
    
      public void start() {
    
        vertx.createHttpServer()
          .requestHandler(req -> VertxCloudEvents.create().rxReadFromRequest(req)
          .subscribe((receivedEvent, throwable) -> {
            if (receivedEvent != null) {
              // I got a CloudEvent object:
              System.out.println("The event type: " + receivedEvent.getType())
            }
          }))
          .rxListen(8080)
          .subscribe(server -> {
            System.out.println("Server running!");
        });
      }
    }

    Above, we start a simple HTTPServer, using the Vert.x API for RxJava 2. Inside the reactive request handler, we invoke the rxReadFromRequest() method and subscribe to the CloudEvents it returns for further processing. Now we can work with the CloudEvent object inside our own server-side framework!

    Conclusion and Outlook

    Working with CloudEvents is simple and Vert.x provides a powerful JVM toolkit to either generate or receive and process CloudEvents in our system. CloudEvents are being adopted by more and more tools and frameworks such as Knative, which uses CloudEvents to exchange data between different components and services in a standardized format.

    The CloudEvent specification is in its early stages with its current 0.2 version. However, even in such infancy, it is generating traction and proving an increasingly useful specification to allow interoperability between applications.

    Additonal Resources

    • Vert.x:
      • Building Reactive Microservices in Java: Asynchronous and Event-Based Application Design, a free ebook
      • Introduction to Vert.x article series by Clement Escoffier
        • Part 1—Introduction to Vert.x - My First Vert.x Application
        • Part 2—Eclipse Vert.x Application Configuration
        • Part 3—Some REST with Vert.x
        • Part 4—Accessing Data, the Reactive Way
        • Part 5—When Vert.x meets Reactive eXtensions
    • CloudEvents:
      • EventFlow: Event-driven microservices on Red Hat OpenShift

     

    Last updated: January 12, 2024

    Recent Posts

    • Federated identity across the hybrid cloud using zero trust workload identity manager

    • Confidential virtual machine storage attack scenarios

    • Introducing virtualization platform autopilot

    • Integrate zero trust workload identity manager with Red Hat OpenShift GitOps

    • Best Practice Configuration and Tuning for Linux and Windows VMs

    Red Hat Developers logo LinkedIn YouTube Twitter Facebook

    Platforms

    • Red Hat AI
    • Red Hat Enterprise Linux
    • Red Hat OpenShift
    • Red Hat Ansible Automation Platform
    • See all products

    Build

    • Developer Sandbox
    • Developer tools
    • Interactive tutorials
    • API catalog

    Quicklinks

    • Learning resources
    • E-books
    • Cheat sheets
    • Blog
    • Events
    • Newsletter

    Communicate

    • About us
    • Contact sales
    • Find a partner
    • Report a website issue
    • Site status dashboard
    • Report a security problem

    RED HAT DEVELOPER

    Build here. Go anywhere.

    We serve the builders. The problem solvers who create careers with code.

    Join us if you’re a developer, software engineer, web designer, front-end designer, UX designer, computer scientist, architect, tester, product manager, project manager or team lead.

    Sign me up

    Red Hat legal and privacy links

    • About Red Hat
    • Jobs
    • Events
    • Locations
    • Contact Red Hat
    • Red Hat Blog
    • Inclusion at Red Hat
    • Cool Stuff Store
    • Red Hat Summit
    © 2026 Red Hat

    Red Hat legal and privacy links

    • Privacy statement
    • Terms of use
    • All policies and guidelines
    • Digital accessibility

    Chat Support

    Please log in with your Red Hat account to access chat support.