aperture VS bleve

Compare aperture vs bleve and see what are their differences.

bleve

A modern text/numeric/geo-spatial/vector indexing library for go (by blevesearch)
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
aperture bleve
28 13
590 9,666
1.7% 0.6%
9.8 8.0
3 days ago 7 days ago
Go Go
Apache License 2.0 Apache License 2.0
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.

aperture

Posts with mentions or reviews of aperture. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-01-18.
  • Defcon: Meta's system for preventing overload with graceful feature degradation
    1 project | news.ycombinator.com | 29 Feb 2024
    Anyone interested in load shedding and graceful degradation with request prioritization should check out the Aperture OSS project.

    https://github.com/fluxninja/aperture

  • Queues Don't Fix Overload
    3 projects | news.ycombinator.com | 18 Jan 2024
    I agree that queues can problem especially when misconfigured. But some amount of queuing is necessary, to absorb short spikes in demand vs capacity. Also, queues can be helpful to re-order requests based on criticality which won't be possible with zero queue size - in which case we have to immediately drop a request or admit it without considering it's priority.

    I think it is beneficial to re-think how we tune queues. Instead of setting a queue size, we should be tuning the max permissible latency in the queue which is what a request timeout actually is. That way, you stay within the acceptable response time SLA while keeping only the serve-able requests in the queue.

    Aperture, an open-source load management platform took this approach. Each request specifies a timeout for which it is willing to stay in the queue. And weighted fair queuing scheduler then allocates the capacity (a request quota or max number of in-flight request) across requests based on the priority and tokens (request heaviness) of each request.

    Read more about the WFQ scheduler in Aperture: https://docs.fluxninja.com/concepts/scheduler

    Link to Aperture's GitHub: https://github.com/fluxninja/aperture

    Would love to hear your thoughts on our approach!

  • Kelsey Hightower's Twitter Spaces on Rate Limits & Flow Control
    1 project | /r/devops | 18 Aug 2023
    For those keen to dive deeper, I highly recommend exploring both the Twitter Space and Aperture: [Twitter Spaces]: https://twitter.com/kelseyhightower/status/1689355284802629633?s=20 [GitHub repo]: https://github.com/fluxninja/aperture
  • Graceful Behavior at Capacity
    1 project | news.ycombinator.com | 7 Aug 2023
    Very interesting blog post! Our team has been working intensively in this area for the last couple of years - flow control, load shedding, controllability (PID control), and so on.

    We have open-sourced our work at - https://github.com/fluxninja/aperture

    We would love feedback from folks reading this blog post!

    Disclaimer: I am one of the co-authors of the Aperture project. There are several interesting ideas we have built into this project and I will be happy to dive into the technical details as well.

  • Why Adaptive Rate Limiting Is a Game-Changer
    1 project | news.ycombinator.com | 22 Jul 2023
    It's a blog on an open-source project that precisely tells you how to implement adaptive rate limiting.

    Just click around a bit:

    - https://github.com/fluxninja/aperture

    - https://docs.fluxninja.com/use-cases/adaptive-service-protec...

    Note: I am one of the authors' of this project.

  • Show HN: Review GitHub PRs with AI/LLMs
    2 projects | news.ycombinator.com | 14 Jul 2023
    At the time of writing, the first sample image on that page is this:

    https://coderabbit.ai/assets/section-1-f9a48066.png

    which recommends adding a "maxIterations" counter to the "for len(executedComponents) ..." loop here:

    https://github.com/fluxninja/aperture/blob/26e00ea818c7c28da...

    HOWEVER

    - the review has failed to notice the logic using "numExecutedBefore" (around line 377) that already prevents the specific bug it is suggesting a fix for

    - the suggested change decrements "maxIterations" inside the "for ... range circuit.components {" loop which means it isn't counting iterations, it's counting components

    This kind of suggestion is particularly nasty because it's unlikely that the test suite populates enough components to hit "maxIterations" - so an inattentive reader could accept it, get a green build, and then deploy a production bug!

  • June 25th, 2023 Deno Deploy Postmortem
    2 projects | news.ycombinator.com | 1 Jul 2023
    The need an adaptive protection system like Aperture[0] to mitigate overloads.

    [0]: https://github.com/fluxninja/aperture

  • Jsonnet – The Data Templating Language
    20 projects | news.ycombinator.com | 27 Mar 2023
    It’s customized to our policy spec. But you can learn from this and adapt it to your spec.

    https://github.com/fluxninja/aperture/blob/main/scripts/json...

  • Show HN: Aperture – Unified Reliability Management for Microservices
    1 project | news.ycombinator.com | 16 Mar 2023
  • Failure Mitigation for Microservices: An Intro to Aperture
    1 project | /r/microservices | 14 Mar 2023

