Nginx常用配置、反向代理

目录

1. 常用配置

基本设置

HTTP配置

虚拟主机配置

2. 高级配置

反向代理配置

SSL/TLS配置

负载均衡配置

1. 常用配置

基本设置
user nginx;
worker_processes auto;
error_log /var/log/nginx/error.log warn;
pid /var/run/nginx.pid;
  • user nginx;: 指定Nginx worker进程的运行用户。
  • worker_processes auto;: 自动设置worker进程的数量。
  • error_log /var/log/nginx/error.log warn;: 错误日志的路径和日志级别。
  • pid /var/run/nginx.pid;: Nginx主进程的PID文件路径。

HTTP配置
http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    tcp_nopush      on;
    tcp_nodelay     on;
    keepalive_timeout  65;
    types_hash_max_size 2048;

    include /etc/nginx/conf.d/*.conf;
    include /etc/nginx/sites-enabled/*;
}
  • include /etc/nginx/mime.types;: 引入MIME类型定义文件。
  • default_type application/octet-stream;: 默认的MIME类型。
  • log_format main ...: 定义日志格式。
  • access_log /var/log/nginx/access.log main;: 访问日志的文件路径。
  • sendfile on;: 开启sendfile功能。
  • tcp_nopush on; tcp_nodelay on;: 优化TCP传输。
  • keepalive_timeout 65;: 客户端与服务器之间的持久连接超时时间。
  • types_hash_max_size 2048;: MIME类型哈希表的最大大小。

虚拟主机配置
server {
    listen 80;
    server_name example.com;

    location / {
        root /var/www/example.com;
        index index.html index.htm;
    }

    error_page 500 502 503 504 /50x.html;
    location = /50x.html {
        root /usr/share/nginx/html;
    }
}
  • server { ... }: 定义一个虚拟主机配置块。
  • listen 80;: 监听80端口。
  • server_name example.com;: 定义服务器的域名。
  • location / { ... }: 处理根路径请求。
  • error_page ...: 定义错误页面处理方式。

2. 高级配置

反向代理配置
server {
    listen 80;
    server_name backend.example.com;

    location / {
        proxy_pass http://backend_servers;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    }
}

upstream backend_servers {
    server backend1.example.com;
    server backend2.example.com;
}
  • server { ... }: 定义反向代理的虚拟主机配置。
  • listen 80;: 监听80端口。
  • server_name backend.example.com;: 定义服务器的域名。
  • location / { ... }: 配置反向代理。
  • proxy_pass http://backend_servers;: 将请求代理到后端服务器组。
  • upstream backend_servers { ... }: 定义后端服务器组。
SSL/TLS配置
server {
    listen 443 ssl;
    server_name secure.example.com;

    ssl_certificate /etc/nginx/ssl/secure.example.com.crt;
    ssl_certificate_key /etc/nginx/ssl/secure.example.com.key;

    location / {
        root /var/www/secure.example.com;
        index index.html index.htm;
    }
}
  • server { ... }: 定义HTTPS的虚拟主机配置。
  • listen 443 ssl;: 监听443端口并启用SSL。
  • ssl_certificate ...; ssl_certificate_key ...;: 指定SSL证书和私钥的路径。
负载均衡配置
upstream backend_servers {
    server backend1.example.com;
    server backend2.example.com;
    server backend3.example.com;
}

server {
    listen 80;
    server_name loadbalanced.example.com;

    location / {
        proxy_pass http://backend_servers;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
    }
}
  • upstream backend_servers { ... }: 定义负载均衡的后端服务器组。
  • proxy_pass http://backend_servers;: 将请求代理到后端服务器组。
  • 16
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: Nginx可以使用反向代理功能来将用户请求转发到后端服务器,从而实现负载均衡、安全限制和其他功能。为了实现反向代理,必须设置Nginx中的proxy_pass参数,以及location块中的proxy_redirect参数。 ### 回答2: Nginx是一个高性能的开源Web服务器软件,除了提供常见的Web服务器功能外,还可以用作反向代理服务器。反向代理是指服务器代替客户端向其他服务器发送请求,并将响应返回给客户端。Nginx作为反向代理服务器,可以通过以下步骤进行配置: 1. 在Nginx配置文件中,添加一个新的server块来定义反向代理配置。可以使用server_name指令指定代理的域名或IP地址。 2. 在代理配置中,使用proxy_pass指令指定要代理的后端服务器的地址。可以是域名、IP地址或Unix域套接字。 3. 配置代理服务器的端口号,使用proxy_set_header指令设置HTTP请求头字段,例如Host、Referer等。 4. 如果后端服务器需要访问客户端的真实IP地址,可以使用proxy_set_header指令设置X-Real-IP和X-Forwarded-For字段来传递真实IP地址。 5. 配置其他代理相关的指令,例如proxy_buffering、proxy_connect_timeout、proxy_read_timeout等,以优化代理服务器的性能和安全性。 6. 保存Nginx配置文件,并重新加载Nginx服务器以使配置生效。 通过上述配置Nginx就可以作为反向代理服务器来转发客户端的请求到后端服务器,并将后端服务器的响应返回给客户端。反向代理可以用于负载均衡、缓存加速、请求过滤以及增加安全性等方面的应用。由于Nginx具有高性能和高可靠性的特点,因此它经常被用作反向代理服务器的首选工具。 ### 回答3: Nginx可以通过配置反向代理来起到负载均衡和提高网站性能的作用。反向代理是指将客户端的请求转发到后端服务器,并将后端服务器的响应返回给客户端。 要配置Nginx作为反向代理,首先需要安装并启动Nginx服务器。接下来,通过编辑Nginx配置文件来指定反向代理的规则。 在配置文件中,可以使用`server`块来定义需要反向代理的后端服务器。例如: ``` server { listen 80; server_name example.com; location / { proxy_pass http://backend_server; } } ``` 在上述示例中,`listen`指令指定了Nginx监听的端口号,`server_name`指令指定了要代理的域名。`location`块用于指定反向代理的规则,其中`proxy_pass`指令将请求转发给`http://backend_server`。 在这个例子中,`http://backend_server`是一个后端服务器的地址,可以是IP地址或域名。当有客户端请求到达Nginx时,Nginx会将请求转发给指定的后端服务器,并将后端服务器的响应返回给客户端。 此外,还可以通过配置Nginx的负载均衡算法来分发请求给多个后端服务器,实现负载均衡的效果。常用的负载均衡算法有轮询、IP哈希、最少连接数等。通过在`location`块中设置`proxy_pass`指令的后端服务器地址,可以轻松配置负载均衡。 在完成配置后,保存配置文件并重新加载Nginx配置。即可使Nginx作为反向代理开始工作,将客户端的请求转发给后端服务器,并将后端服务器的响应返回给客户端,起到负载均衡和提高网站性能的作用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

断墨先生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值