Skip to main content
Version: Draft

AsyncAPI Specifications

The AsyncAPI Specification is a project used to describe and document message-driven APIs in a machine-readable format. It’s protocol-agnostic, so you can use it for APIs that work over any protocol (e.g., AMQP, MQTT, WebSockets, Kafka, HTTP, etc).

The AsyncAPI Specification defines a set of files required to describe such an API. These files can then be used to create utilities, such as documentation, integration and/or testing tools.

AsyncAPI Specification Structure

ComponentDescriptionRequirement
AsyncAPI specificationThe core specificationAll mandatory fields defined in the specification itself
Property descriptionsA human readable description of a property defined in an AsyncAPI specification. Descriptions should be relatively verbose and provide enough information to enable the reader to understand the purpose of the property being described.Specification authors MUST provide descriptions for all properties

AsyncAPI Section

PropertyDescriptionRequirement
asyncapiThe version of the AsyncAPI specification being usedMUST

Info Section

The info section of an AsyncAPI specification contains details on the API Provider.

PropertyDescriptionRequirement
info.titleThe title of the APIMUST
info.descriptionSee Property DescriptionsMUST
info.licenseinfo.license.name MUST info.license.url MUST
info.versionThe version of the APIMUST
info.contactContains details on appropriate mechanism for contacting the API Providerinfo.contact.name MUST info.contact.url MUST

Servers Section

PropertyDescriptionRequirement
servers.urlThe API Provider hostMUST
servers.protocolThe protocol supported by this API Provider hostMUST
servers.securityThe security mechanisms which can be used with this serverMUST
servers.descriptionAdditional information about this server such as the environmentSHOULD

Channels Section

Holds the relative paths to the individual channel and their operations. Channel paths are relative to servers. Channels are also known as "topics", "routing keys", "event types" or "paths". Note that the structure of this section has changed significantly between versions 2 and 3 of the specification.

The below details describe what is expected, through different properties across versions.

  • the address field in v3+ of the specification MUST contain the topic name. If using v2, this MUST be included in the description field
  • the servers field MUST be used in indicate which servers where the channel is available for consumption
  • the messages field in v3+ of the specification MUST be used to represent the messages which are published to a channel. In v2, the message field under the publish or subscribe field MUST be used

External Docs Section

PropertyDescriptionRequirement
externalDocs.urlA URL for further documentation about about the API.MUST

Property Descriptions

AsyncAPI property descriptions are intended to be used by API Consumer developers to understand the purpose of a specification property. Description fields support CommonMark Syntax which SHOULD be used as it enables formatting supported by most rich text OpenAPI tooling.

AsyncAPI Validation

The AsyncAPI document MUST pass validation against the AsyncAPI specification. There are a number of tools available which can perform validation such as the online Swagger Editor. This validation can be added into an automated pipeline or within a developer IDE.