This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2017-09-22
Channels
- # beginners (104)
- # bitcoin (1)
- # boot (5)
- # clara (3)
- # cljs-dev (14)
- # cljsjs (5)
- # cljsrn (1)
- # clojure (242)
- # clojure-italy (17)
- # clojure-news (13)
- # clojure-norway (3)
- # clojure-russia (101)
- # clojure-spec (41)
- # clojure-uk (87)
- # clojurescript (38)
- # core-async (38)
- # cursive (6)
- # datomic (11)
- # defnpodcast (3)
- # docs (14)
- # editors (8)
- # events (1)
- # fulcro (7)
- # hoplon (25)
- # leiningen (4)
- # luminus (7)
- # off-topic (25)
- # onyx (1)
- # portkey (14)
- # random (1)
- # re-frame (7)
- # reagent (4)
- # rum (4)
- # schema (8)
- # shadow-cljs (257)
- # spacemacs (10)
- # specter (4)
- # unrepl (3)
- # yada (1)
I'm watching : https://www.youtube.com/watch?v=qJXqQATJNTk
In my understanding, aws lambda functions are STATELESS. In the counter example, where is the counter atom stored ?
But the idea is to deserialize the atom as a special implementation instead of a regular atom.
So this was a bit of a hack :) The Lambda runtime keeps the process running the handler alive for some period, just like FastCGI back in the old days. In the demo, we used this aspect to store request count in a Clojure atom.
Normally one would store state in a database. But since the runtime keeps the process running the handler alive, one can do initialization, like say creating a database connection, that would otherwise cost too much to do on every invocation.
I think this process liveliness aspect makes things like http keep alive or sql database client side connection pools possible
So yes, Lambda is best though of as stateless, but a process fork for each event still would cost too much even nowadays :)
So in the demo, the process running the lambda handler kept the counter atom in memory. Iām pretty sure that there were multiple processes running, which resulted in multiple separate atoms, which you could call a demo effect š
last week Tatu used portkey in a livecoding event, but then with a RDS PostgreSQL, so the observed state was a bit more consistent š