잠시만 기다려 주세요

     '검찰공화국, 부패공화국... 윤석열은 내려와라... 그리고 수사 받아라... 당신은 대통령을 할 자격이 없다.'
전체검색 :  
이번주 로또 및 연금번호 발생!!   |  HOME   |  여기는?   |  바다물때표   |  알림 (16)  |  여러가지 팁 (1059)  |  추천 및 재미 (156)  |  자료실 (22)  |  
시사, 이슈, 칼럼, 평론, 비평 (613)  |  끄적거림 (136)  |  문예 창작 (716)  |  바람 따라 (75)  |  시나리오 (760)  |  드라마 대본 (248)  |  
살인!


    golang

golang - golang 파일 로그파일 만들기, 로그 생성, 채널 비동기
이 름 : 바다아이   |   조회수 : 9112         짧은 주소 : 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
번 호 카테고리 제 목 이름 조회수
179 golang golang , ... 바다아이 1851
178 golang golang , map . 바다아이 1427
177 golang Golang (, , data ) , ... 바다아이 1509
176 golang golang sort ... 바다아이 1749
175 golang golang html.EscapeString html.UnescapeString input value ... 바다아이 1842
174 golang golang go.mod go.sum . GOPATH SRC not module, 1.16 . 바다아이 5154
173 golang go 1.16 ... is not in GOROOT.. GOPATH .... . 바다아이 6058
172 golang , String Formatting 바다아이 7703
171 golang rand.Intn , random, , . 바다아이 7160
170 golang golang ... 바다아이 10298
169 golang golang gopath, goroot .. golang 바다아이 7809
168 golang golang ... Force download file example 바다아이 9623
167 golang golang , , cpu, memory, disk 바다아이 10891
166 golang golang , ... GOOS, GOARCH 바다아이 8641
165 golang golang checkbox ... 바다아이 8402
164 golang golang , , http .... 바다아이 8175
163 golang golang nil , nil , nil ... 바다아이 8513
162 golang 2 golang, go , .... golang .... 바다아이 11410
161 golang golang postgresql, mysql, mariadb ... ` Grave () .. .. 바다아이 8722
160 golang golang postgresql mysql, mariadb scan , null .. 바다아이 8857
159 golang golang , iconv 바다아이 11656
158 golang golang quote escape, unquote 바다아이 9117
157 golang golang , http errorLog , , ... 바다아이 9192
156 golang golang interface , 바다아이 8614
155 golang golang struct .... 바다아이 9355
154 golang golang map map , 바다아이 8828
153 golang golang map .... .... 바다아이 8347
152 golang golang slice copy 바다아이 8474
151 golang golang goto 바다아이 9359
150 golang golang slice sort , int, string, float64 바다아이 8838
| |









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