Skip to content

Commit

Permalink
Add healthz endpoint to HTTP server
Browse files Browse the repository at this point in the history
  • Loading branch information
mostafa committed Oct 24, 2023
1 parent b4074a1 commit 2d71bda
Show file tree
Hide file tree
Showing 2 changed files with 31 additions and 10 deletions.
22 changes: 20 additions & 2 deletions api/http_server.go
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ package api

import (
"context"
"encoding/json"
"io/fs"
"net/http"

Expand All @@ -12,6 +13,10 @@ import (
"google.golang.org/grpc/credentials/insecure"
)

type Healthz struct {
Status string `json:"status"`
}

// StartHTTPAPI starts the HTTP API.
func StartHTTPAPI(options *Options) {
ctx := context.Background()
Expand All @@ -30,8 +35,21 @@ func StartHTTPAPI(options *Options) {

mux := http.NewServeMux()
mux.Handle("/", rmux)
mux.HandleFunc("/health", func(w http.ResponseWriter, r *http.Request) {
w.WriteHeader(http.StatusOK)
mux.HandleFunc("/healthz", func(w http.ResponseWriter, r *http.Request) {

Check failure on line 38 in api/http_server.go

View workflow job for this annotation

GitHub Actions / Test GatewayD

parameter name 'w' is too short for the scope of its usage (varnamelen)
if liveness(options.Servers) {
w.Header().Set("Content-Type", "application/json")
w.WriteHeader(http.StatusOK)
if err := json.NewEncoder(w).Encode(Healthz{Status: "SERVING"}); err != nil {
options.Logger.Err(err).Msg("failed to serve healthcheck")
w.WriteHeader(http.StatusInternalServerError)
}
} else {
w.Header().Set("Content-Type", "application/json")
w.WriteHeader(http.StatusServiceUnavailable)
if err := json.NewEncoder(w).Encode(Healthz{Status: "NOT_SERVING"}); err != nil {
options.Logger.Err(err).Msg("failed to serve healthcheck")
}
}
})

mux.HandleFunc("/version", func(w http.ResponseWriter, r *http.Request) {
Expand Down
19 changes: 11 additions & 8 deletions cmd/run.go
Original file line number Diff line number Diff line change
Expand Up @@ -696,16 +696,19 @@ var runCmd = &cobra.Command{
GRPCNetwork: conf.Global.API.GRPCNetwork,
GRPCAddress: conf.Global.API.GRPCAddress,
HTTPAddress: conf.Global.API.HTTPAddress,
Servers: servers,
}

go api.StartGRPCAPI(&api.API{
Options: &apiOptions,
Config: conf,
PluginRegistry: pluginRegistry,
Pools: pools,
Proxies: proxies,
Servers: servers,
})
go api.StartGRPCAPI(
&api.API{
Options: &apiOptions,
Config: conf,
PluginRegistry: pluginRegistry,
Pools: pools,
Proxies: proxies,
Servers: servers,
},
&api.HealthChecker{Servers: servers})
logger.Info().Str("address", apiOptions.HTTPAddress).Msg("Started the HTTP API")

go api.StartHTTPAPI(&apiOptions)
Expand Down

0 comments on commit 2d71bda

Please sign in to comment.