File: httpserver.go

package info (click to toggle)
golang-github-rootless-containers-bypass4netns 0.4.2-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 596 kB
  • sloc: sh: 1,936; python: 542; makefile: 33
file content (66 lines) | stat: -rw-r--r-- 1,169 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package main

import (
	"bytes"
	"flag"
	"fmt"
	"io"
	"log"
	"net/http"
)

var (
	url  = flag.String("url", "http://localhost/blk-1m", "")
	mode = flag.String("mode", "server", "")
)

func main() {
	flag.Parse()

	// disable connection pool
	http.DefaultTransport.(*http.Transport).MaxIdleConnsPerHost = -1

	if *mode == "server" {
		fmt.Println("starting server")
		server()
	} else if *mode == "client" {
		err := client(*url)
		if err != nil {
			log.Fatal(err)
		}
	}
}

func server() {
	http.HandleFunc("/ping", func(w http.ResponseWriter, r *http.Request) {
		fmt.Fprintf(w, "pong")
	})

	log.Fatal(http.ListenAndServe(":8080", nil))
}

func client(url string) error {
	resp, err := http.Get(url)
	if err != nil {
		return fmt.Errorf("failed Do err=%q", err)
	}

	if resp.StatusCode != 200 {
		return fmt.Errorf("unexpected status code %d", resp.StatusCode)
	} else {
		var buffer bytes.Buffer

		_, err = io.Copy(&buffer, resp.Body)
		if err != nil {
			return fmt.Errorf("failed Copy() err=%q", err)
		}

		fmt.Printf("resp=%s\n", buffer.String())
	}
	err = resp.Body.Close()
	if err != nil {
		return fmt.Errorf("failed Close() err=%q", err)
	}

	return nil
}