amqp

Go client for AMQP 0.9.1

  • Owner: streadway/amqp
  • Platform:
  • License:: BSD 2-Clause "Simplified" License
  • Category::
  • Topic:
  • Like:
    0
      Compare:

Github stars Tracking Chart

Build Status GoDoc

Go RabbitMQ Client Library

This is an AMQP 0.9.1 client with RabbitMQ extensions in Go.

Project Maturity

This project has been used in production systems for many years. It is reasonably mature
and feature complete, and as of November 2016 has a team of maintainers.

Future API changes are unlikely but possible. They will be discussed on Github
issues
along with any bugs or
enhancements.

Supported Go Versions

This library supports two most recent Go release series, currently 1.10 and 1.11.

Supported RabbitMQ Versions

This project supports RabbitMQ versions starting with 2.0 but primarily tested
against reasonably recent 3.x releases. Some features and behaviours may be
server version-specific.

Goals

Provide a functional interface that closely represents the AMQP 0.9.1 model
targeted to RabbitMQ as a server. This includes the minimum necessary to
interact the semantics of the protocol.

Non-goals

Things not intended to be supported.

  • Auto reconnect and re-synchronization of client and server topologies.
    • Reconnection would require understanding the error paths when the
      topology cannot be declared on reconnect. This would require a new set
      of types and code paths that are best suited at the call-site of this
      package. AMQP has a dynamic topology that needs all peers to agree. If
      this doesn't happen, the behavior is undefined. Instead of producing a
      possible interface with undefined behavior, this package is designed to
      be simple for the caller to implement the necessary connection-time
      topology declaration so that reconnection is trivial and encapsulated in
      the caller's application code.
  • AMQP Protocol negotiation for forward or backward compatibility.
    • 0.9.1 is stable and widely deployed. Versions 0.10 and 1.0 are divergent
      specifications that change the semantics and wire format of the protocol.
      We will accept patches for other protocol support but have no plans for
      implementation ourselves.
  • Anything other than PLAIN and EXTERNAL authentication mechanisms.
    • Keeping the mechanisms interface modular makes it possible to extend
      outside of this package. If other mechanisms prove to be popular, then
      we would accept patches to include them in this package.

Usage

See the 'examples' subdirectory for simple producers and consumers executables.
If you have a use-case in mind which isn't well-represented by the examples,
please file an issue.

Documentation

Use Godoc documentation for
reference and usage.

RabbitMQ tutorials in
Go
are also
available.

Contributing

Pull requests are very much welcomed. Create your pull request on a non-master
branch, make sure a test or example is included that covers your change and
your commits represent coherent changes that include a reason for the change.

To run the integration tests, make sure you have RabbitMQ running on any host,
export the environment variable AMQP_URL=amqp://host/ and run go test -tags integration. TravisCI will also run the integration tests.

Thanks to the community of contributors.

External packages

License

BSD 2 clause - see LICENSE for more details.

Main metrics

Overview
Name With Ownerstreadway/amqp
Primary LanguageGo
Program languageGo (Language Count: 2)
Platform
License:BSD 2-Clause "Simplified" License
所有者活动
Created At2012-04-25 22:11:52
Pushed At2023-09-07 02:58:29
Last Commit At2023-06-19 14:39:15
Release Count2
Last Release Namev1.1.0 (Posted on )
First Release Namev1.0.0 (Posted on )
用户参与
Stargazers Count4.9k
Watchers Count101
Fork Count620
Commits Count537
Has Issues Enabled
Issues Count369
Issue Open Count73
Pull Requests Count104
Pull Requests Open Count21
Pull Requests Close Count46
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private