This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2019-11-29
Channels
- # adventofcode (11)
- # aws (2)
- # bangalore-clj (8)
- # beginners (92)
- # boot (2)
- # calva (26)
- # cider (1)
- # clj-kondo (4)
- # cljs-dev (4)
- # clojure (54)
- # clojure-berlin (5)
- # clojure-houston (6)
- # clojure-italy (12)
- # clojure-nl (7)
- # clojure-uk (39)
- # clojurescript (12)
- # clojutre (6)
- # cryogen (1)
- # cursive (15)
- # datomic (11)
- # duct (1)
- # events (5)
- # fulcro (14)
- # jackdaw (1)
- # joker (2)
- # malli (15)
- # mental-health (1)
- # off-topic (35)
- # reagent (2)
- # reitit (24)
- # rewrite-clj (3)
- # shadow-cljs (19)
- # vim (11)
Ah yeah the problem you're running into is that when kafka tries to create an instance of this class, it tries to locate the class using the default classpath resolver.
However unless you AOT compile a class defined by clojure code, it can only be found using clojure's custom dynamic class resolver.
There is an alternative arity when creating a producer that allows you to pass include a map with keys :key-serde
and :value-serde
. You can use instances of the JSON serde in here which will override whatever serde is specified in the property map (I think you might still need to specify a serde in the property map just because kafka requires it but not sure about that).
https://github.com/FundingCircle/jackdaw/blob/master/src/jackdaw/client.clj#L33