golang 프로세스 종료 db
Golang이 널리 적용됨에 따라 점점 더 많은 애플리케이션이 Golang을 사용하여 데이터베이스 작업을 포함한 데이터 처리를 시작하고 있습니다. 그렇다면 Golang 코드를 작성할 때 데이터베이스 연결 및 종료를 어떻게 잘 처리합니까?
Golang에서는 표준 라이브러리의 데이터베이스/sql 패키지를 사용하여 기본 기능을 제공하는 데이터베이스 작업을 수행할 수 있습니다. 일반적인 상황에서 우리 코드에는 데이터베이스 연결 열기, 사용 및 닫기가 포함됩니다. 제대로 처리되지 않으면 이러한 연결은 전체 프로세스가 종료될 때까지 활성 상태로 유지되므로 특정 리소스 낭비가 발생하고 심지어 데이터베이스 연결 풀이 가득 차서 예기치 않은 오류가 발생합니다. 그렇다면 데이터베이스 연결을 어떻게 잘 닫을 수 있을까요?
연결을 여는 코드 블록에서 defer 키워드를 사용하면 함수가 반환되기 전에 데이터베이스 연결 닫기 메서드가 호출되도록 할 수 있습니다.
func dbOperations() error {
db, err := sql.Open("mysql", "user:password@tcp(host:port)/dbname") if err != nil { return err } defer db.Close() // 进行数据库操作 ... return nil
}
defer 키워드를 사용하면 함수가 반환되기 전에 데이터베이스 연결을 닫을 수 있으므로 프로그램이 종료되기 전에 연결이 제때에 닫힙니다. defer 키워드를 사용하지 않으면 defer db.Close()를 명시적으로 호출해야 합니다. 그렇지 않으면 연결을 닫는 것을 잊어버리게 됩니다. 따라서 데이터베이스 연결을 사용하는 코드에서는 가능하면 defer 키워드를 사용하여 연결 닫기를 관리하세요.
연결 풀에서 연결을 얻을 때마다 연결 풀은 연결 풀에서 사용 가능한 연결을 찾습니다. 사용 가능한 연결이 없으면 새 연결이 생성되어 연결 풀에 추가됩니다. 연결 풀에 너무 많은 연결이 생성되면 연결 풀이 가득 찰 수 있습니다. 연결 풀에서 최대 연결 수와 유휴 연결 수를 설정하면 이러한 상황을 방지할 수 있습니다.
다음은 연결 풀 매개 변수 설정의 예입니다.
db, err := sql.Open("mysql", "user:password@tcp(host:port)/dbname")
if err != nil {
return err
}
db.SetMaxIdleConns(10)
db.SetMaxOpenConns(100)
이 예에서는 SetMaxIdleConns 함수를 사용하여 연결 풀의 유휴 연결 수를 10으로 설정하고 SetMaxOpenConns 함수를 사용하여 연결 풀의 최대 연결 수는 100입니다. 이 예의 작업에서는 연결 풀이 사용될 때마다 새 연결을 생성할 필요가 없으며 연결 풀이 최대 연결 수를 초과하지 않도록 방지합니다.
실제 애플리케이션에서는 데이터베이스 서버가 다운되면 애플리케이션이 이를 제대로 처리하지 못하는 문제에 자주 직면합니다. 이 경우 연결은 항상 대기 상태가 되며 프로그램은 리소스를 낭비하게 됩니다. 이러한 상황을 피하기 위해 연결 시간 초과를 설정할 수 있습니다. 코드 예제는 다음과 같습니다:
db, err := sql.Open("mysql", "user:password@tcp(host:port)/dbname")
if err != nil {
return err
}
db.SetConnMaxLifetime(30 * time.Second)
이 예에서는 연결 수명 주기가 지정된 시간을 초과하는 경우 SetConnMaxLifetime 함수를 통해 데이터베이스 연결에 대한 시간 초과를 설정합니다. , 자동으로 닫힙니다. 연결에 대한 시간 초과를 설정하면 연결이 오랫동안 기다리는 것을 방지하여 리소스 낭비를 피할 수 있습니다.
요약
Golang의 데이터베이스 연결은 귀중한 리소스이므로 올바르게 관리하고 닫아야 합니다. defer 키워드를 사용하고 연결 풀 매개변수를 설정하여 함수가 반환되기 전에 연결이 닫히도록 하고 연결 풀이 채워지는 것을 방지할 수 있습니다. 동시에 연결에 대한 시간 초과를 설정하여 연결이 오랫동안 기다리는 것을 방지할 수 있습니다. 이러한 기술을 통해 우리는 보다 안정적이고 효율적인 데이터베이스 연결 관리 메커니즘을 구축할 수 있습니다.
위 내용은 golang 프로세스 종료 DB의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!