Brought to you by Michael and Brian - take a Talk Python course or get Brian's pytest book


Transcript #120: AWS, MongoDB, and the Economic Realities of Open Source and more

Return to episode page view on github
Recorded on Thursday, Feb 28, 2019.

00:00 Hello and welcome to Python Bytes, where we deliver Python news and headlines directly to your earbuds.

00:05 This is episode 120, recorded February 28th, 2019.

00:11 I'm Michael Kennedy.

00:11 And I'm Brian Okken.

00:12 And this episode is sponsored by DigitalOcean.

00:14 Check them out at pythonbytes.fm/digitalocean.

00:17 Lots of good stuff at that URL, but more about that later.

00:20 Brian, welcome back to the show, man.

00:22 Oh, thanks. Nice episode last week.

00:24 Thanks. Yeah, we went to Seattle and we all had fun and sadly, you were knocked out, but understandably.

00:28 - Man, I sent it to everybody I knew, my daughter and a whole bunch of people and said, "At least listen to the first bit of it because this is why I enjoy working with Michael. It was so nice of you to do a shout out to me." That was nice.

00:41 - Thanks. Yeah, that's really great. Yeah, you're welcome. That's the least I could do.

00:44 Wish you were there, but that's okay. Speaking of people who were almost there, at least was at the conference who I got to spend a lot of time with, but wasn't actually at that live recording, Nina Zinkarenko. How about that? That's our first, the source of our first item, right? She is.

00:57 Yes, how could I resist she put together this wonderful resource for people?

01:02 So what I'm talking about is the ultimate guide to memorable tech talks and it is She said it was going to be a blog post and it turned into what she calls a book But it's a seven articles on medium and it's a seven part series that she covers things like choosing a topic writing a talk proposal tools that she uses planning, writing it, writing your talk out, practicing it and delivering the talk. And it's a phenomenal resource. I'm not done with it, actually. I've read up through the tools section and I'm looking forward to the rest of it. But one of the things, I mean, it speaks right to me, because I got into podcasting partly to get better about this public speaking thing, and it's difficult. And especially for, I think, tool nerds and introverts and stuff like that, jumping into the tools and in the little details you can lose sight of stuff. So one of the things she noticed, she quote from the article is, "I noticed I'd procrastinate on making the slides look good instead of focusing my time on making quality content." It's easy to get sucked into that. Yeah. Yeah, totally. When I should have been like, I've given two talks and many, many talks informally at work and stuff, but two conferences and the, I spent so much time just tweaking the the different slides instead of practicing it and making sure I understand it well enough to even throw the slides away and just do the talk.

02:26 And so I think focusing on planning and leaving all that, the time enough to get all that.

02:31 This is actually the series that I wish I had when I started getting into trying to do talks because either you have out there, there's either stuff that doesn't have enough information, it's just a quick gloss over, or it focuses on one aspect.

02:46 Or on the other end, you've got courses and books.

02:49 This is just a series of blog posts that you can staple together with one staple.

02:54 It's good.

02:55 - Not the big, heavy, super-duper binder staple, but like a regular one, right?

02:59 Like the red one from Office Space.

03:01 - Yeah, yeah, just one of those.

03:03 - This is a great series, and nice work, Nina.

03:06 Good pick, Brian.

03:07 I think it'll help a lot of people.

03:08 I like that it's writing, she covers writing the talk proposal, because it's great to get get into public speaking, but you have to get accepted to get into public speaking a lot of times.

03:17 Although, although, at the bigger conferences, say PyCon, you can always do an open space, and that's kind of like a dip your toe in the water, 'cause you don't have to lead the whole conversation, but you kind of are sort of leading it in spirit.

03:29 - Yeah, and then you can go through all of these steps for just to get ready, and you only have to be up there for, I don't know how long the lightning talks are, but they're not long.

03:37 - Yeah, for sure.

03:38 Yeah, lightning talks are five minutes, open spaces I think are 25, but you don't do the talking the whole time.

03:44 We're definitely going to, you know, as you spoke about the live recording, we're definitely going to do more live recordings at the main PyCon, at some open spaces, if nothing else.

03:50 - Yeah, definitely.

03:51 I wanted to interview a bunch of people for stuff, so.

03:54 - Bringing the mics.

03:54 Okay, super.

03:55 So the next one is something I've been digging into lately.

03:58 Have you done anything with Kubernetes?

04:00 - No.

