Hacking Postgres, Ep. 3: Eric Ridge

Oct 20, 2023 18 min read

In this episode, Ry and Eric talk about ZomboDB, the complicated road that led to the development of pgrx, and what it means for the future of extensions within Postgres. You can watch it below or listen to it on Apple/Spotify (or your podcast platform of choice). Special thanks to Eric for joining us today!

Want to know more about something they mentioned? Here’s a starting point:

Did you enjoy the episode? Have ideas for someone else we should invite? Let us know your thoughts on X at @tembo_io or share them with the team in our Slack Community.

Transcript

[00:00:12] - Ry

Hey, Eric. What’s going on, man?

[00:00:14] - Eric

Hi, Ry. How are you?

[00:00:15] - Ry

Long time no talk.

[00:00:16] - Eric

Yeah, it has been a while.

[00:00:18] - Ry

How are things going?

[00:00:19] - Eric

Well, I think.

[00:00:21] - Ry

Well, maybe let’s give our listeners a quick intro on what you’ve done. I mean, Eric Ridge is pretty much a household name in mean, in case there’s someone listening who doesn’t know what you’ve been working on. You want to give us a quick background on your involvement in postgres over the years?

[00:00:36] - Eric

I think a household name is absolutely not true. First of all, I’m Eric. I am the reason that this postgres extension name ZomboDB exists. And over the years of developing that, something that’s now called Pgrx kind of fell out of all that work that lets us develop extensions for postgres using the Rust programming language. And these things have been where my interest has been as it relates to postgres. I guess past seven, eight years now. Things ZomboDB has been out since 2015, so we’re right at eight years.

[00:01:14] - Ry

Do you know how many it’s at? An uncountable number of Rust extensions now, probably you probably at one point knew how many there were, but now you’ve lost track.

[00:01:24] - Eric

Yeah, that’s a good question. It’s hard to know. There’s no real clearinghouse around extensions.

[00:01:30] - Ry

If only there was, that would be a great thing for someone to build.

[00:01:33] - Eric

Yeah, it would. I wish somebody would get on that. Right. Yeah, that’s a good question. There’s some bigger names using Pgrx, and the TimescaleDB is one. Supabase is one. We recently released plrust, and that’s found its way out on RDS. So that’s exciting for us. What we see popping up are small extensions that are written in Pgrx, and we see a lot of people writing I don’t want to call them one off extensions, but one off extensions that are just, like, specific to their business use case and solve some interesting data domain problem that only they would have. But now they have the ability to build that business logic or data manipulation or what have you into their database and into the database itself.

[00:02:27] - Ry

Without having to go find a C programmer that’s willing to do such work. Right?

[00:02:31] - Eric

Yeah. And that was one of the motivators for developing Pgrx, was I guess I had been working on postgres extensions in some form or fashion since postgres 8.0, and I think that was even before the extension packaging and create extension command and all that came into existence not long before. But I think that that was before and yeah, I mean, just over the years, I got tired of working in C. When you’re developing a postgres extension in C, you’re not only putting on your C programmer hat, but you’re trying to put on the hat of a postgres hacker. Right. You need to understand postgres sources just as much as you do the language itself. So Rust was becoming a popular a number of years ago. So I was like, you know what, I’m going to try to do this.

[00:03:22] - Ry

Well, it’s interesting. It’s like how a lot of games, if they have mods, the language for the mods has to be easier than the language for the core game. Right. So a game might be written in something like Unity, but then they give you, like, Lua as a tool or JavaScript or something simple to build. But in Postgres, that wasn’t true. Now, is Rust as simple as Lua or JavaScript? Maybe not, but it’s still like very beloved people who try to learn it. In my experience so far, it’s 100% like anyone who tries to learn Rust learns it and loves it. I haven’t found someone yet and I have a small sample size, but, yeah, seems like it’s a pretty good hit rate in terms of the perfect mix of control and speed with the ease of onboarding.

[00:04:10] - Eric

