찾다
백엔드 개발Golanggolang으로 kafka 구현하기

엔터프라이즈 수준 애플리케이션 아키텍처의 복잡성이 증가함에 따라 메시지 전송이 중요한 구성 요소가 되었습니다. 이때 카프카가 등장합니다. Kafka는 메시지 게시 및 구독을 지원하는 효율적이고 안정적인 분산 메시지 대기열로, 처리량이 매우 높고 대기 시간이 짧은 최신 엔터프라이즈급 메시징 시스템입니다. Kafka의 API에서는 공식 클라이언트가 여러 언어를 제공하지만 최근에는 Golang이 점점 더 널리 사용되고 있으므로 이 기사에서는 Golang을 구현 언어로 사용하여 Golang을 사용하여 Kafka를 구현하는 방법을 설명합니다.

1. 종속성

시작하기 전에 필수 종속성을 다운로드해야 합니다.

  • sarama: Golang Kafka 클라이언트 라이브러리
  • pkg/errors: Go 표준 라이브러리의 오류 패키지를 캡슐화합니다.

구체적인 사용 방법은 다음과 같습니다. :

go get github.com/Shopify/sarama
go get github.com/pkg/errors

2. 생산자 생성

Kafka의 API를 소개하기 전에 먼저 생산자 인스턴스를 생성해야 합니다. 생산자의 코드는 다음과 같습니다.

package main

import (
    "fmt"
    "time"

    "github.com/pkg/errors"
    "github.com/Shopify/sarama"
)