04:01 - Let me take a step back.

04:02 Have you done anything with Docker?

04:03 - No.

04:03 - So these two things are sort of stacked on top of each other, and they often get complicated.

04:07 So Docker is a little bit of a complicated thing if you haven't done a lot of like deployment and DevOps type stuff because it's all about configuring Linux isolated machines, if you will. And then, in order to actually use them properly, really, with scale out and failover and clusters and connections between them and all that, like a Docker container for your web app, one for the database, you really need some kind of orchestration, which is Kubernetes.

04:32 So there's a ton to learn about all this stuff. Luckily, Michael Herman from testdriven.io, .io, formerly of RealPython.

04:40 I did a really nice write up here.

04:42 He has a course on testdriven.io.

04:44 And this is like an extracted, long example tutorial to get started with Flask on Kubernetes.

04:52 Wow.

04:53 That actually sounds neat.

04:54 Yeah, it's actually pretty approachable.

04:56 I mean, I said it's a complicated topic.

04:58 He really lays out the core ideas.

04:59 And if you ask Pocket, it says reading time is 16 minutes.

05:03 So it's pretty hefty, but it's not book size.

05:05 It's not super, super long.

05:07 Of course, the little steps that it says take more than just one line or whatever.

05:11 You've got to let it configure a cluster or something.

05:14 So there's little wait periods.

05:15 But really nice.

05:16 It talks about how to basically get a Vue.js front end Flask back end app that talks to a database, Postgres in particular, up and running on a Kubernetes cluster.

05:25 So kind of microservice style, which is pretty cool.

05:28 And I'll just run off some of the goals so you guys kind of know what you'll get out of it.

05:31 So explain what a container and container orchestration is, Pros and cons of using Kubernetes over, say, things like Docker Swarm, all the primitive concepts of Kubernetes, Node, Pod, Service, Deployment, et cetera.

05:46 Spinning up a Python app, which is nice.

05:49 Locally with Docker Compose, there's a nice little utility called Minikube, which lets you basically, in just a couple of command lines, create a Kubernetes cluster pre-configured on your machine, which is a super pain.

06:00 So that's really nice that you can just install that thing and have it go and stuff like that.

06:05 It's really quite nice.

06:06 - Oh, I'm definitely gonna check this out.

06:07 Plus, in 16 minutes, I can now put like 75 new keywords on my resume.

06:13 - Oh yeah, this is dense in buzzword bingo hits.

06:16 - Yeah.

06:17 (laughing)

06:18 - Nice.

06:19 You and I both picked something that's a little bit on the controversial side of the world in open source and the community.

06:26 You go first.

06:27 - Okay.

06:28 This is just I think it's still playing out but in the end of January Maybe they announced it earlier, but on the Travis CI blog they announced that Travis CI is to join Idara Idara, I don't know another company basically they got bought by a company and Frankly, I don't really care who owns what but then in February They I started seeing the hashtag Travis alarms on Twitter and they looks like, I mean, from the outside looking in, it looks like they're laying off a bunch of engineers.

07:01 I don't really know what's going on because they're not really talking about it.

07:04 There hasn't been anything else on the Travis CI blog to say what's going on.

07:09 So I've used Travis for running tests on Python projects.

07:13 So I wanted to, I thought, you know, I've wanted to do this anyway, so now's a good time to start looking at if I've got source code on GitHub, I want to use the, and I want to use testing somewhere, and it isn't Travis, where would I do it?

07:26 And so, right now I'm trying to use GitLab and Azure Pipelines with the help of some other people to try to get those running on a couple of projects.

07:36 But there's a lot more. I mean, GitHub lists 17 different options for continuous integration that you can hook up.

07:43 Yeah, that's a big deal, right? Like, Travis has been kind of the go-to.

07:46 Plug it into your open source public GitHub repo and just let it turn away and do all the checks on PRs and things like that, right?

07:54 They claim that our experience is not going to be different.

07:58 However, with less engineers, it's--

08:01 I don't know.

08:02 It seems like it might stagnate and stuff.

08:04 Yeah, something that you also talked about here is Azure Pipelines, Azure Build Pipelines.

08:09 And that definitely seems like it's getting a lot of traction.

08:12 I've heard of some major open source projects moving over to that, either partially or entirely.

08:18 I'm dropping a few links in here.

08:19 One of the links is a couple of things from Anthony Shaw.

