go 11

golang sqlc query log print

golang에서 sqlc를 사용하는데 쿼리를 log에 출력하는 옵션이 없어서 찾아 보니 driver의 hook을 설정해서 쿼리의 실행전과 실행 후에 쿼리를 찍는 소소가 있었다. 그런데 sqlc는 쿼리를 prepared 형식으로 던지기 때문에 parameter와 쿼리가 분리되어서 출력 되는 문제가 있었다. 그래서 gorm의 쿼리를 출력하는 소스를 찾아 보니 logger 폴더에 parameter를 찾아서 찍어 주는 소스가 존재 했다. 두개를 합치면 다음과 같은 소스로 원하는 쿼리를 출력해 볼 수 있다. 1. database driver hook https://github.com/qustavo/sqlhooks GitHub - qustavo/sqlhooks: Attach hooks to any database/..

Dev/Go 2024.03.08

go 1.22 for loop 변경

go 1.22 에서 for loop의 변경 점이 몇 가지 있습니다. for 사용시 for문에서 선언된 변수가 한번만 생성되어서 내부의 goroutine 사용시 마지막 변수가 나오는 문제점이 있었습니다. 이번 1.22에서는 매번 생성되므로 문제가 해결 됩니다. 샘플 코드 package main import ( "fmt" "sync" ) func main() { numbers := []any{1, 2, 3, 4, 5} var wg sync.WaitGroup for _, number := range numbers { wg.Add(1) go func() { defer wg.Done() fmt.Println(number) }() } // // 1.22 이전 버전은 아래의 코드르 형태임 // var number a..

Dev/Go 2024.02.23

dotnet으로 Golang gin 로컬 개발(localhost) 인증서 만들기

Go gin으로 개발중 https를 테스트하는데 인증서가 없어서 문제가 되었다. 로컬 개발이라 도메인도 없는 상황!!! dotnet에 개발 인증서를 만드는 기능이 포함되어 있다.(localhost) 아래의 명령어로 인증서(pem, key) 파일을 만들 수 있다. dotnet dev-certs https -ep ./certificate.crt --trust --format PEM --no-password Go gin TLS 서버 실행 srv.ListenAndServeTLS("./cert/certificate.crt", "./cert/certificate.key") 크롬에서 접속시 안전한 사이트로 표시됨.

Dev/Go 2024.01.11

golang fiber + otel + recover middleware 호출 순서

go로 백앤드를 개발하는데 fiber를 기반으로 개발하고 있습니다. fiber는 middleware라는 파이프라인 구조로 되어 있어서 순서가 중요한 경우가 발생합니다. asp.net core도 동일한 구조로 되어 있어서 아래의 그림과 참조 URL을 보면 이해가 편합니다. https://learn.microsoft.com/ko-kr/aspnet/core/fundamentals/middleware/?view=aspnetcore-7.0 ASP.NET Core 미들웨어 ASP.NET Core 미들웨어 및 요청 파이프라인에 대해 알아봅니다. learn.microsoft.com golang으로 fiber + otel(opentelemetry) middleware + recover middleware 사용시 아래의 ..

Dev/Go 2023.11.10