sarama VS Redis

Compare sarama vs Redis and see what are their differences.

sarama

Sarama is a Go library for Apache Kafka. [Moved to: https://github.com/IBM/sarama] (by Shopify)
InfluxDB - Power Real-Time Data Analytics at Scale
Get real-time insights from all types of time series data with InfluxDB. Ingest, query, and analyze billions of data points in real-time with unbounded cardinality.
www.influxdata.com
featured
SaaSHub - Software Alternatives and Reviews
SaaSHub helps you find the best software and product alternatives
www.saashub.com
featured
sarama Redis
20 32
10,115 19,322
- 0.9%
8.6 8.8
10 months ago 5 days ago
Go Go
MIT License BSD 2-clause "Simplified" License
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

sarama

Posts with mentions or reviews of sarama. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-07-13.
  • Ingesting Data into OpenSearch using Apache Kafka and Go
    6 projects | dev.to | 13 Jul 2023
    Note: Since there are multiple Go clients for Kafka (including Sarama), please make sure to consult their client documentation to confirm whether they support IAM authentication.
  • book about golang and kafka
    6 projects | /r/golang | 4 Jun 2023
    You might want to gradually replace that one with https://github.com/twmb/franz-go because Shopify is looking to find a new owner for Sarama and, until or if they do, it seems to be falling behind with maintenance: https://github.com/Shopify/sarama/issues/2461 For example, they still haven’t addressed this breaking change https://github.com/Shopify/sarama/issues/2358. franz-go has worked well so far in Benthos https://github.com/benthosdev/benthos/tree/main/internal/impl/kafka and it will likely end up as the only implementation once the Sarama-based one will be deprecated
  • Klient - a native, statically-compiled, command line client for Kafka
    3 projects | /r/golang | 10 Feb 2023
    I've used mainly sarama wrapped with a bit of bespoke helper libraries. Never really looked into others, just grabbed one that was actively maintained and went for it.
  • Golang bad design reference
    6 projects | /r/golang | 23 Nov 2022
    Well, as someone who reviews a lot of code, I don't like seeing 100s of little files when a handful of logically grouped files would do. For example, this popular go project: https://github.com/Shopify/sarama is currently 256 small .go files, largely following a one class/file rule.
  • Concurrency in Go is hard
    2 projects | dev.to | 29 Aug 2022
    The first example is something we ran into while working on a project. Up until recently, the sarama library (Go library for Apache Kafka) contained the following piece of code (at sarama/version.go):
  • AWS MSK with go sarama
    1 project | /r/aws | 8 Aug 2022
    Im using the go sarama library to connect to the cluster, using this basic example.
  • Benthos - Fancy stream processing made operationally mundane
    4 projects | /r/dataengineering | 8 Jun 2022
    If you find the kafka input slow, try kafka_franz. It might be a bit faster, since it’s based on https://github.com/twmb/franz-go. The kafka one is based on https://github.com/Shopify/sarama. You can also write a custom input based on https://github.com/confluentinc/confluent-kafka-go, but this library relies on CGo, which can be annoying.
  • Sarama - Go library for Apache Kafka.
    1 project | /r/github_trends | 15 May 2022
  • Understanding Kafka with Factorio
    2 projects | news.ycombinator.com | 26 Nov 2021
  • Is segmentio/kafka-go production ready ?
    2 projects | /r/apachekafka | 1 Jun 2021
    There are a few factors that are stopping me from using kafka-go over Shopify's sarama.

Redis

Posts with mentions or reviews of Redis. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-12-07.
  • Using IAM authentication for Redis on AWS
    2 projects | dev.to | 7 Dec 2023
    MemoryDB documentation has an example for a Java application with the Lettuce client. The process is similar for other languages, but you still need to implement it. So, let's learn how to do it for a Go application with the widely used go-redis client.
  • Unexpected behavior from Redis cluster client - Keys not being found even if they exist in the cluster
    1 project | /r/golang | 27 Oct 2023
    We have setup a redis cluster with 3 master, and 3 slave nodes using redis-go package (https://github.com/redis/go-redis).
  • Building RESTful API with Hexagonal Architecture in Go
    21 projects | dev.to | 27 Sep 2023
    For building the RESTful Point of Sale service API, I've considered and selected a combination of technologies that would work seamlessly together. For handling HTTP requests and responses, using the Gin HTTP web framework would make sense because I think it seems complete and popular among Go community too. To ensure data integrity and persistence, I'm using PostgreSQL database with pgx as the database driver, the reason I choose PostgreSQL because it is the most popular relational database to use in production and offers efficient Go integration. I'm also implementing caching using Redis with go-redis client library, which provides powerful in-memory data storage capabilities.
  • Authentication system using Golang and Sveltekit - Initialization and setup
    7 projects | dev.to | 2 Jun 2023
    Following the completion of the series — Secure and performant full-stack authentication system using rust (actix-web) and sveltekit and Secure and performant full-stack authentication system using Python (Django) and SvelteKit — I felt I should keep the streak by building an equivalent system in PURE go with very minimal external dependencies. We won't use any fancy web framework apart from httprouter and other basic dependencies including a database driver (pq), and redis client. As usual, we'll be using SvelteKit at the front end, favouring JSDoc instead of TypeScript. The combination is ecstatic!
  • Go linter and helper for the OpenTelemetry SDK
    3 projects | /r/golang | 17 May 2023
  • Redis with golang
    3 projects | /r/redis | 26 Mar 2023
  • Tools besides Go for a newbie
    36 projects | /r/golang | 26 Mar 2023
    IDE: use whatever make you productive. I personally use vscode. VCS: git, as golang communities use github heavily as base for many libraries. AFAIK Linter: use staticcheck for linting as it looks like mostly used linting tool in go, supported by many also. In Vscode it will be recommended once you install go plugin. Libraries/Framework: actually the standard libraries already included many things you need, decent enough for your day-to-day development cycles(e.g. `net/http`). But here are things for extra: - Struct fields validator: validator - Http server lib: chi router , httprouter , fasthttp (for non standard http implementations, but fast) - Web Framework: echo , gin , fiber , beego , etc - Http client lib: most already covered by stdlib(net/http), so you rarely need extra lib for this, but if you really need some are: resty - CLI: cobra - Config: godotenv , viper - DB Drivers: sqlx , postgre , sqlite , mysql - nosql: redis , mongodb , elasticsearch - ORM: gorm , entgo , sqlc(codegen) - JS Transpiler: gopherjs - GUI: fyne - grpc: grpc - logging: zerolog - test: testify , gomock , dockertest - and many others you can find here
  • Should I reuse the connection on Redis or close it after every use?
    2 projects | /r/golang | 21 Dec 2022
    Asynq uses https://github.com/go-redis/redis in order to connect to Redis. Whenever you create a client using go-redis, the client internally manages a connection pool, so when you need to execute a command in Redis the client just retrieves a connection from the pool and uses it. After using it, the connection is released and it goes back to the pool (no need to say that the Redis client is thread-safe).
  • a tool for quickly creating web and microservice code
    28 projects | dev.to | 15 Dec 2022
    Caching component go-redis ristretto
  • Storage Layer 📦
    1 project | dev.to | 20 Oct 2022
    First thing first, we will install Redis client for Golang

What are some alternatives?

When comparing sarama and Redis you can also consider the following projects:

Confluent Kafka Golang Client - Confluent's Apache Kafka Golang client

redigo - Go client for Redis

kafka-go - Kafka library in Go

riot - Go Open Source, Distributed, Simple and efficient Search Engine; Warning: This is V1 and beta version, because of big memory consume, and the V2 will be rewrite all code.

franz-go - franz-go contains a feature complete, pure Go library for interacting with Kafka from 0.8.0 through 3.6+. Producing, consuming, transacting, administrating, etc.

Hiredis - Minimalistic C client for Redis >= 1.2

librdkafka - The Apache Kafka C/C++ library

mongo-go-driver - The Official Golang driver for MongoDB

gorush - A push notification server written in Go (Golang).

Go-NATS-Streaming-gRPC-PostgreSQL - Go Nats Streaming gRPC PostgerSQL emails microservice

Mercure - 🪽 An open, easy, fast, reliable and battery-efficient solution for real-time communications

mgo - Go Doc Dot Org