• Stars
    star
    369
  • Rank 115,686 (Top 3 %)
  • Language
    Clojure
  • License
    BSD 3-Clause "New...
  • Created almost 6 years ago
  • Updated 3 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

A Clojure library for the Apache Kafka distributed streaming platform.

Jackdaw · Clojars Project Code Coverage cljdoc badge CircleCI

Jackdaw is a Clojure library for the Apache Kafka distributed streaming platform. With Jackdaw, you can create and list topics using the AdminClient API, produce and consume records using the Producer and Consumer APIs, and create stream processing applications using the Streams API. Jackdaw also contains functions to serialize and deserialize records as JSON, EDN, and Avro, as well as functions for writing unit and integration tests.

Supported versions

Jackdaw currently only works with Clojure >= 1.10. This is because we are using the datafy protocol which was only introduced in 1.10.

Documentation

You can find all the documentation on cljdoc.

Examples

Contributing

We welcome any thoughts or patches. You can reach us in #jackdaw (or open an issue).

Related projects

If you want to get more insight about your topologies, you can use the Topology Grapher library to generate graphs. See an example using jackdaw to check how to integrate it with your topology.

Releasing

Anyone with the appropriate credentials can "cut a release" of jackdaw using the following steps.

  1. Review the diff of master vs the latest released tag (e.g. while preparing 0.7.0, I looked at https://github.com/FundingCircle/jackdaw/compare/0.6.9...master to see what was actually merged vs what was in the Changelog). Make a PR to put a date on the version being released and if necessary ensure completeness and consistency of the Changelog
  2. Use the Draft a new release feature in github to prepare a release
  3. In the "tag version" field, enter the proposed version
  4. In the "release title" field, enter "v[version]"
  5. In the "describe this release" field, enter the contents of the Changelog and add a credit to the contributors of the release
  6. When happy, use the "Publish Release" button to publish the release in github which creates a corresponding git tag
  7. Once the tag is seen by circleci, a deployment build is triggered which builds the project and deploys a release to clojars

Steps 2 to 6 is essentially git tag $version -m "$title\n\n$description" && git push --tags

License

Copyright © 2017 Funding Circle

Distributed under the BSD 3-Clause License.

More Repositories

1

fc4-framework

A Docs as Code tool that helps software creators and documentarians author software architecture diagrams using the C4 model for visualising software architecture.
Clojure
129
star
2

learn-you-some-kafka

Atomic, bite-size, highly-focused interactive tutorials that teach you how to work with Kafka
Ruby
47
star
3

ring-gatekeeper

Authentication middleware in Clojure
Clojure
24
star
4

sass-common

Common Sass mixins and files
SCSS
16
star
5

dotatom

Config for the Atom text editor
CoffeeScript
15
star
6

jukebox

All the best songs. Discuss in #jukebox on Clojurians Slack.
Clojure
15
star
7

ring-request-proxy

Ring middleware to proxy requests
Clojure
14
star
8

fluent-plugin-graylog

GrayLog output plugin for Fluentd
Ruby
13
star
9

factory-time

A Clojure library inspired by factory_girl
Clojure
13
star
10

loga

Unified logging across environments
Ruby
8
star
11

clj-loga

Custom log formatting
Clojure
7
star
12

DaD

a “Docs as Data” toolkit — a command-line tool *and* a Clojure library 🤯🙄😬🤓
Clojure
7
star
13

ring-venturi

Ring middleware to rate-limit requests
Clojure
7
star
14

md2c8e

“Markdown to Confluence” — A tool for publishing sets of Markdown documents to Confluence
Clojure
6
star
15

dotvim

Vim configuration setup
Vim Script
5
star
16

pg_failover

Ruby library for handling failover events in PostgreSQL database clusters
Ruby
4
star
17

sshkit-backends-netssh_global

Configure options for Capistrano 3 and SSHKit globally.
Ruby
4
star
18

krump

A kafka consumer focused on convenience
Ruby
3
star
19

gem-versioner

Gem plugin for specifying pre-release versions when building gems
Ruby
2
star
20

do-make-rethink

A Clojure library for making RethinkDB databases.
Clojure
2
star
21

python_code_academy

Python
2
star
22

ein.alpha

Less than lein, less than pants, more than deps
Clojure
2
star
23

github-tools

Tools for working with GitHub in a large org with many repos.
Ruby
2
star
24

ragtime-cli-tools

Lets you run ragtime migrations from an uberjar
Clojure
2
star
25

hellgrid

Track Ruby gem dependencies across projects.
Ruby
2
star
26

capistrano-ext-superusers

Capistrano plugin to run commands as a specific user
Ruby
1
star