08:22 of course, it wouldn't be a show without Anthony.

08:25 One of them is an article that he writes about Azure pipelines with Python, by example.

08:31 And also he's got a pytest plugin to help with testing on Azure.

08:38 And then one of the people that's been helping me out is, I'm gonna get his name wrong, but Anthony Sautile, Sautile, sorry, Anthony.

08:46 But he's got a whole bunch of different Azure templates on his GitHub repo that look neat.

08:51 - Yeah, cool.

08:53 And as far as I understand it, Azure pipelines are free for public repos and things like that.

08:58 So it's interesting.

08:59 - All the things I'm gonna try are things that have reasonable free levels for open source projects.

09:06 - That's kind of an interesting trend that's been going on.

09:08 There's a lot of things that are free for public open source repos, but paid for private stuff.

09:14 And that seems like a pretty good balance to me.

09:16 - Having the GitHub go to allow private repos is interesting.

09:21 And I'm not sure what drove the Travis change, but yeah, anyway.

09:25 >> Yeah, I'm pretty sure GitHub was pressured by Bitbucket, but I don't know anything about the roots of the Travis one.

09:31 I do have more good news around DigitalOcean for you and all the listeners.

09:36 So they've traditionally had these high compute instances called droplets, they're virtual machines.

09:42 And they've had memory heavy ones, but the memory heavy ones didn't have dedicated CPUs.

09:48 like you did it shared with the VM host, right?

09:52 So it couldn't be guaranteed of like consistent workloads on that thing.

09:57 So now they're announcing a general purpose droplet that is a blend of dedicated CPUs and a wide range of memory configurations.

10:05 So basically you can get quite a bit of RAM.

10:08 I think the lowest one is eight gigs and it goes up to either 64 or 128 gigs of RAM and a whole bunch of dedicated CPUs.

10:16 So it's pretty cool and they talk about, You know, some good examples of using it would be like web applications hosting like an e-commerce site where latency matters, or a medium-sized relational Postgres or NoSQL like MongoDB database 'cause you want your database to be fast, right?

10:32 Like that's the heart of your app, even if you scale the web front end, and other sorts of analytics and so on.

10:37 So you can check that out.

10:38 It's under limited availability, but you can go and like click a button and say I wanna try this.

10:43 So check them out at pythonbytes.fm/digitalocean.

10:46 it really supports the show and keeps us going each week.

10:49 - Yes, very cool.

10:50 - Yeah, thanks.

10:51 So speaking of infrastructure, it's cool to be able to set up your code and your websites and all of your infrastructure to run on Linux.

11:00 And you might even do that on Docker and you might even put those Docker containers on Kubernetes, but a lot of us are not using Linux as our dev machine, right?

11:09 A lot of us are using Macs, at least the ones you'll see walking around the conferences.

11:12 So this next item is called a Python server setup for macOS.

11:17 That's a cool little Apple emoji.

11:18 - Nice.

11:19 - Yeah, so if you wanna run your Nginx and your MicroWizky or your Gunicorn or your production software stack, but you wanna run it locally on macOS, here's a little guide on how to do that.

11:30 So it basically takes you through setting up Nginx, having Nginx serve your static assets.

11:34 They're using Gunicorn and Flask, but you could pretty easily swap that out for MicroWizky and whatever, whatever else you wanna use.

11:42 and then having Nginx be the front end proxy for a scaled out GNU-Core and back end.

11:48 So it's pretty cool.

11:49 Now, I went through this recently, and not all the commands seem to be working, at least on my system.

11:55 I don't know why, what they're going through.

11:56 Maybe I missed a step.

11:58 But even if the commands don't all exactly work, I think it still is a pretty good guide, and it's on GitHub, so if you find mistakes, open an issue.

12:06 It's not super popular, but I think a lot of people will find it helpful if they're trying to develop and something closer to their actual configuration.

12:15 Okay. Is this more for a development environment sort of thing?

12:19 Yeah, exactly. Because normally what you do is you get something like Waitress or you get some other built-in, like, wimpy, non-production, full Python-based web server, and then all the requests go through your flask or pyramid or whatever.

12:35 But in production, it doesn't work that way.

12:36 You have Nginx doing SSL and doing static assets, and then it only passes the Python requests over.

12:41 There's just like, there's quite a bit of difference.

12:43 So if you want to have sort of a QA local thing on your Mac, here you go.

12:48 - Oh, that's nice. Okay. - Yeah. Pretty cool.