If you’re not a C programmer, then writing the postgres extension in C is going to be difficult again, because C and then also because you’re really programming Postgres’s version of C, which is great, but it’s not JavaScript, it’s not Ruby, it’s not Java. If you’re not a Rust programmer, first you’ve got to learn Rust, and Rust is different enough from all the other languages to make that a point. But what we’re trying to do with Pgrx, and it’s going to be a multi year effort to do this, it may never get done, but we’re trying to present the postgres internals in the most idiomatic way possible to Rust. Right. So that if you are a Rust programmer or you are beginning to learn Rust, it’ll be pretty obvious what you need to do in order to make your postgres extension useful.

[00:05:10] - Ry

So you said you were working on extensions as early as Postgres Eight. Were you a Postgres user or our developer even earlier than that, or was that sort of when you got involved?

[00:05:21] - Eric

Yeah, Postgres user, I think we started using Postgres at work in the year 2000 and that might have been I mean, is that 7.1, 7.2? It’s quite a long time ago and we’ve been using it every day since. And, yeah, somewhere along the way we needed to do some work inside the database. So here we are today.

[00:05:46] - Ry

Yeah. For me, when I think about when did I start using Postgres, it’s like thinking about when did I first start using a laptop, it’s like I don’t remember exactly when, but definitely transitioned to having a laptop at some point. But, yeah, it didn’t seem monumental to start using Postgres back then, but obviously it’s come a long way and it’s a pretty exciting ecosystem right now. So, yeah. What do you think the most powerful thing about extensions are? Do you have any thoughts on what are the most powerful things you can do with extensions, out of curiosity?

[00:06:19] - Eric

It’s an interesting question.

[00:06:21] - Ry

What’s the coolest part of, I guess what API? Or maybe another good question is what hasn’t been exposed yet that should be or needs to be in Pgrx? That would be powerful.

[00:06:32] - Eric

Yeah, I’ll start there and then work backwards. There’s a lot of internal APIs within Postgres, and there’s a number of interesting ones. There’s the index access method API, which is really easy to implement. We haven’t added safe wrappers around that to Pgrx, but it’s real easy to implement. It’s really just a handful of functions. There’s the Foreign Data Wrapper API, which Supabase released a project that they call Wrappers that’ll let you create foreign data wrappers using Rust backed up by Pgrx. So kind of the next big API around that genre of internals. There would be the Table Access Method APIs, and we haven’t exposed these at all yet. They’re actually difficult to get at even through our bindings just because of the way they’re set up in the postgres sources. So when we get around to doing that, and I hope that we will, there’s going to be some development effort on our part to safely expose these or safely expose the Table Access Method APIs. But that’s the API that would let you write your own heap storage engineer system in Rust.

[00:07:49] - Ry

Tell me about I mean, probably not everybody knows what ZomboDB is. Maybe quickly describe what it does and what it doesn’t do and what’s coming next with it.

[00:07:59] - Eric

Yeah, it’s the worst named software product.

[00:08:03] - Ry

First off, why’d you call it Zombo, everyone wants to know.

[00:08:06] - Eric

I think, Ry, you’re old enough to remember Zombo.com. If you don’t remember it, then that just means you weren’t playing on the internet. You’re probably doing real work. It still exists so listeners can go and check it out, but the name just came from that. So ZomboDB is a postgres extension, and it’s been through numerous iterations over the past eight years, but it has always been postgres extension that lets you create an index on a table that’s backed by Elasticsearch. Typically the usage pattern is you create the index indexing all of the columns in the table and you point it to an Elasticsearch endpoint over Http or Https, and the ZomboDB keeps that index up to date. It keeps the index MVCC correct. All of your search results are you only see results that would otherwise be visible within the executing transaction has its own query language for doing full text queries, so users don’t have to learn the Elasticsearch query DSL, which is pretty intense.

[00:09:14] - Ry

Can you use the Elasticsearch DSL with it, though?

[00:09:17] - Eric