func main() {
    config := sarama.NewConfig()
    config.Producer.Partitioner = sarama.NewRandomPartitioner
    config.Producer.RequiredAcks = sarama.WaitForAll
    config.Producer.Return.Successes = true

    producer, err := sarama.NewSyncProducer([]string{"localhost:9092"}, config)
    if err != nil {
        panic(errors.Wrap(err, "failed to create producer"))
    }
    defer producer.Close()

    for i := 0; i < 10; i++ {
        message := &sarama.ProducerMessage{
            Topic: "test_topic",
            Value: sarama.StringEncoder(fmt.Sprintf("test message %d", i)),
        }
        partition, offset, err := producer.SendMessage(message)
        if err != nil {
            fmt.Println(errors.Wrapf(err, "failed to send message: %s", message))
        } else {
            fmt.Printf("message sent to partition %d at offset %d
", partition, offset)
        }

        time.Sleep(500 * time.Millisecond) // 延迟发送
    }
}

코드는 주로 다음 작업을 수행합니다.

  • 생산자 구성: 생산자의 구성을 설정하고 분할 방법을 무작위 분할로 지정하고 모든 ISR 노드가 분할될 때까지 기다립니다. 메시지를 확인하고 전송 성공 후 파티션 및 오프셋을 반환하고 반환합니다.
  • 생산자 생성: 지정된 브로커 주소와 구성을 사용하여 생산자 인스턴스를 생성합니다.
  • 메시지 보내기: 메시지 제목과 내용을 포함하여 메시지를 작성하여 보냅니다.
  • 출력 결과: 결과 인쇄, 메시지 파티션 기록 및 오프셋.

3. 소비자 생성

두 번째로 소비자 인스턴스를 생성해야 합니다. 소비자 코드는 다음과 같습니다.

package main

import (
    "context"
    "fmt"
    "os"
    "os/signal"

    "github.com/Shopify/sarama"
    "github.com/pkg/errors"
)

func main() {
    config := sarama.NewConfig()
    config.Consumer.Return.Errors = true

    consumer, err := sarama.NewConsumer([]string{"localhost:9092"}, config)
    if err != nil {
        panic(errors.Wrap(err, "failed to create consumer"))
    }
    defer consumer.Close()

    signals := make(chan os.Signal, 1)
    signal.Notify(signals, os.Interrupt)

    partitions, err := consumer.Partitions("test_topic")
    if err != nil {
        panic(errors.Wrapf(err, "failed to read partitions for topic: test_topic"))
    }

    ctx, cancel := context.WithCancel(context.Background())

    for _, partition := range partitions {
        go func(partition int32) {
            partitionConsumer, err := consumer.ConsumePartition("test_topic", partition, sarama.OffsetOldest)
            if err != nil {
                fmt.Printf("failed to create partition consumer for partition %d: %s
", partition, err)
                return
            }
            defer partitionConsumer.Close()

            for {
                select {
                case msg := <-partitionConsumer.Messages():
                    fmt.Printf("Consumed message from partition %d at offset %d: %s
", msg.Partition, msg.Offset, msg.Value)
                case <-signals:
                    cancel()
                    return
                case err := <-partitionConsumer.Errors():
                    fmt.Printf("Consumed error from partition %d: %s
", partition, err)
                case <-ctx.Done():
                    return
                }
            }
        }(partition)
    }

    <-signals
    fmt.Println("Shutting down consumer")
}

코드는 주로 다음 작업을 수행합니다.

  • 소비자 구성: 소비자를 구성하고 오류 반환 스위치를 설정합니다.
  • 소비자 생성: 지정된 브로커 주소 및 구성을 기반으로 소비자 인스턴스를 생성합니다.
  • 파티션 가져오기: 지정된 주제의 파티션을 가져옵니다.
  • 소비: 별도의 소비를 위해 각 파티션에 대해 고루틴을 엽니다.
  • 출력 결과: 소비된 메시지를 인쇄합니다.

4. 요약

위에서 Golang을 사용하여 Kafka의 생산자 및 소비자 부분을 구현했습니다. 분산 시스템 구현의 중요한 구성 요소 중 하나인 Kafka는 높은 동시성 및 분산 환경에 존재하는 메시지 시스템의 문제를 해결할 수 있습니다. Kafka는 우수한 지원 문서와 안정적인 커뮤니티를 갖추고 있어 실제 개발에 스트레스 없이 적용할 수 있습니다.

위 내용은 golang으로 kafka 구현하기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
INT 기능 및 부작용 : 유지 관리와의 초기화 균형INT 기능 및 부작용 : 유지 관리와의 초기화 균형Apr 26, 2025 am 12:23 AM

toensureInitFunctionSareefeCectiveAdaintainable : 1) minimizesideFectsByReTurningValuesInsteAdglobalstate, 2) inficeDempotencyToHandleMultipLecallsSafely 및 3) BRALKTODDOCLEXINITIANSETSMALLER, FOCUSISSEDFUNCINTURATURITYANDUMALOMODUMALEDUMAL ANDM

GOT GO로 시작 : 초보자 가이드GOT GO로 시작 : 초보자 가이드Apr 26, 2025 am 12:21 AM

goisidealforbeginnersandsuitableforcloudandnetworkservicesduetoitssimplicity, 효율성, 및 콘크리 론 피처

동시성 패턴 : 개발자를위한 모범 사례동시성 패턴 : 개발자를위한 모범 사례Apr 26, 2025 am 12:20 AM

개발자는 다음과 같은 모범 사례를 따라야합니다. 1. 자원 누출을 방지하기 위해 조롱 틴을 신중하게 관리합니다. 2. 동기화를 위해 채널을 사용하지만 과용을 피하십시오. 3. 동시 프로그램의 오류를 명시 적으로 처리합니다. 4. 성능을 최적화하기 위해 GomaxProc을 이해하십시오. 이러한 관행은 효율적이고 강력한 소프트웨어 개발에 효과적이며 자원의 효과적인 관리, 적절한 동기화 구현, 적절한 오류 처리 및 성능 최적화를 보장하여 소프트웨어 효율성 및 유지 관리 가능성을 향상시킬 수 있기 때문입니다.

생산으로 이동 : 실제 사용 사례 및 예제생산으로 이동 : 실제 사용 사례 및 예제Apr 26, 2025 am 12:18 AM

goexcelsinproductionduetoitsperformanceandsimplicity, butrequirescarefulmanagementibility, errorhandling, andresources

GO의 사용자 정의 오류 유형 : 자세한 오류 정보 제공GO의 사용자 정의 오류 유형 : 자세한 오류 정보 제공Apr 26, 2025 am 12:09 AM

표준 오류 인터페이스가 제한된 정보를 제공하고 사용자 정의 유형이 더 많은 컨텍스트와 구조화 된 정보를 추가 할 수 있으므로 오류 유형을 사용자 정의해야합니다. 1) 사용자 정의 오류 유형에는 오류 코드, 위치, 컨텍스트 데이터 등이 포함될 수 있습니다. 2) 디버깅 효율성 및 사용자 경험 향상, 3) 복잡성 및 유지 보수 비용에주의를 기울여야합니다.

GO 프로그래밍 언어로 확장 가능한 시스템 구축GO 프로그래밍 언어로 확장 가능한 시스템 구축Apr 25, 2025 am 12:19 AM

goisidealforbuildingscalablesystemsduetoitssimplicity, 효율성 및 빌드-내부 컨 컨 오렌 스upport.1) go'scleansyntaxandminimalisticdesignenenhance-reductivityandreduceerrors.2) itsgoroutinesandChannelsableefficedsoncurrentProgramming, DistributingLoa

GO에서 시작 기능을 효과적으로 사용하기위한 모범 사례GO에서 시작 기능을 효과적으로 사용하기위한 모범 사례Apr 25, 2025 am 12:18 AM

initTectionsIntOnaUtomaticallyBeforemain () andAreSefulforsettingupenvirondentAnitializingVariables.usethemforsimpletasks, propoysideeffects 및 withtestingntestingandloggingtomaincodeclarityAndestability.

GO 패키지에서 시작 함수의 실행 순서GO 패키지에서 시작 함수의 실행 순서Apr 25, 2025 am 12:14 AM

goinitializespackages는 theyareimported, theexecutesinitfunctions, theneiredefinitionorder, andfilenamesDeterMineDeTerMineTeRacrossMultipleFiles.ThemayLeadTocomplexInitializations의 의존성 의존성의 의존성을 확인합니다

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는