Pular para o conteúdo

Load Balancing

Esta receita demonstra como usar Nginx como um servidor reverse proxy para fazer load balance de tráfego entre vários servidores Echo.

package main
import (
"context"
"fmt"
"net/http"
"os"
"github.com/labstack/echo/v5"
"github.com/labstack/echo/v5/middleware"
)
var index = `
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Upstream Server</title>
<style>
h1, p {
font-weight: 300;
}
</style>
</head>
<body>
<p>
Hello from upstream server %s
</p>
</body>
</html>
`
func main() {
name := os.Args[1]
port := os.Args[2]
e := echo.New()
e.Use(middleware.Recover())
e.Use(middleware.RequestLogger())
e.GET("/", func(c *echo.Context) error {
return c.HTML(http.StatusOK, fmt.Sprintf(index, name))
})
sc := echo.StartConfig{Address: port}
if err := sc.Start(context.Background(), e); err != nil {
e.Logger.Error("failed to start server", "error", err)
}
}
Terminal window
cd upstream
go run server.go server1 :8081
go run server.go server2 :8082

Veja o guia de instalação do Nginx.

Crie um arquivo /etc/nginx/sites-enabled/localhost com o seguinte conteúdo:

upstream localhost {
server localhost:8081;
server localhost:8082;
}
server {
listen 8080;
server_name localhost;
access_log /var/log/nginx/localhost.access.log combined;
location / {
proxy_pass http://localhost;
}
}
Terminal window
service nginx restart

Acesse https://localhost:8080, e você deverá ver uma página servida a partir de “server 1” ou “server 2”.

Terminal window
Hello from upstream server server1