You can, and there’s a number of ways to do that. The query language itself allows you to just insert as part of an expression. You can insert a JSON block to represent a query DSL node. There’s a full set of SQL builder functions, so you can build query DSL through SQL statements. You can mix and match these things together. It’s pretty sophisticated on that front, and it also exposes nearly all of Elasticsearch’s aggregate endpoints to enable you to do really interesting aggregations with your full text. And since all the fields of a table are also stored in the Elasticsearch index, you can do some really interesting things that involve full text queries and aggregating on various metadata fields and do all this with a large distributed elastic search cluster behind the scenes and do it in near real time. It’s really slick. The downside to ZomboDB is that you now have an Elastic search cluster running alongside your postgres cluster. And ES is a living breathing system. It requires significant attention and maintenance in production. It gives you a lot of capabilities to scale out horizontally very easily, but it is its own living breathing system there.

[00:10:42] - Ry

Yeah, it’d be great if you can build a version of this without requiring elastic.

[00:10:46] - Eric

Yeah, I know a guy that’s working on that. I know a company that’s working.

[00:10:50] - Ry

Yeah, someday that’d be possible.

[00:10:53] - Eric

Yeah, well, you had asked where the name came from and I said all that to say that the name came from. Once we kind of got ZomboDB working, we were like, whoa, it’s really amazing what you can do with this and how easy it is to use. And one of the mantras from Zombo.com is the only limit is yourself. And ZomboDB really kind of makes it feel that way because it makes querying your data, especially real dense text data, just super simple.

[00:11:26] - Ry

And so you use Zombo pretty aggressively within TCDI, which is where you work, right?

[00:11:33] - Eric

Yeah, TCDI is my employer. Yeah. We’ve had Zombo in production since 2013 and we didn’t open source until 2015. Yeah, I don’t want to give away numbers, but we have more ZomboDB installations and Elasticsearch instances than we probably want.

[00:11:53] - Ry

Is it sort of a competitive advantage for the business? The power that I know, you guys, it’s like legal documents. I might get it wrong, but like searching legal documents to some degree, right? Is it a competitive advantage for the business? The fact that Zombo is inside, would you say?

[00:12:08] - Eric

Yeah, absolutely. Our industry is e-discovery litigation support and among many other areas within that domain, searching large volumes of text is a key thing. And we’re the only player in our industry that has text search capabilities to the degree that we do. And I’m not going to go name or other competitors or anything, but their abilities to do complicated text search that involves fuzzy queries plus regular expressions, plus boolean expressions, plus long tail proximity queries hit highlighting it’s our abilities to do that just far exceed our competitors because of ZomboDB, because of postgres, and because of Elasticsearch.

[00:12:55] - Ry

Do you use the extension in both transactional use cases as well as analytical? Or is it mostly just powering the search bar inside the product or is there some back end? I guess I call it like analytical type use cases for it as well.

[00:13:12] - Eric

Yeah. So with postgres. Right. Everything is transactional.

[00:13:15] - Ry

Yeah.

[00:13:16] - Eric

We expose search in a very complex manner. I guess, to our users. Users, it’s much more than just a search box. They can search by particular fields and design proximity queries, and they can do term lookups. They can create real time dashboards and whatnot through our software. That’s all backed by ZomboDB. One interesting use case is in the world of litigation. The plaintiffs will provide the defendants with a list of keywords that need to be searched in order to find documents that are responsive to particular to these topics. And these keywords are sometimes just literally a keyword one word. Sometimes they’re phrases, sometimes they’re wild card terms. Sometimes they’re phrases with embedded wildcards. Sometimes they’re patterns that need to be recognized. And so, like an analytics side of what we use ZomboDB for is taking these ginormous lists of things and kicking it off and getting back a list of the 6 million documents out of the 200 million that might match this set of keywords that the plaintiffs have requested production for.

[00:14:25] - Ry

Yeah, that’s intense. Could see the power of that. What are your other favorite extensions? Probably all the other ones you’ve made, but give me your top five postgres extensions. zombos, one. What are a couple of others that you like?

[00:14:39] - Eric

I don’t use PostGIS or PostGIS, but I am super impressed with it. I think of it as kind of like the gold standard of what a postgres extension ought to look like. ZomboDB does integrate with it, but the data world that I live in doesn’t involve the need to do geographical type queries. But I’ve always been really impressed with it. I think the postgres foreign data wrapper as an extension is really great, and that comes from the core community, but pretty impressed with that. Citus has always been interesting to me. I guess they’ve long since been bought out by Microsoft and are still going strong. I think that Citus really shows off the power of what a postgres extension can do, and it also shows off the power of having committers on the hackers and hackers to be able to help move the extension system in postgres forward so that you can then implement something like Citus on top of it.

