>백엔드 개발 >Golang >Go HTTP 핸들러 전체에서 MySQL 연결을 공유하는 방법은 무엇입니까?

Go HTTP 핸들러 전체에서 MySQL 연결을 공유하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-11-12 21:42:021038검색

How to Share a MySQL Connection Across Go HTTP Handlers?

Go HTTP 핸들러에서 MySQL 연결 공유

Go에서는 데이터베이스 연결 관리가 데이터베이스/sql 패키지를 사용하여 원활하게 이루어집니다. 이 가이드는 MySQL 연결을 설정하고 이를 HTTP 핸들러 간에 공유하는 방법에 대한 심층적인 개요를 제공합니다.

연결 설정

main() 함수는 데이터베이스 연결 초기화를 담당합니다. . 여기서는 단일 연결이 아닌 연결 풀 핸들을 반환하는 sql.Open()을 호출합니다. 이 핸들은 필요에 따라 연결을 제공하기 위한 논리를 캡슐화하여 효율적인 리소스 활용을 보장합니다.

db, err := sql.Open("mysql", "root:@/mydb?charset=utf8")

구성 및 핑

연결 풀이 설정되면 애플리케이션의 요구 사항에 맞게 구성할 수 있습니다. . 예를 들어 풀에서 최대 유휴 연결 수를 설정할 수 있습니다.

db.SetMaxIdleConns(100)

데이터베이스의 가용성을 확인하려면 계속하기 전에 ping을 수행해야 합니다.

err = db.Ping()

연결 공유

연결 공유의 핵심은 db 변수를 main() 및 HTTP 핸들러 모두에서 액세스할 수 있는 전역 변수로 만드는 데 있습니다. 이렇게 하면 모든 고루틴이 동일한 연결 풀을 활용할 수 있습니다.

var db *sql.DB // global variable to share between main and HTTP handlers

HTTP 핸들러에서 연결 사용

HTTP 핸들러 내에서 공유 연결을 사용하여 데이터베이스와 상호 작용할 수 있습니다. 예를 들어, "hello" 테이블에서 데이터를 검색하려면:

func HomeHandler(w http.ResponseWriter, r *http.Request) {
    var msg string
    err := db.QueryRow("SELECT msg FROM hello WHERE page=?", "home").Scan(&msg)
    if err != nil {
        fmt.Fprintf(w, "Database Error!")
    } else {
        fmt.Fprintf(w, msg)
    }
}

위 내용은 Go HTTP 핸들러 전체에서 MySQL 연결을 공유하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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