This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2022-11-21
Channels
- # announcements (10)
- # aws (10)
- # babashka (23)
- # beginners (111)
- # biff (8)
- # calva (25)
- # clj-kondo (9)
- # cljsrn (4)
- # clojure (72)
- # clojure-belgium (6)
- # clojure-europe (50)
- # clojure-germany (2)
- # clojure-nl (1)
- # clojure-norway (6)
- # clojure-uk (1)
- # datahike (3)
- # emacs (10)
- # graalvm (19)
- # graphql (3)
- # juxt (7)
- # kaocha (9)
- # malli (23)
- # nbb (20)
- # pathom (17)
- # pedestal (6)
- # polylith (11)
- # portal (8)
- # remote-jobs (3)
- # shadow-cljs (18)
- # sql (3)
- # tools-deps (20)
Hi there! I’ve ⛵ away from and am in 🐍 land at the moment. Hopefully will back to the wonderful immutable land of parenthesis soon! Meantime, I’ve spent some time bringing some good stuff from Clojure into the Python community: Polylith 😄 Here’s what I’ve been working on and it has reached version 1 (the “good enough” release). The repo, with docs and videos (links in the readme). I’d love to hear your feedback about this (or from your Python-fellows out there): https://github.com/DavidVujic/python-polylith I also plan to write a blog post about this later this week too.
People are often https://twitter.com/janetacarr/status/1594465433037545474?s=46&t=8sOPPa-aQDuy9utVJ0mZag to Polylith in the beginning.
I have to admit I was a little bit skeptical about it too, but got hooked quickly. Working in the same team as the father of probably helped :star-struck:
I assume polylith is not a silver bullet 🙂 . I would be curious to know where the inflection point is. At what point does is make sense to use polylith? And does it makes sense to start with polylith from the beginning or migrate after the project is rather stable? The discussion seems to resemble the microservice one. I never heard the port and adapter discussion in an FP context until now. Would like to see some examples of the mentioned strategies protocols and higher-order functions. -- End Brain Dump
My feeling is that Polylith makes sense as soon as you have multiple deployable artifacts being built from a single monorepo.
So don't start with a polylith project 🙂. I need more "good practices" on how to keep all nice and tidy until the critical mass has been reached. I just need to figure out how to do all the Coupling and Cohesion stuff in FP and presto I have a modular monolith. I probably read to many blogs 🙂.
If I knew I was going to be creating multiple artifacts when I was starting a new monorepo, I'd "start with a polylith project" 🙂
I’ve used Polylith since it was in the idea phase in several production systems. I chose it when I started my own company, even though it was initially a small single artifact workspace. Our workspace got larger and larger over time, and we added more artifacts as needed. Adding artifacts and changing how we deploy became easy tasks since we had Polylith. Polylith even saved us from a production disaster when we first launched; we were able to split our deployment artifacts to isolate a part in the API causing memory leaks while we were working on a solution. This split took less than 30 minutes. I understand that if you have a small project and are unfamiliar with Polylith, it could be too much of an investment to read through the book-long documentation. I did start with Polylith at my company since I had a bias toward it; I was a part of the Polylith team. However, I can assure you that learning and understanding Polylith will add good tools to your developer's toolbox. And, if you are already familiar with Polylith, it won’t hurt to start with it, even for small projects.
I'm not sceptic, I would even go as far as saying polylith is definitely a silver bullet when it comes to orgs with multiple services/apps. What I wish it did and for this reason I don't currently use it is support cljs
Polylith to the rescue!
We've recently switched from the default Jetty (9) Ring adapter to the sunng Jetty 11 adapter (despite it being called ring-jetty9-adapter
) for security reasons -- Jetty 9 is out of community support and has had a few CVEs recently. Unfortunately, one of our web apps also uses Cognitect's AWS API which still depends on the Jetty 9 client and that does not work with the Jetty 11 http/util libs, and Cognitect's code doesn't work with the Jetty 11 client.
So we applied the "swappable implementations" trick: copied our web-server
component to web-server-9
, swapped out the deps.edn
reference to the sunng adapter for the old Ring adapter, and updated the require to point back to the old Ring adapter ns.
Updated the main deps.edn
: move poly/web-server
from :dev
to :+default
(and tweaked our other profiles). Updated the one app's deps.edn
under projects
to change poly/web-server
to ../../components/web-server-9
And that was it!