[00:15:36] - Ry

When they were building that, did they have to add things to extensions in order to build that? I don’t know the whole history of Citus, but was that kind of like.

[00:15:46] - Eric

Yeah, they’ve had a number of changes in postgres, I think, especially in the planner and executor to be able to support the ability to extend it better. And I think some of that came from the original Citus company people. That’s great, right?

[00:16:03] - Ry

Yeah, that’s awesome.

[00:16:05] - Eric

What I like to see are people using Pgrx to just solve a problem that they have with their application. I see things like somebody just needed to talk to an S3 bucket, and so they put together a little Pgrx extension to do that. Little things like that are what get me excited about Postgres extensions.

[00:16:26] - Ry

Yeah, it’s pretty timely. I have a co-op that started literally today. Shout out to Jay and I told him to build a clerk FDW using the Supabase Wrappers SDK. And he’s like, what the hell do you say to me? Just try read the docs, we’ll see where it goes. But I’ll report back how that goes. But yeah, Clerk, we’re using Clerk for Auth for our company, and I just need a simple read access to three collections. So I figure he should be able to get it done by the end of the day, but I might be pushing too hard.

[00:17:00] - Eric

Well, it’s possible. And that’s a great example of where having a simple framework for making an extension is really powerful. Right. I mean, once you figure out the documentation and how to tie the two things together, it probably is just an afternoon’s worth of work. And now you’ve got something that solves a problem and you can move on.

[00:17:21] - Ry

Yeah, I figure his second one maybe will take an afternoon, first one might take a few days, but we’ll see.

[00:17:26] - Eric

Well, sure, yeah.

[00:17:28] - Ry

Well, that’s great. Yeah, we’re super excited, obviously, by all the possibilities that Pgrx brings to Postgres, and the great work you guys have done historically to get us to this point is much appreciated.

[00:17:42] - Eric

Well, thanks. That’s one of the reasons why we, TCDI donated Pgrx to the PG Central Foundation is to provide it a long term home for the Postgres community. TCDI is a litigation support company. We’re not a database company, so to speak. So we wanted to get this stuff in the hands of a foundation that can help shepherd it forward and make sure that it can survive.

[00:18:09] - Ry

I imagine you have some open issues there that you could use help with. They’re probably pretty hard to do, right? Like building a framework is a lot harder to building a thing with a framework. But are you looking for additional help from people to build out Pgrx?

[00:18:23] - Eric

Yeah, for sure. I can’t even tell you off the top of my head how many contributions we’ve had over the past four years that Pgrx has been alive. And it seems like every couple of weeks somebody new comes by with a new contribution. But yeah, one of the things that we’re focused on right now is I guess it’s two things kind of concurrently. One is we’re improving Pgrx, is testing fundamentals, and it’s both tying in more interesting things in CI like Valgrind, to different approaches to unit testing, which includes we’re doing a big push on property testing right now within Pgrx. I think there’s going to be some pull request landing in the next week or so with that. And we’re also focused on improving some of the memory safety and soundness impedance mismatches between Postgres internals and Rust’s compiler. So it’s a big concerted effort to take a look at these issues.

[00:19:25] - Ry

Well, it seems like contributing to Pgrx could be like a gateway drug towards getting closer to helping with postgres itself. Right. Because you need to understand the internals to do anything in know, at least unless you’re working on tests or yeah, I mean in general, adding new features to Pgrx means understanding postgres well enough to create that interface, which is big challenge.

[00:19:48] - Eric

It does. And we myself and the others that on the decor development team there, we spend probably as much time in the postgres sources as we do actually writing code for it in.

[00:20:03] - Ry

You guys. If you come up with a big new release of Pgrx or any other extensions that you can think of, I’d love to have you back. Eric, it was great catching up with you.

[00:20:12] - Eric

Yeah, sure. Likewise. Thank you so much for having me.