写点什么

云原生 - 模块二 -httpserver

作者:hunk
  • 2022 年 1 月 09 日
  • 本文字数:1223 字

    阅读完需:约 4 分钟

编写一个 HTTP 服务器,大家视个人不同情况决定完成到哪个环节,但尽量把 1 都做完:

  1. 接收客户端 request,并将 request 中带的 header 写入 response header

  2. 读取当前系统的环境变量中的 VERSION 配置,并写入 response header

  3. Server 端记录访问日志包括客户端 IP,HTTP 返回码,输出到 server 端的标准输出

  4. 当访问 localhost/healthz 时,应返回 200

package main
import ( "fmt" "log" "net" "net/http" "net/http/pprof" "os" "strings")
func index(w http.ResponseWriter, r *http.Request) { w.Write([]byte("<h1>Welcome to Cloud Native</h1>")) // 03.设置version os.Setenv("VERSION", "v1.0.1") version := os.Getenv("VERSION") w.Header().Set("VERSION", version) fmt.Printf("os version: %s \n", version) // 02.将requst中的header 设置到 reponse中 for k, v := range r.Header { for _, vv := range v { fmt.Printf("Header key: %s, Header value: %s \n", k, v) w.Header().Set(k, vv) } } // 04.记录日志并输出 clientip := getCurrentIP(r) //fmt.Println(r.RemoteAddr) log.Printf("Success! Response code: %d", 200) log.Printf("Success! clientip: %s", clientip)}
// 05.健康检查的路由func healthz(w http.ResponseWriter, r *http.Request) { fmt.Fprintf(w, "working")}
func getCurrentIP(r *http.Request) string { // 这里也可以通过X-Forwarded-For请求头的第一个值作为用户的ip // 但是要注意的是这两个请求头代表的ip都有可能是伪造的 ip := r.Header.Get("X-Real-IP") if ip == "" { // 当请求头不存在即不存在代理时直接获取ip ip = strings.Split(r.RemoteAddr, ":")[0] } return ip}
// ClientIP 尽最大努力实现获取客户端 IP 的算法。// 解析 X-Real-IP 和 X-Forwarded-For 以便于反向代理(nginx 或 haproxy)可以正常工作。func ClientIP(r *http.Request) string { xForwardedFor := r.Header.Get("X-Forwarded-For") ip := strings.TrimSpace(strings.Split(xForwardedFor, ",")[0]) if ip != "" { return ip } ip = strings.TrimSpace(r.Header.Get("X-Real-Ip")) if ip != "" { return ip } if ip, _, err := net.SplitHostPort(strings.TrimSpace(r.RemoteAddr)); err == nil { return ip } return ""}
func main() { mux := http.NewServeMux() // 06. debug mux.HandleFunc("/debug/pprof/", pprof.Index) mux.HandleFunc("/debug/pprof/profile", pprof.Profile) mux.HandleFunc("/debug/pprof/symbol", pprof.Symbol) mux.HandleFunc("/debug/pprof/trace", pprof.Trace) mux.HandleFunc("/", index) mux.HandleFunc("/healthz", healthz) if err := http.ListenAndServe("localhost:8080", mux); err != nil { log.Fatalf("start http server failed, error: %s\n", err.Error()) }}
复制代码


发布于: 刚刚阅读数: 2
用户头像

hunk

关注

还未添加个人签名 2019.01.23 加入

还未添加个人简介

评论

发布
暂无评论
云原生-模块二-httpserver