Skip to content
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

Add Pulsar transport #2297

Open
schrepfler opened this issue Nov 29, 2018 · 7 comments · May be fixed by #3788
Open

Add Pulsar transport #2297

schrepfler opened this issue Nov 29, 2018 · 7 comments · May be fixed by #3788

Comments

@schrepfler
Copy link
Contributor

I think it would be useful to try to add an additional transport to Zipkin which would be Apache Pulsar.

Feature:
Description of the feature

Rational
Pulsar has several features which I think make it interesting for us:

  1. Integrated SQL query capability.
    Latest Pulsar has integrated SQL query capabilities based on the Facebook Presto engine. This means it's possible to query data directly from the topic thus reducing the need to have a separate DB tier.
    Benefit: Potentially simplified deployments.
    Unknown: Not quite clear how capable is the query engine and would it be suitable for the kind of queries Zipkin makes.

  2. Tiered storage.
    Pulsar has the capability to offload topics onto long term/cheap storage (ex. S3) without having to estimate ahead of time any size or time based expiration policies.
    Benefit: Simplify DB management overhead and provide simple way how to enable cheap durable persistence.

  3. Decoupled storage from brokers
    By decoupling brokers from storage Pulsar (at least on paper) should be easier to scale out.
    Benefit: Smaller operational overhead, less chances of errors and simplified operations.

  4. Scales to more topics

  5. Multitenancy and Georeplication capabilties.
    Benefit: Potentially diverse business uses

  6. Pulsar functions.
    It's possible to implement very low latency triggers based on messages which trigger actions directly in the middleware.

  7. Kafka compatibility mode.
    Might be possible to use it in Kafka compatibility mode to simplify development (but at that point I'm not sure if it's possible to leverage the other features).

  8. Web Sockets capability
    It's possible to expose the data stream over web sockets, might be interesting if we want to do fancy stuff in the UI (like real time tracing on a giant ring, I think this view was lost from the old days at Twitter?)

  9. Lower latency thank Kafka (on paper)

  10. Schema registry
    If the data is persisted in one of the formats that support schema it might be possible to evolve the format by using the format schema tools and the registry. I think using a schema is a requirement in order to be able to use Presto to query the data. JSON, Protobuf and Avro are supported.

@bsideup
Copy link
Contributor

bsideup commented Feb 11, 2019

A few non-func points from me:

  1. Pulsar provides truly async client, while Kafka is coming from the blocking world
  2. Pulsar consumer API is simpler than Kafka's (where if you don't poll you might end up de-assigned from the partition (sic!))
  3. Running Kafka behind NAT is problematic, while Pulsar can be used with a proxy
  4. Pulsar SQL is a driver for Presto, not a brand new tech from scratch by a commercial owner of the tech
  5. Backing up Pulsar clusters is much easier thanks to the tiered storage

@schrepfler
Copy link
Contributor Author

schrepfler commented Feb 11, 2019

Is 2) a problem? I think in this case we care mostly about the publisher API (agent/middleware -> pulsar) which can also be batched/delayed locally (at risk of loss).

@bsideup
Copy link
Contributor

bsideup commented Feb 11, 2019

No2 is an advantage of Pulsar, not a problem :) Sorry for confusing :)

Also, Kafka's publisher can block on publish, even if async API is used, while afaik there is no such issue in Pulsar

@schrepfler
Copy link
Contributor Author

No problem. I think Kafka did mitigate the blocking client a bit in the last releases (just for fairness/completeness of the argument) https://cwiki.apache.org/confluence/display/KAFKA/KIP-266%3A+Fix+consumer+indefinite+blocking+behavior

@bsideup
Copy link
Contributor

bsideup commented Feb 11, 2019

Only in the consumer part, but there are still blocking calls in Kafka's async producer :(

@codefromthecrypt
Copy link
Member

if anyone does a spike, do link back for the fans

@codefromthecrypt
Copy link
Member

I see there was a spike of interest, but unsure any outcome. Did anyone do anything?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants