写点什么

云原生训练营 -Week02

作者:jjn0703
  • 2022 年 2 月 27 日
  • 本文字数:758 字

    阅读完需:约 2 分钟

编写一个 HTTP 服务器:

  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/http" "os")
func ReadUserIP(r *http.Request) string { IpAddress := r.Header.Get("X-Real-Ip") if IpAddress == "" { IpAddress = r.Header.Get("X-Forwarded-For") } if IpAddress == "" { IpAddress = r.RemoteAddr } return IpAddress}
func health(w http.ResponseWriter, r *http.Request) { w.Write([]byte("working"))}
func analyseHeader(w http.ResponseWriter, r *http.Request) { w.Write([]byte("Hello, this is server")) err := os.Setenv("VERSION", "V1.0.0") if err != nil { log.Fatalf("Setting env VERSION failed") } version := os.Getenv("VERSION") w.Header().Set("VERSION", version) fmt.Printf("os version: %s \n", version) // 将request中的header依次copy到response中 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) } } fmt.Println(r.RemoteAddr) fmt.Printf("Ip is: %s\n", ReadUserIP(r)) log.Printf("Success! Response code: %d", 200)}
func main() { serveMux := http.NewServeMux() serveMux.HandleFunc("/", analyseHeader) serveMux.HandleFunc("/healthz", health) err := http.ListenAndServe(":8080", serveMux) if err == nil { log.Fatalf("Starting server failed on port 8080 failed") }}
复制代码


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

jjn0703

关注

Java工程师/终身学习者 2018.03.26 加入

USTC硕士/健身健美爱好者/Java工程师.

评论

发布
暂无评论
云原生训练营-Week02