12:50 - Let's check this out. - Uh-huh. What do you got for the next one?

12:52 When I started using command line interface stuff, I used Click.

12:56 So I did a quick search for different ways to build a command line interface, meaning, like, if I-- not an interactive thing, although I know that those are a thing, but just if I want to-- if I've got a script that I'm writing and I want to take values in, it's parsing the arguments passed into the script or whatever.

13:16 Click is great, I love it, but it's something extra. It's not built into Python yet, it's an extra dependency.

13:22 That's fine for a lot of times, but sometimes you just want a couple different parameters that somebody can pass in.

13:28 And so the built-in argparse is part of the standard library, and that would be good to use.

13:34 Yeah, it's cool. And it's better than just going to, you know, sys.argv and going after an array of whatever, right?

13:39 You get a little more help than that.

13:40 Right. I actually didn't realize that argpars was so easy.

13:43 So there's, Jeff Hale put together an article called "Learn Enough Python to be Useful - ArgPars".

13:49 That's a kind of long title, but it's a tutorial on argpars.

13:52 And it's that I couldn't find a good intro guide for argpars when I needed one.

13:58 So I wrote this article.

13:59 And I got to say, it's a very nice quick introduction.

14:02 So if you want to throw some arguments on an application, try this.

14:07 It definitely seems like a good idea.

14:08 There's certainly times where I'm like, you know, I just don't feel like going to all the formality.

14:13 I just need to know, basically, did they pass some simple thing here?

14:16 Yes or no.

14:17 Right.

14:17 And this is cool, especially for my little proof of concept ideas.

14:22 Yeah.

14:22 Yeah.

14:22 So it comes built in, which is really nice.

14:25 Nothing to install.

14:26 So you don't want to necessarily take on click and make people go through virtual environments and pip and all that, if literally this is the only, that would be the only thing, right?

14:35 So here's another good chance to not do that.

14:37 - Oh yeah, that's a great idea, is if you don't already have any other dependencies, then yeah, using this.

14:42 - Exactly, 'cause that'll definitely increase the challenge of using your code.

14:46 All right, so you got to go first with Travis CI.

14:49 I have another one that's a little bit of a sticky situation here, but I think it's really interesting to dig into, okay?

14:55 - Okay.

14:56 - This is actually from January 14th, Actually, let me look at the AWS blog and see when they published it.

15:03 January 9th.

15:04 So this is something I've been wanting to talk about for a little while, but it's involved.

15:08 There's a lot of moving parts and a lot of layers to this.

15:10 So I didn't want to just give it like a super peripheral, sort of skim the surface type of thing.

15:16 So here's the deal.

15:17 I'm talking about an article by a guy named Ben Thompson who runs Stratechery, which is a really great resource for understanding the business side of software.

15:26 So super interesting work that he's doing there.

15:29 This one's called AWS, MongoDB, and the Economic Realities of Open Source.

15:34 Yeah, and he also runs a podcast called Exponent.

15:38 And Exponent is sort of the audio side.

15:42 He does this with another guy named James.

15:45 And I'm linking to an hour-long episode he did on this called Inverted Pyramids, which talks about demand and building platforms and things like that.

15:53 So really interesting interplay between open source, cloud computing and so on.

15:57 But it focused on this disagreement at a business level between MongoDB and AWS.

16:03 Okay, so MongoDB, they make databases, right?

16:06 They make a document database and they have kind of a unique API and they are definitely the most popular of the document databases.

16:14 Regardless of whether you like MongoDB or not, certainly they are well known and well used in that space, right, in the DocumentDB space.

16:22 If you're not doing that, you're probably doing Postgres in the Python world.

16:25 But AWS wanted to have a MongoDB as a service type of offering, like they have RDS and other managed database options, right?

16:35 They want to have basically a MongoDB compatible one.

16:39 But MongoDB, the company, their business model is basically three things.

16:44 They sell an enterprise version of the on-premise software.

16:48 That's kind of unrelated to this.

16:50 They have a free community version.

16:52 And then they sell this thing called Atlas DB, which is MongoDB as a service.

16:57 And what you do is you go to MongoDB Atlas and you say I'd like to run this on AWS, or I'd like to run it on Azure, on Google's cloud.

17:04 So that's MongoDB's business model.

17:06 AWS just wants just to have a service.

