一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

云服務(wù)器|WEB服務(wù)器|FTP服務(wù)器|郵件服務(wù)器|虛擬主機(jī)|服務(wù)器安全|DNS服務(wù)器|服務(wù)器知識|Nginx|IIS|Tomcat|

服務(wù)器之家 - 服務(wù)器技術(shù) - Nginx - 如何使用Nginx在AWS上部署React?

如何使用Nginx在AWS上部署React?

2021-03-31 22:2551CTOMatt Sokola Nginx

本文將幫你實(shí)現(xiàn)在生產(chǎn)環(huán)境上部署React應(yīng)用程序。這次將使用Docker和Nginx來保護(hù)API密鑰和代理請求,以防止跨域資源共享(CORS)違規(guī)。

在每個項(xiàng)目的生命周期中,都需要在生產(chǎn)環(huán)境上發(fā)布新功能,即使新版本更新并不那么明顯。

如何使用Nginx在AWS上部署React?

大多數(shù)Web應(yīng)用程序都使用某些API來完成更新,但是它們通常托管在不同的服務(wù)器上。這種情況下,作為開發(fā)人員就需要解決跨源資源共享(CORS)問題。所以通常的做法是建立一個后端。

不過,優(yōu)秀的開發(fā)人員應(yīng)該保持應(yīng)用程序的簡單性,并去除所有多余的部分。在本文中,我將展示如何準(zhǔn)備React應(yīng)用程序,以便將它們部署到生產(chǎn)環(huán)境中。

我可以做一個微不足道的React示例應(yīng)用,但它的幫助意義不是很大。因此,我決定將我的應(yīng)用程序與聯(lián)邦儲備銀行提供的一個API連接。API需要一個訪問鍵來檢索數(shù)據(jù),并且端點(diǎn)受到了跨域請求的保護(hù),所以沒有外部web應(yīng)用程序能夠直接使用數(shù)據(jù)。

這里需要注意的是,如果您的應(yīng)用程序依賴服務(wù)器端呈現(xiàn),那本次教程并不是正確的部署策略,雖然你可以得到一些思路上的啟發(fā),但仍需要后端的支持。

前提條件

在按照本文操作之前,掌握一些創(chuàng)建React應(yīng)用程序和Docker的基本知識是至關(guān)重要的。

React APP 示例

 

我用create-react-app創(chuàng)建了一個簡單的網(wǎng)絡(luò)應(yīng)用程序。該應(yīng)用程序唯一的功能是顯示一個代表美國GDP的折線圖。

該應(yīng)用程序僅從以下API獲取數(shù)據(jù):

  1. https://api.stlouisfed.org/fred/series/observations?series_id=GDPCA&frequency=a&observation_start=1999-04-15&observation_end=2021-01-01&file_type=json&api_key=abcdefghijklmnopqrstuvwxyz123456 

參數(shù):

  • series_id:序列ID。GDPCA代表“實(shí)際GDP”。
  • frequency:數(shù)據(jù)匯總,a代表年度。
  • observation_start:觀察期的開始。
  • observation_end:觀察期的結(jié)束。
  • file_type:數(shù)據(jù)格式。默認(rèn)*xml*。
  • api_key:從此API檢索任何數(shù)據(jù)所需的訪問密鑰。

生活并不總是完美的,API設(shè)計(jì)也不理想。它要求開發(fā)人員將訪問鍵和預(yù)期的數(shù)據(jù)輸出作為URL參數(shù)傳遞。將輸出作為參數(shù)傳遞對我們來說不是問題,但泄漏API密鑰的風(fēng)險卻是個問題。

即使拋開密鑰泄漏的風(fēng)險,在跨域請求保護(hù)下從外部調(diào)用FRED API,也會收到錯誤。

許多開發(fā)人員會建議構(gòu)建中間件(后端)來代理API請求并過濾敏感數(shù)據(jù)。在某種程度上,這是一個有效的方法。但我更喜歡以一種更YAGNI的方式構(gòu)建我的應(yīng)用程序,不過,我們本次的示例將不需要構(gòu)建。

讓我們使用Nginx

 

