Dev 52

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

Kibana server is not ready yet.

kibana 설정 후 "Kibana server is not ready yet." 계속 나오는 현상이 있었다. 여러 원인이 있겠지만 나의 경우 kibana.yml에 elasticsearch.hosts는 설정 했지만 username, password를 설정 하지 않아서 계속 문제가 발생되었다. elasticsearch.hosts: ['http://es2:9200'] 다음과 같이 username, passowrd 를 더 설정해 주거나 아예 다 설정 하지 않으면 config UI가 나온다. elasticsearch.hosts: ['http://es2:9200'] elasticsearch.username: kibana_system elasticsearch.password: password

Dev/elasticsearch 2024.02.08

elasticsearch 8.x build-in user password change

es의 8.x 부터는 elasticsearch-setup-passwords 는 사용하지 말라고 나온다. 그리고 RPM 또는 dnf로 es를 설치 하면 elasticsearch-setup-passwords을 실행 할 수가 없다.(이건 처음 한번만 사용 가능) 그래서 계정의 패스워드를 변경하려면 elasticsearch-reset-password 를 사용해야 한다. # 자동 패스워드 생성 ./elasticsearch-reset-password -u apm_system ./elasticsearch-reset-password -u kibana_system ./elasticsearch-reset-password -u kibana ./elasticsearch-reset-password -u logstash_syst..

Dev/elasticsearch 2024.01.31

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 cross-compile windows, mac(darwin), linux

go에서 빌드를 하는 경우 바이너리 실행파일을 생성합니다. 그런데 바이너리 실행파일은 OS(windows, mac, linux)별 아키텍쳐(x86, x64, arm64)별로 다른 구조 및 라이브러리 참조가 다르기 때문에 빌드시에 어떤 타켓으로 빌드 할 지 결정이 필요합니다. go build 시에는 go env에 저장된 환경변수 파일에 따른 정보로 빌드가 됩니다. GOARCH='arm64' GOHOSTARCH='arm64' GOHOSTOS='darwin' GOOS='darwin' 1. Windows 바이너리 컴파일 # Windows x64 빌드 GOOS=windows GOARCH=amd64 go build # Windows x86 빌드 GOOS=windows GOARCH=386 go build 2. Mac..

Dev/Go 2023.12.18

go - package

go의 모든 파일은 package로 시작해야 합니다. package main package handler package에 입력되는 이름은 main을 제외하고는 모두 파일을 포함하는 디렉토리명을 사용합니다. 이런 구조라면 error_handler, login_handler 등의 같은 디렉토리에 포함되는 파일은 모두 package handler로 시작합니다. package handler package main은 특별한 package로 프로그램의 시작시점인 func main을 포함 할 수 있습니다. package main또한 여러개의 파일이 존재할 수 있으나 같은 패키지에는 같은 이름의 함수가 한 개만 존재해야 하므로 main 함수는 하나만 선언 할 수 있습니다.

Dev/Go 2023.11.24

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