
Errors from staticcheck: test/images/agnhost/dns/common.go:79:6: func runCommand is unused (U1000) test/images/agnhost/inclusterclient/main.go:75:16: using time.Tick leaks the underlying ticker, consider using it only in endless functions, tests and the main package, and use time.NewTicker here (SA1015) test/images/agnhost/net/nat/closewait.go:41:5: var leakedConnection is unused (U1000) test/images/agnhost/netexec/netexec.go:157:17: printf-style function with dynamic format string and no further arguments should use print-style function instead (SA1006) test/images/agnhost/netexec/netexec.go:250:18: printf-style function with dynamic format string and no further arguments should use print-style function instead (SA1006) test/images/agnhost/netexec/netexec.go:317:18: printf-style function with dynamic format string and no further arguments should use print-style function instead (SA1006) test/images/agnhost/netexec/netexec.go:331:19: printf-style function with dynamic format string and no further arguments should use print-style function instead (SA1006) test/images/agnhost/netexec/netexec.go:345:19: printf-style function with dynamic format string and no further arguments should use print-style function instead (SA1006) test/images/agnhost/netexec/netexec.go:357:19: printf-style function with dynamic format string and no further arguments should use print-style function instead (SA1006) test/images/agnhost/netexec/netexec.go:370:19: printf-style function with dynamic format string and no further arguments should use print-style function instead (SA1006) test/images/agnhost/netexec/netexec.go:380:9: this value of err is never used (SA4006) test/images/agnhost/netexec/netexec.go:381:17: printf-style function with dynamic format string and no further arguments should use print-style function instead (SA1006) test/images/agnhost/netexec/netexec.go:386:17: printf-style function with dynamic format string and no further arguments should use print-style function instead (SA1006) test/images/agnhost/pause/pause.go:43:23: syscall.SIGKILL cannot be trapped (did you mean syscall.SIGTERM?) (SA1016) test/images/agnhost/serve-hostname/serve_hostname.go:125:15: the channel used with signal.Notify should be buffered (SA1017) test/images/agnhost/webhook/patch_test.go:131:13: this value of err is never used (SA4006) test/images/pets/peer-finder/peer-finder.go:155:6: this value of newPeers is never used (SA4006)
131 lines
3.4 KiB
Go
131 lines
3.4 KiB
Go
/*
|
|
Copyright 2014 The Kubernetes Authors.
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
you may not use this file except in compliance with the License.
|
|
You may obtain a copy of the License at
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
See the License for the specific language governing permissions and
|
|
limitations under the License.
|
|
*/
|
|
|
|
// A small utility to just serve the hostname on TCP and/or UDP.
|
|
|
|
package servehostname
|
|
|
|
import (
|
|
"fmt"
|
|
"log"
|
|
"net"
|
|
"net/http"
|
|
"os"
|
|
"os/signal"
|
|
"syscall"
|
|
"time"
|
|
|
|
"github.com/spf13/cobra"
|
|
)
|
|
|
|
// CmdServeHostname is used by agnhost Cobra.
|
|
var CmdServeHostname = &cobra.Command{
|
|
Use: "serve-hostname",
|
|
Short: "Serves the hostname",
|
|
Long: `Serves the hostname through HTTP / TCP / UDP on the given port.`,
|
|
Args: cobra.MaximumNArgs(0),
|
|
Run: main,
|
|
}
|
|
|
|
var (
|
|
doTCP bool
|
|
doUDP bool
|
|
doHTTP bool
|
|
doClose bool
|
|
port int
|
|
)
|
|
|
|
func init() {
|
|
CmdServeHostname.Flags().BoolVar(&doTCP, "tcp", false, "Serve raw over TCP.")
|
|
CmdServeHostname.Flags().BoolVar(&doUDP, "udp", false, "Serve raw over UDP.")
|
|
CmdServeHostname.Flags().BoolVar(&doHTTP, "http", true, "Serve HTTP.")
|
|
CmdServeHostname.Flags().BoolVar(&doClose, "close", false, "Close connection per each HTTP request.")
|
|
CmdServeHostname.Flags().IntVar(&port, "port", 9376, "Port number.")
|
|
}
|
|
|
|
func main(cmd *cobra.Command, args []string) {
|
|
if doHTTP && (doTCP || doUDP) {
|
|
log.Fatalf("Can't server TCP/UDP mode and HTTP mode at the same time")
|
|
}
|
|
|
|
hostname, err := os.Hostname()
|
|
if err != nil {
|
|
log.Fatalf("Error from os.Hostname(): %s", err)
|
|
}
|
|
|
|
if doTCP {
|
|
listener, err := net.Listen("tcp", fmt.Sprintf(":%d", port))
|
|
if err != nil {
|
|
log.Fatalf("Error from net.Listen(): %s", err)
|
|
}
|
|
go func() {
|
|
for {
|
|
conn, err := listener.Accept()
|
|
if err != nil {
|
|
log.Fatalf("Error from Accept(): %s", err)
|
|
}
|
|
log.Printf("TCP request from %s", conn.RemoteAddr().String())
|
|
conn.Write([]byte(hostname))
|
|
conn.Close()
|
|
}
|
|
}()
|
|
}
|
|
if doUDP {
|
|
addr, err := net.ResolveUDPAddr("udp", fmt.Sprintf(":%d", port))
|
|
if err != nil {
|
|
log.Fatalf("Error from net.ResolveUDPAddr(): %s", err)
|
|
}
|
|
sock, err := net.ListenUDP("udp", addr)
|
|
if err != nil {
|
|
log.Fatalf("Error from ListenUDP(): %s", err)
|
|
}
|
|
go func() {
|
|
var buffer [16]byte
|
|
for {
|
|
_, cliAddr, err := sock.ReadFrom(buffer[0:])
|
|
if err != nil {
|
|
log.Fatalf("Error from ReadFrom(): %s", err)
|
|
}
|
|
log.Printf("UDP request from %s", cliAddr.String())
|
|
sock.WriteTo([]byte(hostname), cliAddr)
|
|
}
|
|
}()
|
|
}
|
|
if doHTTP {
|
|
http.HandleFunc("/", func(w http.ResponseWriter, r *http.Request) {
|
|
log.Printf("HTTP request from %s", r.RemoteAddr)
|
|
|
|
if doClose {
|
|
// Add this header to force to close the connection after serving the request.
|
|
w.Header().Add("Connection", "close")
|
|
}
|
|
|
|
fmt.Fprintf(w, "%s", hostname)
|
|
})
|
|
go func() {
|
|
// Run in a closure so http.ListenAndServe doesn't block
|
|
log.Fatal(http.ListenAndServe(fmt.Sprintf(":%d", port), nil))
|
|
}()
|
|
}
|
|
log.Printf("Serving on port %d.\n", port)
|
|
signals := make(chan os.Signal, 1)
|
|
signal.Notify(signals, syscall.SIGTERM)
|
|
sig := <-signals
|
|
log.Printf("Shutting down after receiving signal: %s.\n", sig)
|
|
log.Printf("Awaiting pod deletion.\n")
|
|
time.Sleep(60 * time.Second)
|
|
}
|