{"id":23932241,"url":"https://github.com/d0ugur4su/kafka-fundamentals-for-java-developers","last_synced_at":"2025-02-24T02:17:03.300Z","repository":{"id":44422844,"uuid":"512440758","full_name":"D0UGUR4SU/Kafka-fundamentals-for-java-developers","owner":"D0UGUR4SU","description":"Studies related about Kafka-fundamentals-for-java-developers Udemy course","archived":false,"fork":false,"pushed_at":"2022-07-14T18:23:22.000Z","size":221,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":2,"default_branch":"main","last_synced_at":"2025-01-06T00:14:03.110Z","etag":null,"topics":["kafka","kafka-streams","stream-processing"],"latest_commit_sha":null,"homepage":"","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/D0UGUR4SU.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}},"created_at":"2022-07-10T13:22:18.000Z","updated_at":"2022-07-14T18:23:59.000Z","dependencies_parsed_at":"2022-09-14T05:21:05.265Z","dependency_job_id":null,"html_url":"https://github.com/D0UGUR4SU/Kafka-fundamentals-for-java-developers","commit_stats":null,"previous_names":["d4gur4su/kafka-fundamentals-for-java-developers","d0ugur4su/kafka-fundamentals-for-java-developers"],"tags_count":0,"template":false,"template_full_name":null,"repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/D0UGUR4SU%2FKafka-fundamentals-for-java-developers","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/D0UGUR4SU%2FKafka-fundamentals-for-java-developers/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/D0UGUR4SU%2FKafka-fundamentals-for-java-developers/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/D0UGUR4SU%2FKafka-fundamentals-for-java-developers/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/D0UGUR4SU","download_url":"https://codeload.github.com/D0UGUR4SU/Kafka-fundamentals-for-java-developers/tar.gz/refs/heads/main","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":240404762,"owners_count":19796064,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","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":["kafka","kafka-streams","stream-processing"],"created_at":"2025-01-06T00:13:49.954Z","updated_at":"2025-02-24T02:17:03.241Z","avatar_url":"https://github.com/D0UGUR4SU.png","language":"Java","funding_links":[],"categories":[],"sub_categories":[],"readme":" \u003ch1 align=\"center\"\u003eKafka-fundamentals-for-java-developers\u003c/h1\u003e\n\n\u003cp align=\"center\"\u003e\n    \u003cimg src=\"assets/logo.png\"\u003e\n\u003c/p\u003e\n\n---\n\n# 💻 About the project\n\n• What is Apache Kafka?\nApache Kafka is an open source software platform for message stream processing written in Scala with Java. Among the advantages of the platform, we can emphasize its way of unifying its components and external Plugins, low latency and high throughput, approaching the real-time data feed.\n## Concepts\n\n• Messages – Understand by messages all the information that travels over Apache Kafka, be it a phrase, a word, an array of bytes, etc.\n\n• Streaming – Streaming applied on this platform is the entire flow of a message until the capture by Apache Kafka and the consumption of this message, where we have the   following scenario: Actor -\u003e Action -\u003e Generates x messages, that is, a request flow for example: Cashier-\u003eCreation-\u003eOrder and from this flow there can be a series of messages.\n\n• Topic – A topic is a way of labeling or categorizing a message, imagine a closet with 10 drawers, each drawer can be a topic and the closet is the Apache Kafka platform, so in addition to categorizing it groups messages, another better analogy about the topic would be tables in relational databases.\n\n• Producer – The producer or producer is the person who connects to a messaging platform and sends one or more messages to a specific topic.\n\n• Consumer – The consumer or consumer is the person who connects to a messaging platform and consumes one or more messages from a specific topic.\n\n• Broker – The concept of broker in Kafka's platform is nothing more than practically Kafka himself, he is the one who manages the topics, defines the way of storing messages, logs etc.\n\n• Cluster – The concept of cluster is nothing more than a set of Brokers that communicate with each other or not for better scalability and fault tolerance.\n\n• Log file – Each topic stores its records in a log format, that is, in a structured and sequential way, the log file is therefore the files that contain the information of a topic.\n\n• Partitions – The partitions or partitions as the name said is the partition layer of messages within a topic, this partitioning guarantees the elasticity, fault tolerance and scalability of Apache Kafka, so each topic can have several partitions in different locations.\n\n• Replicas – Replicas are like partitions of partitions, they have the same role as the partition but as a form of redundancy for a given partition, so Kafka partitions are highly available and replicated, when stream data is persisted in Kafka, it becomes available even if the app crashes.\n\n• Segments – The segments are inside the partitions and segment the information contained in the log files of that partition, every topic has its partition and its segmentation, the segmentation serves to manage the ordering of the log file information as well as the time it will be persisted.\n\n---\n    \n## 🦸 Author\n\n\u003ca href=\"#\"\u003e\n \u003cimg style=\"border-radius: 50%;\" src=\"https://avatars.githubusercontent.com/u/50157211?s=120\u0026v=4\" width=\"100px;\" alt=\"\"/\u003e\n\u003cbr /\u003e\n\nMade by Douglas Souza 👋🏽 Get in touch!\n\n[![Linkedin Badge](https://img.shields.io/badge/-Douglas-blue?style=flat-square\u0026logo=Linkedin\u0026logoColor=white\u0026link=https://www.linkedin.com/in/dagurasujava/)](https://www.linkedin.com/in/dagurasujava/) \n[![Gmail Badge](https://img.shields.io/badge/-contini.ds@gmail.com-c14438?style=flat-square\u0026logo=Gmail\u0026logoColor=white\u0026link=mailto:contini.ds@gmail.com)](mailto:contini.ds@gmail.com)\n\n---\n## README versions\n\n[English 🇺🇸](./README.md)\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fd0ugur4su%2Fkafka-fundamentals-for-java-developers","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fd0ugur4su%2Fkafka-fundamentals-for-java-developers","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fd0ugur4su%2Fkafka-fundamentals-for-java-developers/lists"}