Show HN: Streambed – Stream Postgres to Iceberg on S3, Supports Postgres Wire
vira28
88 points
19 comments
May 31, 2026
Related Discussions
Found 5 related stories in 95.8ms across 9,043 title embeddings via pgvector HNSW
- Show HN: IceGate – Observability data lake engine mineev · 14 pts · April 13, 2026 · 55% similar
- Show HN: My Private GitHub on Postgres calebhwin · 36 pts · May 01, 2026 · 55% similar
- Postgres with Builtin File Systems ngaut · 54 pts · March 14, 2026 · 54% similar
- Postgres Traffic Control samlambert · 17 pts · March 23, 2026 · 54% similar
- Snowflake Postgres, Lakebase, HorizonDB: Picking the Lock-In You Want samaysharma · 35 pts · May 12, 2026 · 53% similar
Discussion Highlights (6 comments)
cpard
Replicating the Postgres WAL to S3 and Iceberg reliably is a hard problem but it’s not accurate to say that no ETL is needed here. maybe you can say it’s more of an ELT pattern but anyone who’s interested into using this for realistic analytics they will have to transform the data at some point. If an org is early enough to think that they can use a solution like this and just get in duckdb and start spitting out reports, they will be up for a really bad experience. Please educate people to do the right thing and realize the scope of the work they are facing, it might feel that it hurts your growth in the short term but it will benefit you greatly in the mid-long term as a vendor.
karakanb
Hi, this looks interesting, thanks for sharing. I am the builder of ingestr ( https://github.com/bruin-data/ingestr ), so I am very much in the same space. I really like that you did this in Go, and I'll definitely dig a bit more into the source code to see how you tackled the CDC stuff, given that there is not many reliable CDC libraries in Go, and there are quite a few gotchas when it comes to doing CDC right. We also hand-rolled ours in ingestr, or I must say clanker-rolled, and we got quite a few things wrong in the first place. Curious about the postgres-compatible query option: what's the usecase you have in mind there? My perception is that any org that would use Iceberg also has one or a few query engines in place, is this more for debugging stuff? Quite cool stuff, keep it up!
vira28
Author here. For context, I was the tech lead for the Postgres team at Cloudflare, and this came directly out of a challenge I kept hitting there: BI and dashboard teams needed to run long-running analytical queries, and the answer was always to spin up another bespoke read replica or stand up an ETL dump into an analytical database and query that. So the question I started with was: what's the fewest components I could get away with? That led to the architecture here — Streambed connects to Postgres as a logical replication subscriber (same mechanism as a read replica) and streams WAL changes straight into Apache Iceberg on S3, queryable from psql via an embedded DuckDB. There are a lot of edge cases to handle, and it's very much early days. Welcome any feedback.
oa335
nice work! we have handrolled something similar at work. do you have any perf metrics? throughput, end-to-end latency, etc?
buremba
Looks interesting! It reminds me of pg_lake, which we evaluated for our startup https://lobu.ai but it's missing a lot of pushdown capabilities which made OLAP queries expensive. I also tried DuckLake but that required us to move away from PG-first approach. I was thinking of using Debezium to create Iceberg on S3 for our append-only PG tables and use DuckDB. I will try Streambed out as well!
viveknathani_
interesting approach, was exploring a Postgres to Clickhouse CDC setup while helping a team sometime back, this seems better as it allows separating the compute (query server) and storage (s3) layers, and thereby allowing us to be creative in cost reductions