{"id":19179952,"url":"https://github.com/bbb1991/kafka-example","last_synced_at":"2026-06-22T14:32:13.054Z","repository":{"id":80433340,"uuid":"84764206","full_name":"bbb1991/kafka-example","owner":"bbb1991","description":null,"archived":false,"fork":false,"pushed_at":"2017-03-13T11:32:14.000Z","size":307,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":2,"default_branch":"master","last_synced_at":"2025-02-23T01:44:59.026Z","etag":null,"topics":["java","kafka","rest-api","rsa-key-pair"],"latest_commit_sha":null,"homepage":null,"language":"Java","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/bbb1991.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2017-03-12T23:09:21.000Z","updated_at":"2017-03-12T23:15:57.000Z","dependencies_parsed_at":null,"dependency_job_id":"fb1263f4-f0e7-4757-bc81-1f8aef3b5bba","html_url":"https://github.com/bbb1991/kafka-example","commit_stats":null,"previous_names":[],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/bbb1991/kafka-example","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bbb1991%2Fkafka-example","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bbb1991%2Fkafka-example/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bbb1991%2Fkafka-example/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bbb1991%2Fkafka-example/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/bbb1991","download_url":"https://codeload.github.com/bbb1991/kafka-example/tar.gz/refs/heads/master","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/bbb1991%2Fkafka-example/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":286080680,"owners_count":34653712,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2026-05-26T15:22:16.424Z","status":"online","status_checked_at":"2026-06-22T02:00:06.391Z","response_time":106,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["java","kafka","rest-api","rsa-key-pair"],"created_at":"2024-11-09T10:45:30.634Z","updated_at":"2026-06-22T14:32:13.025Z","avatar_url":"https://github.com/bbb1991.png","language":"Java","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Пример взаимодействия сервер клиента через Kafka\n![David Dependency Management](https://david-dm.org/bbb1991/kafka-example.svg)\n![Travis CI](https://travis-ci.org/bbb1991/kafka-example.svg?branch=master)\n\n## Общие сведения\n![Kafka](kafka.jpg)\n\nПростой пример работы с Apache Kafka, Подписанием JSON обьекта RSA ключом.\nСостоит из модулей клиент-сервер.\nРаботает следующим образом:\n- Пользователь отправляет серверу REST запрос, содержащий модель Employee (взят из воздуха и беcсмысленный ~~как и моя жизнь~~)\n- Сервер получает данное сообщение, подписывает ее RSA ключем и отправляет ее дальше на Kafka.\n- Kafka перессылает сообщение всем подписчикам\n- Клиенты (то бишь подписчики) получают сообщение, расшифровывают ее, и печатает в консоль\n\n## Как собрать\nв консоли набрать \n```bash\nmvn package\n```\n\n## Как запустить\n1. Скачать и запустить Apache Kafka\n2. Запустить сервер (Сервер оформлен в виде embedded файла, то есть standalone JAR файл чтобы не париться с деплоем).\n3. Запустить n клиентов (Обычные Jar файлы)\n4. Браузером постучаться на адрес: http://localhost:8080/entry - это даст ~~ачивку \"Эксперт по бессмысленной трете жизни\"~~ пример JSON обьекта, которую можно дальше отправить\n5. Отправить POST запрос на адрес выше. В теле указать ранее полученный JSON обьект\n6. Посмотреть консоль клиентов\n\n## Как настроить\nВсе настройки свалены в одну кучу, в файл: application.properties. Лежит в модуле common\n\n## Примечание\nДанный пример написан за один вечер, без соблюдения каких либо правил и общепринятых решений. При чтений данного кода возмно Вам захочется посмотреть на меня с болью и глубокой скорбью.\n\n## TODO\n- Написать тесты\n- Использовать IoC библиотеку\n- Заменить JSON на другой обьект. Avro?\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fbbb1991%2Fkafka-example","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fbbb1991%2Fkafka-example","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fbbb1991%2Fkafka-example/lists"}