잠시만 기다려 주세요

     '월급 200 받는 사람이 국회의원 되는 그날까지... 슈퍼기득권 전부 아웃... 국회의원 봉사직 전환을 꿈꾸며... '
전체검색 :  
이번주 로또 및 연금번호 발생!!   |  HOME   |  여기는?   |  바다물때표   |  알림 (19)  |  여러가지 팁 (1095)  |  추천 및 재미 (163)  |  자료실 (28)  |  
시사, 이슈, 칼럼, 평론, 비평 (790)  |  끄적거림 (142)  |  문예 창작 (719)  |  바람 따라 (75)  |  시나리오 (760)  |  드라마 대본 (248)  |  
살인!


    golang

golang - golang 파일 로그파일 만들기, 로그 생성, 채널 비동기
이 름 : 바다아이   |   조회수 : 10148         짧은 주소 : https://www.bada-ie.com/su/?961591918601
아래 사용한 OpenFile 옵션은 여기 게시판에서 "open" 으로 검색해 보시면 옵션들은 있습니다.
혹은 https://golang.org/pkg/os/#pkg-variables 부분 보시면 자세히 나와 있습니다.
확인하시고 용도에 맞게 알아서 변경하시고요...

복잡하게 해 놨는데 일부러 여러코드 보시라고 이것저것 몇개 써 놨습니다.
go 루틴으로 숫자 로그 남기는 부분이고 그걸 bufio 패키지를 사용해서
일정 크기 이상되면 쓰고 프로그램 끝날 때는 남은 것 전부 flush 해서 기록합니다.
요청시마다 매번 파일 쓰기 하면 부담되니까 잘라서 쓰는 것입니다.

실행 후 로그파일 보시고 ctrl + c 하셔서 프로그램 종료 후 확인해 보세요...
나눠서 로그 남겨지는 거 확인하실 수 있습니다.



package main

import (
    "bufio"
    "log"
    "os"
    "os/signal"
    "strconv"
    "time"
)

/* 비동기 로깅 */
var logChannel chan string
var bufferedAccessLogWriter *bufio.Writer

func logSetup(logFile string) {

    // 로그 파일이 없으면, 생성한다, 요건 사실 없어도 되요.. 아래에서 없으면 자동으로 만들어요...
    // 참고나 하시라고 써 놓습니다.
    if _, err := os.Stat(logFile); os.IsNotExist(err) {
        f, _ := os.Create(logFile)
        f.Close()
    }

    // 로그 채널을 만든다
    logChannel = make(chan string)

    // 채널을 통한 비동기 로깅
    go func() {

        f, _ := os.OpenFile(logFile, os.O_RDWR|os.O_APPEND|os.O_CREATE, 0666)
        defer f.Close()

        bufferedAccessLogWriter = bufio.NewWriter(f)

        // 채널이 닫힐 때까지 메시지 받으면 로깅
        for msg := range logChannel {

            bufferedAccessLogWriter.WriteString(time.Now().String() + " " + msg + "\n")
        }
    }()
}

/* 테스트 코드 */
func main() {
    logSetup("./logfile.txt")

    go func() {
        for i := 1; i < 200; i++ {
            n := strconv.Itoa(i)
            logChannel <- n
        }
    }()

    go func() {
        for i := 100; i < 1200; i++ {
            logChannel <- strconv.Itoa(i)
        }
    }()

    c := make(chan os.Signal, 1)
    signal.Notify(c, os.Interrupt)

    <-c
    log.Println("프로그램을 끝내셨네요..")
    close(logChannel)
    bufferedAccessLogWriter.Flush()
    os.Exit(0)
}


참고 : http://golang.site/go/article/210-채널을-이용한-비동기-로깅
| |





      1 page / 6 page
번 호 카테고리 제 목 이름 조회수
180 golang golang ... 바다아이 114
179 golang golang , ... 바다아이 2691
178 golang golang , map . 바다아이 2080
177 golang Golang (, , data ) , ... 바다아이 2393
176 golang golang sort ... 바다아이 2777
175 golang golang html.EscapeString html.UnescapeString input value ... 바다아이 2701
174 golang golang go.mod go.sum . GOPATH SRC not module, 1.16 . 바다아이 6218
173 golang go 1.16 ... is not in GOROOT.. GOPATH .... . 바다아이 7373
172 golang , String Formatting 바다아이 8691
171 golang rand.Intn , random, , . 바다아이 8214
170 golang golang ... 바다아이 11961
169 golang golang gopath, goroot .. golang 바다아이 8943
168 golang golang ... Force download file example 바다아이 10962
167 golang golang , , cpu, memory, disk 바다아이 12029
166 golang golang , ... GOOS, GOARCH 바다아이 9687
165 golang golang checkbox ... 바다아이 9543
164 golang golang , , http .... 바다아이 9368
163 golang golang nil , nil , nil ... 바다아이 9449
162 golang 2 golang, go , .... golang .... 바다아이 12691
161 golang golang postgresql, mysql, mariadb ... ` Grave () .. .. 바다아이 10003
160 golang golang postgresql mysql, mariadb scan , null .. 바다아이 10060
159 golang golang , iconv 바다아이 12879
158 golang golang quote escape, unquote 바다아이 10306
157 golang golang , http errorLog , , ... 바다아이 10691
156 golang golang interface , 바다아이 9767
155 golang golang struct .... 바다아이 10490
154 golang golang map map , 바다아이 9975
153 golang golang map .... .... 바다아이 9299
152 golang golang slice copy 바다아이 9489
151 golang golang goto 바다아이 10683
| |









Copyright ⓒ 2001.12. bada-ie.com. All rights reserved.
이 사이트는 리눅스에서 firefox 기준으로 작성되었습니다. 기타 브라우저에서는 다르게 보일 수 있습니다.
[ Ubuntu + GoLang + PostgreSQL + Mariadb ]
서버위치 : 오라클 클라우드 춘천  실행시간 : 0.29657
to webmaster... gogo sea. gogo sea.