Nginx配置web服务器及部署反向代理

Nginx配置web服务器及部署反向代理

配置web服务器

项目部署到linux上的静态文件代理给Nginx处理。当访问服务器IP时,可以自动返回静态文件主页。

主配置文件中server块对应的次配置include /etc/nginx/conf.d/*.conf,也就是/etc/nginx/conf.d/目录下的配置文件,可以在该目录下新增一个autotpsite.conf配置文件,执行命令:vim /etc/nginx/conf.d/autotpsite.conf

注:主配置文件中server块默认监听端口为80,若次配置文件中server块监听端口与主配置文件中相同,会产生冲突

server {
        listen       8080;
        listen       [::]:8080;
        server_name  _;
        # root         /data/project/autotpsite/dist;

        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        error_page 404 /404.html;
        location = /404.html {
        }

        error_page 500 502 503 504 /50x.html;
        location = /50x.html {
        }       
}

其中server_name下一行中的root /data/project/autotpsite/dist;这里配置的静态文件根目录,就是项目静态文件所在的目录

访问 http://127.0.0.1:8080/index.html 对应的文件目录是/data/project/autotpsite/dist/index.html

但是一般情况下,不这样进行配置,而是放到location块

server {
        listen       8080;
        listen       [::]:8080;
        server_name  _;
        # root         /data/project/autotpsite/dist;

        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        error_page 404 /404.html;
        location = /404.html {
        }

        error_page 500 502 503 504 /50x.html;
        location = /50x.html {
        }
        
        location / {
			root   /data/project/autotpsite/dist;  
    	}      
}
location语法

相对匹配:

location /path/ {
	root   /data/software/static;  
}

文件路径等于 root + location/data/software/static 拼接 /path/,如访问 http://ip/path/ 对应的文件目录/data/software/static/path/

举例:

location / {
	root   /data/project/autotpsite/dist;  
}

访问 http://127.0.0.1:8080/index.html 对应的文件目录是/data/project/autotpsite/dist/index.html

绝对匹配:

location /path/ { 
 	alias   /data/software/static/; 
}

文件路径等于alias对应目录,与location无关, 目录必须以 / 结尾,如访问 http://ip/path/ 对应的文件目录 /data/software/static/

举例:

location /static/ {
	alias   /data/project/autotpsite/dist/;  
}

访问 http://127.0.0.1:8080/static/index.html 对应的文件目录是/data/project/autotpsite/dist/index.html,也就是说,访问路径里需要加上路由static才能够访问

alias 与 root 是二选一的关系 ,不能并存

location指令说明:

功能:用于匹配URL,语法如下:

1= :用于不含正则表达式的 URL 前,要求请求字符串与 URL 严格匹配,如果匹配
成功,就停止继续向下搜索并立即处理该请求。
2、~:用于表示 URL 包含正则表达式,并且区分大小写。
3、~*:用于表示 URL 包含正则表达式,并且不区分大小写。
4、^~:用于不含正则表达式的 URL 前,要求 Nginx 服务器找到标识 URL 和请求字符串匹配度最高的 location 后,立即使用此 location 处理请求,而不再使用 location 块中的正则 uri 和请求字符串做匹配。

注意:如果 uri 包含正则表达式,则必须要有 ~ 或者 ~* 标识

部署反向代理

反向代理服务器和目标服务器对外就是一个服务器,暴露的是代理服务器地址,隐藏了真实服务器 IP 地址。

在这里插入图片描述

访问服务器的时候,可以发现只能返回静态文件,而静态文件中的Ajax请求全部失效了,接口并没有返回任何内容

原因就是 web 服务没有代理app服务,app服务是由uWSGI代理的。所以我们要做的就是将发送app服务的请求转给 uWSGI就可以了。

在Django项目的settings.py配置文件中DEBUG = True,debug模式还是为TRUE,是通过urls.py文件中配置的静态文件目录去访问静态文件,这里需要将静态文件的访问交由Nginx处理

from django.conf.urls.static import static
from django.contrib import admin
from django.urls import path,include

# from sqtp import urls
urlpatterns = [
    path('admin/', admin.site.urls),
    path('api/',include('sqtp.urls')),
]+ static("/",document_root='dist')

而对应api/这个接口,也交由Nginx配置反向代理,通过Nginx再转发给uWSGI代理

代理转发

autotpsite.conf配置文件进行编辑,在Nginx中配置proxy_pass代理转发

这里只有一个服务器,也就是说反向代理服务器和目标服务器是同一个服务器,所以配置proxy_pass代理转发为127.0.0.1,而Django项目的端口为8888,所以proxy_pass http://127.0.0.1:8888

server {
        listen       8080;
        listen       [::]:8080;
        server_name  _;
        # root         /data/project/autotpsite/dist;

        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        error_page 404 /404.html;
        location = /404.html {
        }

        error_page 500 502 503 504 /50x.html;
        location = /50x.html {
        }
        
        location / {
			root   /data/project/autotpsite/dist;  
    	}
        
        #location /api/ {
        #    proxy_pass  http://127.0.0.1:8888;
        #}

        location /api/ {
   			include       uwsgi_params;
   			uwsgi_pass     127.0.0.1:8888; 
        	# 此方式需要 uwsgi采用socket连接方式
		}
}

Django项目的app服务是由uWSGI服务器代理的,这里可以不使用http协议,而是采用socket连接方式,这里uwsgi_pass代理转发对应的是一个二进制的socket协议

更新uWSGI服务配置

[uwsgi]
chdir =./
// 项目根目录,配置文件处于项目根目录,因此设置为相对路径即可,复用性更高
module = autotpsite.wsgi:application
// 指定wsgi模块下的application对象
socket = 0.0.0.0:8888
//Nginx使用uwsgi_pass做方向代理时 需要设置成socket
master = true
// 主进程
pidfile = uwsgi8888.pid
// pid 文件,用于脚本启动,停止该进程
daemonize = uwsgi_server.log
// 日志文件
enable-threads = true
// 新增配置--允许多线程
buffer-size = 40960
// 设置请求头最大字节数,用于socket模式

location这里也可以使用正则的方式匹配URL,同时支持api/jira/两个url

location ~/(api/|jira/) {
   include       uwsgi_params;
   uwsgi_pass     127.0.0.1:8888;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,这里是一个简单的Nginx反向代理配置示例: ```nginx server { listen 80; server_name example.com; location / { proxy_pass http://localhost:3000; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; } } ``` 这个配置将会把所有的来自 example.com 的请求都转发到本地的 3000 端口上去。其中,`proxy_pass` 指定了要转发的目标地址,`proxy_set_header` 则是设置了一些 HTTP 头信息,比如 Host 和 X-Real-IP 等。 当然,实际的配置可能会更加复杂,需要根据具体的需求进行调整。 ### 回答2: nginx是一款高性能的反向代理服务器软件。反向代理是指代理服务器接收来自客户端的请求,然后将请求转发给内部的服务器,最后将服务器返回的响应返回给客户端。通过nginx反向代理配置,我们可以实现负载均衡、高可用、缓存等功能。 在nginx配置反向代理一般需要以下步骤: 1. 在nginx配置文件中找到http块,添加一个新的server块,指定监听的端口和域名或IP地址。 2. 在server块中配置location指令,用于匹配客户端请求的URL地址。可以使用正则表达式进行更灵活的匹配。 3. 在location块中使用proxy_pass指令,指定转发请求的目标服务器地址和端口。例如:proxy_pass http://localhost:8080。 4. 可以通过proxy_set_header指令设置转发请求时所需的头部信息,如Host、User-Agent等。 5. 配置其他反向代理相关的指令,如proxy_connect_timeout、proxy_read_timeout等参数,用于控制与目标服务器的连接和读取超时时间。 6. 重启nginx服务,使配置生效。 配置完毕后,nginx会根据配置反向代理规则,将客户端的请求转发给目标服务器处理。目标服务器将处理结果返回给nginx,然后nginx将结果返回给客户端。 需要注意的是,配置反向代理时要确保目标服务器已经启动,并且可以正常响应请求。同时,配置的域名或IP地址需要与客户端的请求匹配,否则转发将无法生效。 通过nginx反向代理配置,我们可以实现多种功能,如实现负载均衡、部署静态缓存、提供SSL加密、进行HTTP请求过滤等。这使得nginx成为了非常强大和灵活的反向代理服务器软件。 ### 回答3: Nginx是一个高性能的Web服务器反向代理服务器反向代理是一种服务器配置模式,它允许Nginx接收客户端请求并将其转发到后端服务器,然后将响应返回给客户端。以下是Nginx反向代理配置步骤: 1. 安装和启动Nginx服务器:首先,需要在服务器上安装Nginx,并启动它。可以使用包管理器来执行这些操作。 2. 配置反向代理:编辑Nginx配置文件(通常位于/etc/nginx/nginx.conf),添加反向代理配置。可以使用以下示例作为基本配置: ``` server { listen 80; server_name your_domain.com; location / { proxy_pass http://backend_server_ip:backend_server_port; } } ``` 在上面的配置中,将"your_domain.com"替换为你的域名,"backend_server_ip"替换为后端服务器的IP地址,"backend_server_port"替换为后端服务器的端口号。此配置将把所有来自客户端的请求转发到后端服务器。 3. 重新加载Nginx配置:在完成配置之后,使用以下命令重新加载Nginx配置,使更改生效: ```bash sudo nginx -s reload ``` 4. 测试:使用Web浏览器或其他HTTP客户端工具发送请求到你的域名并验证是否成功被转发到后端服务器。 需要注意的是,上述配置仅涵盖了基本的反向代理配置。根据需要,还可以添加其他配置项,例如请求的缓存、负载均衡等。 总之,Nginx反向代理配置非常灵活和强大,并且可以帮助我们将客户端请求转发到后端服务器,从而提高网站或应用程序的性能和可靠性。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值