import{_ as s,o as n,c as a,R as e}from"./chunks/framework.1625126e.js";const A=JSON.parse('{"title":"","description":"","frontmatter":{},"headers":[],"relativePath":"en_US/guide/q3.md","filePath":"en_US/guide/q3.md","lastUpdated":1687756292000}'),o={name:"en_US/guide/q3.md"},l=e(`
Use Nginx or Caddy to reverse proxy gRPC
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name data.example.com; # The domain name where the Agent connects to Dashboard
ssl_certificate /data/letsencrypt/fullchain.pem; # Your domain certificate path
ssl_certificate_key /data/letsencrypt/key.pem; # Your domain's private key path
underscores_in_headers on;
location / {
grpc_read_timeout 300s;
grpc_send_timeout 300s;
grpc_socket_keepalive on;
grpc_pass grpc://grpcservers;
}
}
upstream grpcservers {
server localhost:5555;
keepalive 1024;
}
data.example.com:443 { # The domain name where the Agent connects to Dashboard
reverse_proxy {
to localhost:5555
transport http {
versions h2c 2
}
}
}
Dashboard Configuration
CDN Bypassed Domain/IP
with the domain name you configured in Nginx or Caddy, for example data.example.com
, and save it./opt/nezha/dashboard/data/config.yaml
file in the panel server and change proxygrpcport
to the port that Nginx or Caddy is listening on, such as 443
as set in the previous step. Since we have SSL/TLS enabled in Nginx or Caddy, we need to set tls
to true
, restart the panel when you are done.Agent Configuration
Enable Cloudflare CDN (optional)
According to Cloudflare gRPC requirements: gRPC services must listen on port 443 and must support TLS and HTTP/2. So if you need to enable CDN, you must use port 443 when configuring Nginx or Caddy reverse proxy gRPC and configure the certificate (Caddy will automatically apply and configure the certificate).
Network
page and turn on the gRPC
switch, then go to the DNS
page, find the resolution record of the domain with gRPC configuration, and turn on the orange cloud icon to enable CDN.