通过middleware机制写日志

4年以前  |  阅读数:167 次  |  编程语言:Golang 
package main

import "net/http"
import "time"
import "fmt"

func runLogging(logs chan string) {
    for log := range logs {
        fmt.Println(log)
    }
}

func wrapLogging(f http.HandlerFunc) http.HandlerFunc {
    logs := make(chan string, 10000)
    go runLogging(logs)
    return func(w http.ResponseWriter, r *http.Request) {
        start := time.Now()
        f(w, r)
        method := r.Method
        path := r.URL.Path
        elapsed := float64(time.Since(start)) / 1000000.0
        logs <- fmt.Sprintf(
            "method=%s path=%s elapsed=%f",
            method, path, elapsed)
    }
}

func hello(w http.ResponseWriter, r *http.Request) {
    w.Header().Set("Content-Type", "text/plain")
    time.Sleep(time.Millisecond * 50)
    fmt.Fprintln(w, "Hello logged world")
}

func main() {
    handler := wrapLogging(hello)
    http.HandleFunc("/", handler)
    http.ListenAndServe(":5000", nil)
}
 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
将二进制数据转为16进制以便显示
获取IMSI
获取IMEI
Java生成UUID
PHP自定义函数获取搜索引擎来源关键字的方法
让你成为最历害的git提交人
在Zeus Web Server中安装PHP语言支持
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Yii2汉字转拼音类的实例代码
Python 2与Python 3版本和编码的对比
php+ajax+json 详解及实例代码
php封装的page分页类完整实例
PHP设计模式之工厂模式与单例模式
php数组合并array_merge()函数使用注意事项
PHP实现简单爬虫的方法
php实现数组中索引关联数据转换成json对象的方法
wget使用技巧