잠시만 기다려 주세요


 
HOME   |  여기는?   |  바다물때표   |  여러가지 팁 (781)  |  추천 및 재미 (53)  |  자료실 (18)  |  끄적거림 (456)  |  시나리오 (757)  |  드라마 대본 (248)  |  

2019년 07월 20일
남의 것 빼앗으려 말고 남 등쳐 먹을 생각 말아라. 남이 조금 잘 되면 어떻게 해서든 한다리 걸쳐 간이라도 빼먹으려는 사람들을 우린 인간 쓰레기라고 부른다. 질투하지도 말아라. 스스로 노력과 고통으로 얻은 것만이 진실이며 오래간다. - 바다아이
 

    golang

golang - golang 파일 로그파일 만들기, 로그 생성, 채널 비동기
이 름 : 바다아이   |   조회수 : 1158         짧은 주소 : 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 ... 바다아이 9
170 golang golang gopath, goroot .. 바다아이 69
169 golang golang ... Force download file example 바다아이 302
168 golang golang , , cpu, memory, disk 바다아이 617
167 golang golang , ... GOOS, GOARCH 바다아이 442
166 golang golang checkbox ... 바다아이 529
165 golang golang , , http .... 바다아이 579
164 golang golang nil , nil , nil ... 바다아이 608
163 golang 2 golang, go , .... golang .... 바다아이 827
162 golang golang postgresql, mysql, mariadb ... ` Grave () .. .. 바다아이 686
161 golang golang postgresql mysql, mariadb scan , null .. 바다아이 739
160 golang golang , iconv 바다아이 800
159 golang golang quote escape, unquote 바다아이 787
158 golang golang , http errorLog , , ... 바다아이 877
157 golang golang interface , 바다아이 840
156 golang golang struct .... 바다아이 870
155 golang golang map map , 바다아이 831
154 golang golang map .... .... 바다아이 903
153 golang golang slice copy 바다아이 808
152 golang golang goto 바다아이 873
151 golang golang slice sort , int, string, float64 바다아이 926
150 golang URL Parsing, url . parse 바다아이 922
149 golang golang , interface{} ... 바다아이 877
148 golang golang interface to string, , , map slice json 바다아이 848
147 golang golang How to convert JSON string to map and slice, json 바다아이 837
146 golang golang , file write, Writing Files 바다아이 993
145 golang golang Insert Line or String to File, , , , , 바다아이 806
144 golang golang replace 바다아이 857
143 golang golang split explode , , ... 바다아이 921
142 golang golang email read parse, , ..... .... 바다아이 868
| |






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