17:08 So MongoDB, who owns the IP, the licensing of MongoDB, the server, changed it to something called AGPL.

17:19 Have you heard of AGPL?

17:21 Well, I think, but I don't remember what it is.

17:22 You've heard of GPL, right?

17:23 Basically, if you use this software in yours, then you must make yours open source.

17:29 That's true when you directly depend on it.

17:32 But what if it's hosted and managed by Amazon and you just talk to it over the network?

17:37 You're not interacting with it.

17:38 You're not using it, right?

17:39 Well, AGPL is like GPL plus network.

17:42 So if you access this software over the network, it's like the GPL applies to you.

17:47 Isn't that weird?

17:48 So basically, what that means is AWS cannot have a hosted MongoDB.

17:56 Because if they do, it triggers this AGPL and AWS becomes open source or something crazy like this.

18:05 The consequences are too high and Apple's banned it from the App Store, Google has banned it from all, any AGPL software basically is not allowed within Google.

18:12 It's really not something these cloud companies are interested in having interactions with.

18:18 Because it takes the GPL bit and doesn't talk about shipping stuff, but accessing over the network.

18:21 So that brings us to the interesting part.

18:25 So what does AWS do?

18:26 Not just go, okay, great, we keep running Atlas.

18:28 No, AWS says, today, they said this on January 9th, today we are launching Amazon DocumentDB with MongoDB compatibility, a fast, scalable, and highly available database that's designed to be compatible with your existing MongoDB applications and tools.

18:43 It's purpose-built, it has all this replication, et cetera, et cetera, and it's all for your production scale MongoDB workloads.

18:50 So they took the exact API of MongoDB and rebuilt a brand new server and service from it, from scratch.

18:57 >> Okay, interesting.

18:58 >> They didn't do it on the latest one, because the latest one has the AGPL, so they went back to 3.6.

19:02 The latest one is like 4.05 or something like that.

19:05 So they went back to the latest one, the newest one that doesn't have this restriction.

19:09 They mimicked that, which should be good enough actually for most people, I would guess.

19:13 >> Yeah, weird.

19:14 >> Is that interesting?

19:15 You change your license so we can't have it.

19:17 So we literally copy your API, like byte for byte on the wire identical and rebuild a new service from scratch on it.

19:24 - Okay, both sides are kind of being sneaky and whatever.

19:29 - Yes, I feel a little more kinship towards the MongoDB Inc side because they developed this whole thing from scratch and they built it up and they got it popular.

19:39 But yeah, it's definitely an interesting tit and tat.

19:42 So what is the Zagpl to all of Mongo then?

19:46 What if I build my website?

19:47 Yeah, the community edition is separate for your self-hosting somehow.

19:52 But there's clauses about accessing it over the network.

19:55 Basically, it's very much like the GDPR is mostly built to fight Google and Facebook.

20:02 My understanding is basically this is to fight the cloud providers, not meant to interact with regular people just running the community version.

20:08 OK, but regular people are running on clouds, too.

20:11 I know.

20:11 It's quite interesting.

20:12 I just would not want to pick a fight with one of these big players, but whatever.

20:17 - Yeah, so I encourage people to both, maybe first listen to the podcast and then read the article if you want to go all in, but you can skim the article, you can't always skim the podcast.

20:27 I know some people do like 2.5x, but those people are crazy.

20:30 It melts my brain, I can't do it.

20:31 - I do 1.3.

20:32 - Yeah, that's a pretty good balance.

20:34 There's layer upon layer.

20:36 Maybe I'll come to the conclusion real quick.

20:38 So it says, "Thus we have arrived at a conundrum "for open source companies.

20:42 MongoDB leveraged open source to gain Mindshare, right?

20:45 Started as open source.

20:47 MongoDB Inc. built a successful company selling additional tools for enterprises to run MongoDB.

20:53 But more and more enterprises don't want to run software, easier or not.

20:57 They want to hire AWS or Microsoft or Google or some other cloud provider to run it for them because they value performance and scalability and all that.

21:04 So it leaves MongoDB pretty much like a little bit outside the value chain, which is interesting.

21:11 And there's just a lot of interesting trade-offs for open source VC funded companies and traditional monetization strategies are looking harder and harder in the face of cloud computing companies.

21:22 There's go, that's cool API, we'll do that.

21:25 I told you lots of layers and I really, I don't know, it takes a lot of pondering and I really don't know where I am.

21:30 But I think it's a big deal, honestly.

