濮阳杆衣贸易有限公司

主頁 > 知識庫 > nginx上部署react項目的實例方法

nginx上部署react項目的實例方法

熱門標簽:coreldraw地圖標注 物超所值的400電話申請 信陽銷售外呼系統(tǒng)招商 菏澤crm外呼系統(tǒng)價格 遼寧電銷平臺外呼系統(tǒng)軟件 如何在各種地圖標注自己的地址 營銷電銷機器人招商 百應電銷機器人靠譜嗎 申請400電話號碼多少錢

測試項目:react-demo

  1. 克隆你的react-demo項目到服務器上(默認使用Github管理我們的項目)
  2. 如果需要,請安裝項目環(huán)境,比如:node.js,yarn等
  3. 進入項目目錄,執(zhí)行npm run build,開始構建項目
  4. 構建成功之后,會生成一個dist文件夾(取決于你的項目配置),這個文件夾里的靜態(tài)文件,就是我們的項目的訪問文件了,
  5. 配置Nginx,Linux服務器是進入到:/etc/nginx/sites-enabled,然后以管理員身份,新建一個你的react項目的配置文件,比如:react-demo.conf,然后,編輯文件:
server {
  listen 8080;
  # server_name your.domain.com;
  root /home/root/react-demo/dist;
  index index.html index.htm;
  location / {
    try_files $uri $uri/ /index.html;
  }
  location ^~ /assets/ {
    gzip_static on;
    expires max;
    add_header Cache-Control public;
  }
  error_page 500 502 503 504 /500.html;
  client_max_body_size 20M;
  keepalive_timeout 10;
}

執(zhí)行sudo service nginx restart重啟Nginx服務,

訪問項目,http://IP:8080/

注意事項:

1、配置域名的話,需要80端口,成功后,只要訪問域名即可訪問的項目

2、如果你使用了React-Router的browserHistory 模式,請在Nginx配置中加入如下配置:

location / {
  try_files $uri $uri/ /index.html;
}

原理,因為我們的項目只有一個根入口,當輸入類似/home的url時,找不到這個頁面,這是,nginx會嘗試加載index.html,加載index.html之后,react-router就能起作用并匹配我們輸入的/home路由,從而顯示正確的home頁面,,如果browserHistory模式的項目沒有配置上述內容,會出現404的情況。

可參考react-router文檔:

https://react-guide.github.io/react-router-cn/docs/guides/basics/Histories.html

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對腳本之家的支持。如果你想了解更多相關內容請查看下面相關鏈接

標簽:泰安 廈門 江西 江門 湖北 內江 瀘州 玉樹

巨人網絡通訊聲明:本文標題《nginx上部署react項目的實例方法》,本文關鍵詞  nginx,上,部署,react,項,目的,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《nginx上部署react項目的實例方法》相關的同類信息!
  • 本頁收集關于nginx上部署react項目的實例方法的相關信息資訊供網民參考!
  • 推薦文章
    亳州市| 郁南县| 天峻县| 崇左市| 同德县| 沧源| 丹东市| 高平市| 南木林县| 龙川县| 周宁县| 彰化市| 华容县| 西峡县| 晋中市| 湟中县| 灌云县| 陇西县| 麻阳| 遂溪县| 广南县| 衡山县| 临澧县| 汝州市| 色达县| 永仁县| 清原| 中宁县| 贵定县| 张家口市| 历史| 育儿| 织金县| 江西省| 温泉县| 宜宾县| 宁陵县| 石河子市| 晋江市| 旺苍县| 日土县|