This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2016-03-07
Channels
- # admin-announcements (5)
- # aws (2)
- # boot (313)
- # cider (69)
- # cljsfiddle (18)
- # cljsrn (17)
- # clojars (6)
- # clojure (121)
- # clojure-austin (4)
- # clojure-bangladesh (4)
- # clojure-colombia (2)
- # clojure-dusseldorf (17)
- # clojure-japan (1)
- # clojure-russia (65)
- # clojure-sg (4)
- # clojurescript (94)
- # community-development (6)
- # core-matrix (2)
- # cursive (2)
- # data-science (6)
- # datomic (28)
- # hoplon (4)
- # jobs (1)
- # jobs-discuss (1)
- # keechma (15)
- # ldnclj (2)
- # off-topic (6)
- # om (140)
- # om-next (1)
- # onyx (47)
- # parinfer (11)
- # re-frame (13)
- # reagent (4)
- # spacemacs (7)
- # specter (7)
- # yada (18)
lucasbradstreet: I am also looking at integrating Onyx with input from an HTTP endpoint - I was going to go down the route of using an async chan to shovel the requests into an Onyx workflow, but would using onyx-seq
be a better sln do you think?
@acron: placing the requests on an async channel is fine but not very fault tolerant / clusterable as you will have to do it on the node that is allocated the task. You could do this by pinning that task via tagged constraits but you're probably better off just using onyx-seq. Do you have a way to re-fetch results in a node goes down? I ask because I need to know whether it might be possible to write a more fault tolerant input plugin
If you could explain a little more about how the web service works it might help
lucasbradstreet: you're right, my explanation was bad sorry. And I actually liked your idea about using Kafka as an input - so I'd have a web service take 'CQRS' commands, write them to Kafka and then an Onyx node can pick them up from there.
@acron: I think that approach would be fine. You just need to make sure to monitor your service that transfers from the web service to Kafka, since it’s the lynchpin
I'm trying to use the kafka plugin but it doesn't seem to read messages off my topic. No complaints during startup and kafkacat sees the messages, but the logging around my task doesn't seem to be kicking in which I presume means there's nothing being read..
@acron: Are you seeing the peers start their jobs?
in onyx.log something like
16-Mar-07 09:48:34 Gardners-MacBook-Pro.local INFO [onyx.peer.task-lifecycle] - [732a9b65-1674-46db-b80e-dcc493d9234c] Enough peers are active, starting the task
Are you using the lein template?
I'm not, no, I am just evolving one of the onyx-examples. I had a go with the lein template but it opted to go for something contained in a single file, just so I can understand it better whilst I'm still toying
Ok gotcha
@acron are you using the same ZooKeeper that Kafka is connected to with Onyx?
Maybe Kafka is writing its information to a different ZooKeeper than the one that the Kafka plugin is using for discovery
that might be a good idea
anyway, I suspect it’s something ZK related
Yea understandable
we’re working on that
@acron: S'all good. Gotta bump your head a few times before you learn your way around.
that'll be one upside of the new task bundles, as it'll be impossible to forget that
Just noticed something curious. I defined my workflow as [[:a :b] [:b :c] [:b :d] [:d :e]]
where :c
is an output/leaf. I added a flow-condition {:flow/from :b :flow/to [:d] :flow/predicate :pred?}
and this seems to prevent any flow to :c
even though I'd assume the :b->:c
relationship is unaffected by the flow condition.
If I add a flow condition like this, am I obliged to be explicit about everything else that :b
flows to?
I always forget about how this works, but the idea is that enabling flow conditions for that task will default to flowing out to the flow/to tasks you define, unioning the to tasks as predicates are matched for all the flow conditions you define
@acron: Yes, it requires you to be explicit.
Doing it this way is a lot more composable, though it does force you to be more explicit
I've seen a couple of examples of Onyx workflows and catalogs that involve writing to a Kafka topic and then reading from the same topic as the next step (http://yuppiechef.github.io/cqrs-server/, half way down the page). Other than for the purposes of visualising and maintaining a single workflow, is this even a good idea?
@acron: Independent starting/stopping is one advantage of having two separate jobs (workflows).
@acron: I tend to prefer it as well. Just a heads up, that CQRS project you linked to is super old. Hasn't been updated in about a year.
@michaeldrogalis: thanks for the warning. I haven't actually looked at the code, but trying to get inspiration for methodology
@acron: A ES/CQRS project based on Onyx today would look quite a bit different.
We have a stateful aggregation model now that did not exist back then.
Ah gotcha cool. Let me know if you have any observations/suggestions. Its always good to get a new set of eyes on this stuff.
Something a bit more recent: https://github.com/teaforthecat/bones
@lucasbradstreet, @michaeldrogalis: our new cluster is live 3 x ZK, 3 x Onyx. finally!