잠시만 기다려 주세요


 
HOME   |  여기는?   |  바다물때표   |  여러가지 팁 (804)  |  추천 및 재미 (75)  |  자료실 (17)  |  끄적거림 (467)  |  시나리오 (760)  |  드라마 대본 (248)  |  

2019년 10월 15일
일이 어려울까 벌벌 떠는건 시간 낭비다. 그냥 하다보면 다 하게 되어 있다. - 바다아이
 




    golang

golang - golang 파일 로그파일 만들기, 로그 생성, 채널 비동기
이 름 : 바다아이   |   조회수 : 1427         짧은 주소 : https://www.bada-ie.com/su/?51523238584
아래 사용한 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
번 호 카테고리 제 목 이름 조회수
171 golang golang ... 바다아이 317
170 golang golang gopath, goroot .. 바다아이 316
169 golang golang ... Force download file example 바다아이 576
168 golang golang , , cpu, memory, disk 바다아이 928
167 golang golang , ... GOOS, GOARCH 바다아이 693
166 golang golang checkbox ... 바다아이 823
165 golang golang , , http .... 바다아이 866
164 golang golang nil , nil , nil ... 바다아이 906
163 golang 2 golang, go , .... golang .... 바다아이 1193
162 golang golang postgresql, mysql, mariadb ... ` Grave () .. .. 바다아이 981
161 golang golang postgresql mysql, mariadb scan , null .. 바다아이 1045
160 golang golang , iconv 바다아이 1109
159 golang golang quote escape, unquote 바다아이 1105
158 golang golang , http errorLog , , ... 바다아이 1189
157 golang golang interface , 바다아이 1138
156 golang golang struct .... 바다아이 1190
155 golang golang map map , 바다아이 1135
154 golang golang map .... .... 바다아이 1207
153 golang golang slice copy 바다아이 1082
152 golang golang goto 바다아이 1176
151 golang golang slice sort , int, string, float64 바다아이 1214
150 golang URL Parsing, url . parse 바다아이 1229
149 golang golang , interface{} ... 바다아이 1160
148 golang golang interface to string, , , map slice json 바다아이 1132
147 golang golang How to convert JSON string to map and slice, json 바다아이 1176
146 golang golang , file write, Writing Files 바다아이 1303
145 golang golang Insert Line or String to File, , , , , 바다아이 1091
144 golang golang replace 바다아이 1151
143 golang golang split explode , , ... 바다아이 1245
142 golang golang email read parse, , ..... .... 바다아이 1151
| |




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