Nginx代理同域名前后端分離項目的完整步驟
更新時間:2020年10月18日 09:56:57 作者:Mr_houzi
這篇文章主要給大家介紹了關于Nginx代理同域名前后端分離項目的完整步驟,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
前后端分離項目,前后端共用一個域名。通過域名后的 url 前綴來區(qū)別前后端項目。
以 vue + php 項目為例。直接上 server 模塊的 nginx 配置。
server
{
listen 80;
#listen [::]:80 default_server ipv6only=on;
server_name demo.com; # 配置項目域名
index index.html index.htm index.php;
# 1.轉給前端處理
location /
{
# 前端打包后的靜態(tài)目錄
alias /home/wwwroot/default/vue-demo/dist/;
}
# 2.轉給后端處理
location /api/ {
try_files $uri $uri/ /index.php?$query_string;
}
# 3.最終php在這里轉給fpm
location ~ [^/]\.php(/|$)
{
# 后端項目目錄
root /home/wwwroot/default/demo/public/;
#fastcgi_pass 127.0.0.1:9000;
fastcgi_pass unix:/tmp/php-cgi.sock;
fastcgi_index index.php;
include fastcgi.conf;
include pathinfo.conf;
}
# 4.處理后端的靜態(tài)資源
location /public/ {
alias /home/wwwroot/default/demo/public/uploads/;
}
#error_page 404 /404.html;
access_log /home/wwwlogs/access.log main;
}
簡單解釋
- 當域名后存在 /api/ 前綴時,將轉給后端處理;
- 當域名后存在 /uploads/ 前綴時,訪問后端的靜態(tài)資源。
- 由于 location 精準匹配的原則,除以上之外的訪問都會被轉到第一處 location 訪問前端頁面。
例如:
訪問文章列表接口
GET https://demo.com/api/posts
訪問上傳的圖片
GET https://demo.com/uploads/xxx.jpg
訪問前端首頁
GET https://demo.com/
訪問文章頁面
GET https://demo.com/posts
PS:alias 路徑末尾一定要有 / 。
總結
到此這篇關于Nginx代理同域名前后端分離項目的文章就介紹到這了,更多相關Nginx代理同域名前后端分離項目內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Nginx偽靜態(tài)配置和常用Rewrite偽靜態(tài)規(guī)則集錦
偽靜態(tài)是一種可以把文件后綴改成任何可能的一種方法,如果我想把php文件偽靜態(tài)成html文件,這種相當簡單的,下面我來介紹nginx 偽靜態(tài)配置方法有需要了解的朋友可參考。2014-06-06
Windows環(huán)境實現(xiàn)Nginx配置及開機自啟動
本文主要介紹了Windows環(huán)境實現(xiàn)Nginx配置及開機自啟動,通過兩種方式可以實現(xiàn)nginx的開機自啟動,具有一定的參考價值,感興趣的可以了解一下2024-03-03
prometheus監(jiān)控nginx并實現(xiàn)可視化的操作指南
Nginx是一款高性能的Web服務器,被廣泛應用于各類的網(wǎng)站和應用程序中,為了保證Nginx的正常工作,我們需要對其進行監(jiān)控和管理,所以本文給大家介紹了prometheus監(jiān)控nginx并實現(xiàn)可視化的操作指南,需要的朋友可以參考下2024-05-05

