Centrifugo alternatives and similar packages
Based on the "Messaging" category.
Alternatively, view Centrifugo alternatives based on common mentions on social networks and blogs.
-
sarama
Sarama is a Go library for Apache Kafka. [Moved to: https://github.com/IBM/sarama] -
machinery
Machinery is an asynchronous task queue/job queue based on distributed message passing. -
NATS Go Client
Golang client for NATS, the cloud native messaging system. -
Confluent Kafka Golang Client
Confluent's Apache Kafka Golang client -
Mercure
An open, easy, fast, reliable and battery-efficient solution for real-time communications -
APNs2
⚡ HTTP/2 Apple Push Notification Service (APNs) push provider for Go — Send push notifications to iOS, tvOS, Safari and OSX apps, using the APNs HTTP/2 protocol. -
Uniqush-Push
Uniqush is a free and open source software system which provides a unified push service for server side notification to apps on mobile devices. -
Chanify
Chanify is a safe and simple notification tools. This repository is command line tools for Chanify. -
amqp
An AMQP 0-9-1 Go client maintained by the RabbitMQ team. Originally by @streadway: `streadway/amqp` -
mangos
mangos is a pure Golang implementation of nanomsg's "Scalablilty Protocols" -
PingMe
PingMe is a CLI which provides the ability to send messages or alerts to multiple messaging platforms & email. -
emitter
Emits events in Go way, with wildcard, predicates, cancellation possibilities and many other good wins -
Bus
🔊Minimalist message bus implementation for internal communication with zero-allocation magic on Emit -
redisqueue
redisqueue provides a producer and consumer of a queue that uses Redis streams -
go-mq
Declare AMQP entities like queues, producers, and consumers in a declarative way. Can be used to work with RabbitMQ. -
nsq-event-bus
A tiny wrapper around NSQ topic and channel :rocket: -
drone-line
Sending line notifications using a binary, docker or Drone CI. -
go-events
:mega: Pure nodejs EventEmmiter for the Go Programming Language. -
Ratus
Ratus is a RESTful asynchronous task queue server. It translated concepts of distributed task queues into a set of resources that conform to REST principles and provides a consistent HTTP API for various backends. -
RapidMQ
RapidMQ is a pure, extremely productive, lightweight and reliable library for managing of the local messages queue -
go-notify
Package notify provides an implementation of the Gnome DBus Notifications Specification. -
Commander
Build event-driven and event streaming applications with ease -
structured pubsub
Publish and subscribe functionality within a single process in Go. -
go-vitotrol
golang client library to Viessmann Vitotrol web service -
go-longpoll
Parked: PubSub queuing with long-polling subscribers (not bound to http) -
jazz
Abstraction layer for simple rabbitMQ connection, messaging and administration
Free Global Payroll designed for tech teams
Do you think we are missing an alternative of Centrifugo or a related project?
README
Centrifugo is an open-source scalable real-time messaging server. Centrifugo can instantly deliver messages to application online users connected over supported transports (WebSocket, HTTP-streaming, SSE/EventSource, GRPC, SockJS, WebTransport). Centrifugo has the concept of a channel – so it's a user-facing PUB/SUB server.
Centrifugo is language-agnostic and can be used to build chat apps, live comments, multiplayer games, real-time data visualizations, collaborative tools, etc. in combination with any backend. It is well suited for modern architectures and allows decoupling the business logic from the real-time transport layer.
Several official client SDKs for browser and mobile development wrap the bidirectional protocol. In addition, Centrifugo supports a unidirectional approach for simple use cases with no SDK dependency.
For details, go to the Centrifugo documentation site.
How to install
See installation instructions in Centrifugo documentation.
Highlights
- Centrifugo is fast and capable to scale to millions of simultaneous connections
- Simple integration with any application – Centrifugo works as a separate service, provides HTTP and GRPC API
- Client real-time SDKs for popular frontend environments – for both web and mobile development
- Strict client protocol based on Protobuf schema, with JSON and binary data transfer support
- Bidirectional transport support (WebSocket and SockJS) for full-featured communication
- Unidirectional transport support for simple use cases with zero SDK dependency - use native APIs (SSE, Fetch, WebSocket, GRPC)
- User authentication with JWT or over connection request proxy to the configured HTTP/GRPC endpoint
- Proper connection management and expiration control
- Various types of channel subscriptions: client-side or server-side
- Transform RPC calls sent over real-time transport to the configured HTTP or GRPC endpoint calls
- Presence information for channels (show all active clients in a channel)
- History information for channels (last messages published into a channel)
- Join/leave events for channels (client subscribed/unsubscribed)
- Automatic recovery of missed messages between reconnects over configured retention period
- Built-in administrative web panel
- Cross-platform – works on Linux, macOS and Windows
- Ready to deploy (Docker, RPM/DEB packages, automatic TLS certificates, Prometheus instrumentation, Grafana dashboard)
- Open-source license
Backing
This repository is hosted by packagecloud.io.
Also thanks to JetBrains for supporting OSS (most of the code here written in Goland):
*Note that all licence references and agreements mentioned in the Centrifugo README section above
are relevant to that project's source code only.