bleve

Posts with mentions or reviews of bleve. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2023-06-04.
  • Hermes v1.7
    3 projects | /r/golang | 4 Jun 2023
    I don't have the answer to that, but the project has been alive for many years. Seems maybe you should find the answer since you are developing a competing solution? Also it might be a good reference project for solving similar problems to yours. They do have bench tests you could play with https://github.com/blevesearch/bleve/blob/master/query_bench_test.go
  • Seeking a free full text search solution for large data with progress display
    5 projects | /r/golang | 26 May 2023
    I know of https://github.com/blevesearch/bleve and I think there was another project for full text search that I can't find now.
  • Any Full Text Search library for json data?
    13 projects | /r/golang | 1 Jan 2023
  • An alternative to Elasticsearch that runs on a few MBs of RAM
    65 projects | news.ycombinator.com | 24 Oct 2022
    I would be interested in such a testbed. I would also like to know how Bleve Search (https://github.com/blevesearch/bleve) turns out.

    I have for many years now a small search engine project in my free-time pipeline, but I'm before crawling even and I intend to sit for searching part after some of that.

  • What is the coolest Go open source projects you have seen?
    84 projects | /r/golang | 15 Sep 2022
  • BetterCache 2.0 (has full text search/remove, etc.)
    5 projects | /r/golang | 2 Sep 2022
    Haha. Seriously I can’t tell the difference between these libraries https://github.com/blevesearch/bleve
  • I want to dive into how to make search engines
    16 projects | news.ycombinator.com | 25 Aug 2022
    I've never worked on a project that encompasses as many computer science algorithms as a search engine. There are a lot of topics you can lookup in "Information Storage and Retrieval":

    - Tries (patricia, radix, etc...)

    - Trees (b-trees, b+trees, merkle trees, log-structured merge-tree, etc..)

    - Consensus (raft, paxos, etc..)

    - Block storage (disk block size optimizations, mmap files, delta storage, etc..)

    - Probabilistic filters (hyperloloog, bloom filters, etc...)

    - Binary Search (sstables, sorted inverted indexes, roaring bitmaps)

    - Ranking (pagerank, tf/idf, bm25, etc...)

    - NLP (stemming, POS tagging, subject identification, sentiment analysis etc...)

    - HTML (document parsing/lexing)

    - Images (exif extraction, removal, resizing / proxying, etc...)

    - Queues (SQS, NATS, Apollo, etc...)

    - Clustering (k-means, density, hierarchical, gaussian distributions, etc...)

    - Rate limiting (leaky bucket, windowed, etc...)

    - Compression

    - Applied linear algebra

    - Text processing (unicode-normalization, slugify, sanitation, lossless and lossy hashing like metaphone and document fingerprinting)

    - etc...

    I'm sure there is plenty more I've missed. There are lots of generic structures involved like hashes, linked-lists, skip-lists, heaps and priority queues and this is just to get 2000's level basic tech.

    - https://github.com/quickwit-oss/tantivy

    - https://github.com/valeriansaliou/sonic

    - https://github.com/mosuka/phalanx

    - https://github.com/meilisearch/MeiliSearch

    - https://github.com/blevesearch/bleve

    - https://github.com/thomasjungblut/go-sstables

    A lot of people new to this space mistakenly think you can just throw elastic search or postgres fulltext search in front of terabytes of records and have something decent. The problem is that search with good rankings often requires custom storage so calculations can be sharded among multiple nodes and you can do layered ranking without passing huge blobs of results between systems.

  • Why Writing Your Own Search Engine Is Hard (2004)
    5 projects | news.ycombinator.com | 23 Jul 2022
    For those curious, I'm on my 3rd search engine as I keep discovering new methods of compactly and efficiently processing and querying results.

    There isn't a one-size-fits all approach, but I've never worked on a project that encompasses as many computer science algorithms as a search engine.

    - Tries (patricia, radix, etc...)

    - Trees (b-trees, b+trees, merkle trees, log-structured merge-tree, etc..)

    - Consensus (raft, paxos, etc..)

    - Block storage (disk block size optimizations, mmap files, delta storage, etc..)

    - Probabilistic filters (hyperloloog, bloom filters, etc...)

    - Binary Search (sstables, sorted inverted indexes)

    - Ranking (pagerank, tf/idf, bm25, etc...)

    - NLP (stemming, POS tagging, subject identification, etc...)

    - HTML (document parsing/lexing)

    - Images (exif extraction, removal, resizing / proxying, etc...)

    - Queues (SQS, NATS, Apollo, etc...)

    - Clustering (k-means, density, hierarchical, gaussian distributions, etc...)

    - Rate limiting (leaky bucket, windowed, etc...)

    - text processing (unicode-normalization, slugify, sanitation, lossless and lossy hashing like metaphone and document fingerprinting)

    - etc...

    I'm sure there is plenty more I've missed. There are lots of generic structures involved like hashes, linked-lists, skip-lists, heaps and priority queues and this is just to get 2000's level basic tech.

    - https://github.com/quickwit-oss/tantivy

    - https://github.com/valeriansaliou/sonic

    - https://github.com/mosuka/phalanx

    - https://github.com/meilisearch/MeiliSearch

    - https://github.com/blevesearch/bleve

    A lot of people new to this space mistakenly think you can just throw elastic search or postgres fulltext search in front of terabytes of records and have something decent. That might work for something small like a curated collection of a few hundred sites.

  • Mattermost – open-source platform for secure collaboration
    6 projects | news.ycombinator.com | 24 Jun 2022
    Search in SQL databases is a tough beast to get it right. And given that we support MySQL and Postgres both, it gets even harder to support quirks of both of them.

    In enterprise editions, the only addition is Elasticsearch. But in our open-source version, we do have support for https://github.com/blevesearch/bleve. Although, it's in beta, we have a lot of customers using it.

    I am wondering if you have tried using it and didn't like it?

  • A Database for 2022
    13 projects | news.ycombinator.com | 1 Apr 2022

What are some alternatives?

When comparing aperture and bleve you can also consider the following projects:

rules_jsonnet - Jsonnet rules for Bazel

Elasticsearch - Free and Open, Distributed, RESTful Search Engine

slo-exporter - Slo-exporter computes standardized SLI and SLO metrics based on events coming from various data sources.

elastic - Deprecated: Use the official Elasticsearch client for Go at https://github.com/elastic/go-elasticsearch

awesome-sre-tools - A curated list of Site Reliability and Production Engineering Tools

goriak - goriak - Go language driver for Riak KV

now-boltwall - Vercel lambda deployment for a Nodejs Lightning-powered Paywall

elasticsql - convert sql to elasticsearch DSL in golang(go)

ai-pr-reviewer - AI-based Pull Request Summarizer and Reviewer with Chat Capabilities.

goes

etleneum - the centralized smart contract platform

elastigo - A Go (golang) based Elasticsearch client library.