我是NGINX的忠實(shí)擁護(hù)者,因?yàn)樗鼛砹撕唵涡浴ginx擁有準(zhǔn)備生產(chǎn)級Web服務(wù)器所需的全部功能,比如HTTP2、壓縮、TLS和許多其他的。最重要的是,我們可以通過定義幾行配置來實(shí)現(xiàn)。像下面的代碼片段:

  1. ... 
  2.  
  3. http { 
  4. ... 
  5.  
  6. server { 
  7. ... 
  8.  
  9. location /api { 
  10. set $args $args&&file_type=json&api_key=abcdefghijklmnopqrstuvwxyz123456
  11. proxy_pass https://api.stlouisfed.org/fred/series; 

上面這4行是我隱藏API鍵和抑制CORS錯誤所需要的全部關(guān)鍵代碼。也就是從現(xiàn)在開始,所有對API的HTTP請求都將被代理到FRED api,而且只有我們的應(yīng)用程序才能使用該API。所有外部請求都將面臨CORS錯誤。

這就是我們的端點(diǎn)的樣子:

  1. /api/observations?series_id=GDPCA&frequency=a&observation_start=1999-04-15&observation_end=2021-01-01 

我們既不需要傳遞api_key參數(shù)也不需要傳遞file_type參數(shù)來檢索數(shù)據(jù)。也沒有人可以從URL中讀取訪問密鑰,因?yàn)樗前踩摹?/p>

Docker喜歡Nginx

 

在云中運(yùn)行NGINX最方便的方法就是使用Docker。

接下來我們只需要創(chuàng)建一個包含以下內(nèi)容的Dockerfile:

  1. FROM nginx 
  2.  
  3. COPY container / 
  4. COPY build /usr/share/nginx/html 

現(xiàn)在,只需要三個步驟就可以運(yùn)行FRED APP:

  • 構(gòu)建React應(yīng)用程序。這個過程生成包含靜態(tài)文件的build/目錄。
  • 構(gòu)建Docker映像。將創(chuàng)建一個可運(yùn)行的Docker映像。
  • 發(fā)布Docker鏡像到某個存儲庫或在本地機(jī)器上運(yùn)行它。

接下來,讓我們嘗試在我們的機(jī)器上運(yùn)行它。

  1. $ yarn install 
  2. $ yarn build 
  3. $ docker build -t msokola/fred-app:latest . 
  4. $ docker run -p 8081:80 -it msokola/fred-app:latest 

8081是一個端口號。這意味著該應(yīng)用程序?qū)⒃谝韵耈RL: http://localhost:8081下可用。

在瀏覽器中打開這個URL后,你應(yīng)該會在終端中看到這樣的日志:

  1. 0.0.0.1 - - [11/Mar/2021:18:57:50 +0000] "GET / HTTP/1.1" 200 1556 "-" "Mozilla/5.0 (Macintosh; Intel Mac OS X 11_2_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.192 Safari/537.36" "-" 
  2. ... 
  3. 0.0.0.1 - - [11/Mar/2021:18:57:51 +0000] "GET /api/observations?series_id=GDPCA&frequency=a&observation_start=1999-04-15&observation_end=2021-01-01 HTTP/1.1" 200 404 "http://localhost:8081/" "Mozilla/5.0 (Macintosh; Intel Mac OS X 11_2_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/88.0.4324.192 Safari/537.36" "-" 

請注意日志中的兩個200,因?yàn)樗鼈兇鞨TTP狀態(tài)OK。如果你在API請求旁邊看到的是一個400,這意味著你的API密鑰有問題。

總結(jié)

如果你的項(xiàng)目還沒開始,那你可能還沒部署過APP。但未雨綢繆是件好事,因?yàn)檫t早有一天你會用到的。

【原文地址】:https://developer.51cto.com/art/202103/654465.htm

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 欧美一级视频在线高清观看 | 亚洲大爷操 | 久久亚洲网站 | 日韩一级片在线播放 | 久久99r66热这里有精品 | 四虎影院最新网址 | 国产日韩欧美在线播放 | 亚洲男gay同性同志 亚洲免费在线看 | 国产实拍会所女技师在线 | ass性强迫rape | 日本免费观看95视频网站 | 日韩国产成人 | 日韩精品高清自在线 | 国产精品制服丝袜白丝www | 深夜在线小视频 | 玩50岁四川熟女大白屁股直播 | 午夜人妻理论片天堂影院 | 4444kk在线看片| 第一次破学生处破 | 亚洲午夜小视频 | 久久中文字幕亚洲 | 国产香蕉久久 | 无人影院在线播放视频 | 日韩成人免费aa在线看 | 日韩成人在线视频 | 小小水蜜桃免费影院 | 亚洲欧美日韩国产一区二区精品 | 日本不卡在线视频高清免费 | 欧美成人禁片在线观看俄罗斯 | 色小孩导航 | 久久机热视频 这里只有精品首页 | 性欧美videofree中文字幕 | 日本性爱| 我不卡影院手机在线观看 | 扒开女人下面 | 香蕉人人超人人超碰超国产 | 日韩无遮挡大尺度啪啪影片 | 亚洲xxxxxhd奶水女人 | 本站只有精品 | 天天快乐高清在线观看 | aaa一级毛片免费 |