>백엔드 개발 >Golang >Go의 `recover()` 기능은 충돌 발생 시 어떻게 고루틴 지속성을 보장할 수 있습니까?

Go의 `recover()` 기능은 충돌 발생 시 어떻게 고루틴 지속성을 보장할 수 있습니까?

DDD
DDD원래의
2024-11-23 01:39:37885검색

How Can Go's `recover()` Function Ensure Goroutine Persistence in the Face of Crashes?

충돌에도 불구하고 고루틴 지속성 보장

동시 Go 프로그램에서는 여러 고루틴이 동시에 실행되는 경우가 많으며 각각은 서로 다른 작업을 수행합니다. 그러나 고루틴 실패 처리 문제를 해결하여 하나의 고루틴이 충돌하더라도 다른 고루틴이 계속 실행되도록 하는 것이 중요합니다.

두 개의 고루틴이 있는 프로그램을 고려해보세요. queue.ConsumeAndDoSomething()은 대기열을 소비하고 api.StartServer는 다음과 같습니다. ()는 API를 실행합니다. 이상적으로는 queue.ConsumeAndDoSomething()이 실패하더라도 API 서버는 영향을 받지 않고 그대로 유지되어야 하며 그 반대의 경우도 마찬가지입니다.

이 지속성을 달성하는 한 가지 접근 방식은 내장된 Recover() 함수와 지연된 함수를 사용하는 것입니다. Recover() 함수는 패닉을 포착하고 정리 루틴을 실행할 수 있는 반면, 지연된 함수는 주변 함수의 끝에서 자동으로 실행됩니다.

다음은 복구() 및 지연된 함수를 사용하여 고루틴 충돌로부터 보호하는 방법입니다.

func protect(f func()) {
    defer func() {
        if err := recover(); err != nil {
            log.Printf("Recovered: %v", err)
        }
    }()

    f()
}

이 도우미 함수인 protected()는 제공된 함수(f)를 패닉을 처리하는 지연 함수로 래핑합니다. 지연된 함수는 패닉 발생 여부에 관계없이 f 반환 전에 실행됩니다.

protect()를 사용하려면 간단히 goroutine 함수를 인수로 전달합니다.

func main() {
    go protect(queue.ConsumeAndDoSomething)
    go protect(api.StartServer)

    for {
        time.Sleep(time.Second)
        fmt.Println("tick")
    }
}

이 메커니즘을 사용하면 즉, queue.ConsumeAndDoSomething() 또는 api.StartServer()에서 패닉이 발생하면 지연된 함수에 의해 포착되어 프로그램 충돌 없이 정리됩니다. 다른 고루틴은 예상대로 계속 실행됩니다.

위 내용은 Go의 `recover()` 기능은 충돌 발생 시 어떻게 고루틴 지속성을 보장할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.