-
Notifications
You must be signed in to change notification settings - Fork 734
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
KSQL quickstart for Kubernetes #164
base: master
Are you sure you want to change the base?
Conversation
If I exec |
Did some catching up, watched https://www.confluent.io/kafka-summit-london18/ksql-201-a-deep-dive-into-query-processing. KSQL is highly interesting because unlike the other streaming platform tools it is
I really need to get this up and running. The experimental web api sounds interesting too. CLI isn't of much use in kubernetes. Edit: my player wouldn't give me a link, but at around 25:00 in the video there's a very enlightening description of KSQL as abstraction on top of Kafka Streams. |
There's an amazing infinite loop in the docs on how to download KSQL. I fail to find a way to download a compiled package. The confluent platform download requires an e-mail registration, so I wouldn't want to redistribute it in docker. Edit: In fact the loop wasn't infinite. After a few rounds I understood that one instruction is the naming of individual deb packages. Result: StreamingMicroservicesPlatform/docker-kafka#4 |
If I understood it right then KSQL Rest API is not for production use. |
@pavel-agarkov I too would be glad if you're wrong :) https://docs.confluent.io/current/ksql/docs/installation/server-config/index.html#non-interactive-headless-ksql-usage may indicate that you're right though. Also "proper response codes" in https://docs.confluent.io/5.0.0-beta1/release-notes.html#ksql indicate that 4.x is immature wrt REST. |
Actually experiments using CLI + production as a ConfigMap with mounted Edit: Result topics and regular consumers would be practical enough for most of our use cases. |
Yes, to consume results the regular consumers can be used to read from the topics created by KSQL. |
Maybe we could come up with something similar to how https://github.com/coreos/prometheus-operator combines rules files into a single config? Could start as a client side script instead of an operator. I'm not sure KSQL will be valuable to us, an organization where only programmers use Kafka. As an abstraction on top of Kafka Streams, KSQL can only have a subset or equal feature set, so we could just as well use java. Two potential advantages:
Because https://www.confluent.io/blog/introducing-confluent-platform-preview-releases/ says "We encourage developers to build applications against the API shipped in this preview" I've updated the docker image to 5.0.0-beta1. |
I did a little experimenting with KSQL using https://hub.docker.com/r/confluentinc/cp-ksql-cli/ https://hub.docker.com/r/confluentinc/cp-ksql-server/ The experiment was done using a single node Kafka cluster, hosted in minikube on my local machine. Two KSQL processes were started outside of minikube, in docker. Both the brokers and schema registry were configured to make their IPs accessible outside of the cluster using #160. Maybe I missed something, but the |
I think Confluent recently started shipping |
I was able to get the server spun up utilizing the following (not sure if this is good practice or not, I'm very new to K8 but wanted to get this fired up to test with) https://gist.github.com/jeffbeagley/7934fb90d3778519914ccd4521da2ca4 |
The sequel to #68, using confluent's images because I failed to build 0.5 using earler Dockerfiles. No luck with starting ksql-cli in k8s yet though.
I'd like to set up the equivalent of https://github.com/confluentinc/ksql/tree/master/docs/quickstart.
@pavel-agarkov @clintfred I've tried to refresh #68 with a new build of ksql but the old build steps failed on various test crashes. I'd happily switch to confluent's images, but my quick attempt here fails to start ksql and fails to get any logs out of the failed container. Unfortunately I don't have more time to spend on this in the near future. I thought converting the docker-compose.yml in quick start would be a no-brainer.
I set up a fresh kafka + avro-tools from master with no tweaks at all.