21:32 - It is a big deal.

21:33 And for the rest of us, the topic is important.

21:36 Document databases are kind of amazing and I think that we need to push those forward and having legal structures trying to get in the way of making this just better for everybody.

21:48 I know that everybody that started it should be able to make money, but also it needs to move forward.

21:55 So yeah, there's lots of sides to this.

21:58 - There are a lot of angles and a lot of sides, and Ben does a super job covering it.

22:02 So anyway, link to that if that sounds interesting, and check it out.

22:05 It's not exactly the newest of news, but I think it's big news still in the open source world.

22:09 - Okay.

22:10 - Extra stuff for us this week?

22:12 - Just that I'm so terrible with names, but the people that do the Teaching Python podcast, I just released an episode of Testing Code where I interviewed them.

22:22 - Yeah, I saw that come out, that's great.

22:23 - Yeah, so that was cool.

22:25 Do you have any extras?

22:26 - I have a couple of extras, just mostly follow-ups and some news.

22:30 So the folks running PyTexas in Austin, which sounds like a really fun place to be if you couldn't come to PyCascades in Seattle, PyTexas 2019 is going to be April 13th and 14th.

22:41 The registration is open and I'm linking to their page and stuff.

22:44 It looks pretty cool.

22:46 That's one.

22:47 The other is the article we covered from Anthony Shaw last week.

22:49 Apparently it was like two years old and somebody had sent it to us so it felt like, oh yeah, here's a new article from Anthony.

22:55 So we covered it as if and without any caveats.

22:58 So Anthony Shaw, sorry we dug up your old, your very far past predictions of the future and then presented them from today.

23:06 But they're still good.

23:07 I thought it was quite a good article and it stands the test of time pretty well.

23:11 And finally, remember when I talked about Rust Python and I said the reason this makes me super, super happy, Brian, is that it enables this WebAssembly future of Python because Rust has a very strong WebAssembly story?

23:24 Well, on that episode page, one of the core developers posted a comment, said, thanks for covering this.

23:31 By the way, rustpython.github.io/demo.

23:35 Yeah, that's it running in the web.

23:38 The CPython built on Rust, well, Rust Python, running the web under WebAssembly.

23:44 So if you open that bad boy up, and boom, it's up and running.

23:48 You can go and type stuff.

23:49 There's not much of a standard library.

23:51 That's something we already covered previously.

23:53 So it's kind of mostly a language level thing.

23:55 But here it is, two megabytes WebAssembly binaries running in your browser.

24:00 It's pretty cool.

24:01 - That is really pretty cool.

24:03 - Yeah.

24:04 Yeah, alright, so that's all of it for my extra stuff as well.

24:06 Okay.

24:07 You got a joke for me?

24:08 People are enjoying this joke segment.

24:10 I'm enjoying the joke segment.

24:11 I do not have one.

24:12 Okay, I got two.

24:13 I'll see what you think of these, okay?

24:14 Okay.

24:15 Why was the developer unhappy at their job?

24:17 I don't know, why?

24:18 They wanted arrays.

24:20 A-R-R-A-Y-S.

24:21 Arrays.

24:22 That's pretty bad.

24:24 That's lists for all the Python people.

24:26 Yes.

24:27 Where did the parallel function wash its hands?

24:30 I'm not sure where.

24:30 In async.

24:31 A-S.

24:32 Was there a line or did it have to wait?

24:34 (laughing)

24:36 - That's pretty good.

24:38 Yeah, these are bad, these are pretty bad, bud.

24:39 Here they are.

24:40 - No, it's good.

24:42 I have kids, so I'll retell these.

24:45 They won't understand it, but that's all right.

24:47 - Yeah, but they'll be in like the style in which they should appreciate.

24:52 They just, the jokes just won't make sense.

24:54 - Yeah, anyway.

24:56 - Awesome, all right, well, welcome back and thanks for doing the show with me today.

24:59 - Yeah, thank you.

25:00 - You bet.

25:01 listening to Python Bytes. Follow the show on Twitter via @PythonBytes. That's Python Bytes as in B-Y-T-E-S. And get the full show notes at PythonBytes.fm. If you have a news item you want featured, just visit PythonBytes.fm and send it our way. We're always on the lookout for sharing something cool. On behalf of myself and Brian Auchin, this is Michael Kennedy. Thank you for listening and sharing this podcast with your friends and colleagues.

Back to show page