精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

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

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

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

?[[390531]]?

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

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

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

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

前提條件

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

React APP 示例

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

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

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:觀察期的開(kāi)始。
  • observation_end:觀察期的結(jié)束。
  • file_type:數(shù)據(jù)格式。默認(rèn)*xml*。
  • api_key:從此API檢索任何數(shù)據(jù)所需的訪問(wèn)密鑰。

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

即使拋開(kāi)密鑰泄漏的風(fēng)險(xiǎn),在跨域請(qǐng)求保護(hù)下從外部調(diào)用FRED API,也會(huì)收到錯(cuò)誤。

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

讓我們使用Nginx

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

...

http {
...

server {
...

location /api {
set $args $args&&file_type=json&api_key=abcdefghijklmnopqrstuvwxyz123456;
proxy_pass https://api.stlouisfed.org/fred/series;
}
}
}

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

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

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

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

Docker喜歡Nginx

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

接下來(lái)我們只需要?jiǎng)?chuàng)建一個(gè)包含以下內(nèi)容的Dockerfile:

FROM nginx

COPY container /
COPY build /usr/share/nginx/html

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

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

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

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

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

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

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" "-"
...
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" "-"

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

總結(jié)

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

【51CTO譯稿,合作站點(diǎn)轉(zhuǎn)載請(qǐng)注明原文譯者和出處為51CTO.com】


責(zé)任編輯:黃顯東 來(lái)源: hackernoon.com
相關(guān)推薦

2020-10-26 07:40:17

Terraform

2023-02-07 16:36:34

機(jī)器學(xué)習(xí)Docker無(wú)服務(wù)器

2015-01-06 09:41:25

AWS數(shù)據(jù)庫(kù)部署數(shù)據(jù)庫(kù)監(jiān)控

2014-07-28 10:13:59

AWS部署APIEC2

2012-05-24 09:15:45

ibmdw

2009-06-01 11:23:08

Glassfish部署Glassfish

2013-07-26 11:28:08

Git

2012-05-07 08:33:20

dotcloudDjango

2024-07-16 09:41:01

2021-12-21 21:00:23

Ansible樹(shù)莓派語(yǔ)音助手

2023-09-11 09:35:20

Docker程序

2015-10-10 15:56:22

OpenShiftNodeJS部署PaaS

2015-10-23 17:29:24

AtomicOpenStack 應(yīng)用部署

2024-07-22 15:49:07

KubernetesRedis

2011-12-23 09:28:41

Redmine

2010-08-10 11:04:19

部署SCOMWindows Ser

2021-03-17 10:05:42

KubernetesRedis數(shù)據(jù)庫(kù)

2021-05-17 14:51:23

鏈碼區(qū)塊鏈網(wǎng)絡(luò)

2021-06-24 14:45:33

AWS 應(yīng)用程序NGINX

2021-09-08 11:25:45

KubernetesAPISIXLinux
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

91成人在线观看喷潮教学| 99精品99久久久久久宅男| 韩国三级hd中文字幕| 国产成人免费精品| 亚洲精品美国一| 久久五月天婷婷| 91影院在线播放| 亚洲精品美女| 色婷婷综合久久久久中文字幕1| www.久久com| 电影亚洲精品噜噜在线观看| 亚洲乱码一区二区三区在线观看| 国产自产在线视频一区| 欧美高清69hd| 伊人久久大香线蕉av超碰演员| 国产亚洲欧美日韩一区二区| 亚洲成a人片在线www| 亚洲不卡中文字幕| 成人久久久久爱| 三级黄色在线观看| 任我爽精品视频在线播放| 欧洲一区二区三区| 国产欧美一区二区色老头 | 黄色一级a毛片| 免费的国产精品| 97久久精品人搡人人玩| 国产一区第一页| 亚洲综合小说图片| 欧美精品一区二区不卡| www.午夜av| 精品女同一区二区三区在线观看| 性做久久久久久免费观看欧美| 亚洲一区二区三区精品在线观看| 三级无遮挡在线观看| 国产精品乡下勾搭老头1| 国产福利精品视频| 97久久久久久久| 欧美视频福利| 九九热这里只有精品6| 99久久精品久久亚洲精品| 蜜桃a∨噜噜一区二区三区| 精品成人私密视频| 免费观看一区二区三区| 九九99久久精品在免费线bt| 欧美日韩免费视频| 成人性生交免费看| 99精品在免费线偷拍| 91电影在线观看| 亚洲精品乱码久久久久久自慰| 黄色污网站在线观看| 五月婷婷激情综合网| r级无码视频在线观看| 丁香花视频在线观看| 亚洲综合男人的天堂| 成年丰满熟妇午夜免费视频| fc2ppv国产精品久久| 亚洲精选视频在线| av日韩在线看| 高清电影在线免费观看| 亚洲高清免费视频| 国产二级片在线观看| 色资源二区在线视频| 欧美午夜久久久| 97国产精东麻豆人妻电影| 新版的欧美在线视频| 欧美天堂在线观看| av视屏在线播放| 国产精品亚洲成在人线| 欧美日本韩国一区| 亚洲天堂小视频| 99re热精品视频| 亚洲精品99久久久久中文字幕| 麻豆精品国产传媒av| 精品日产乱码久久久久久仙踪林| 日韩av中文字幕在线免费观看| 亚洲欧美日韩综合在线| 涩涩视频网站在线观看| 亚洲午夜久久久久久久久电影院| 乱熟女高潮一区二区在线| 天天干在线视频论坛| 亚洲韩国一区二区三区| 日韩欧美视频网站| 日韩三级影视| 欧美日韩一区三区四区| 久久成年人网站| 亚洲码欧美码一区二区三区| 亚洲电影天堂av| 丰满少妇高潮一区二区| 婷婷久久一区| 97在线观看视频国产| 最近中文字幕免费在线观看| 国产精品一二三区| 欧美日韩亚洲在线| 黄a在线观看| 岛国av一区二区在线在线观看| 国产精品亚洲二区在线观看| 亚洲伊人精品酒店| 亚洲精品国精品久久99热 | 欧美亚洲大陆| 丝袜美腿亚洲一区二区| 久久久久香蕉视频| 日韩精品一区第一页| 不卡一卡2卡3卡4卡精品在| 欧洲毛片在线| 一区二区在线观看视频| 免费观看精品视频| 精品国产不卡一区二区| 亚洲欧美日韩中文在线制服| 久久久久亚洲av无码专区体验| 久久动漫亚洲| 国产乱码精品一区二区三区中文 | 国产成人澳门| 中文字幕亚洲二区| 尤物视频在线观看国产| 久久99国产精品麻豆| 久久国产精品精品国产色婷婷| 看女生喷水的网站在线观看| 欧美午夜性色大片在线观看| 男男受被啪到高潮自述| 成人3d精品动漫精品一二三| 91成人在线视频| 亚洲高清在线观看视频| 国产精品久久久久久久久果冻传媒 | 国产免费一区二区三区在线观看| 神宫寺奈绪一区二区三区| 亚洲欧洲国产专区| 免费在线观看毛片网站| 老司机在线精品视频| 欧美另类极品videosbest最新版本| 综合久久中文字幕| 久久久国产一区二区三区四区小说| 性高湖久久久久久久久aaaaa| 日韩欧美专区| 中文字幕亚洲在线| 日日夜夜狠狠操| 99久久国产综合精品色伊| 无码av天堂一区二区三区| 国产视频网站一区二区三区| 中文字幕精品国产| 波多野结衣黄色| 久久久久久亚洲综合| 亚洲国产精品久久久久婷蜜芽| caoporn成人| 欧美激情二区三区| 亚洲第一色网站| 亚洲综合免费观看高清在线观看| 交换做爰国语对白| 一区二区三区四区在线观看国产日韩| 国产欧美在线看| 日韩伦理在线电影| 9191国产精品| 五月天婷婷色综合| 国产福利一区二区三区视频| 久久精品国产精品亚洲精品色 | 777午夜精品免费视频| 天天色天天综合| 国产中文字幕一区| 成人在线观看毛片| 国产精品22p| 欧美一区二区三区免费观看 | youjizz亚洲| 久久久久久久激情视频| 色香蕉在线视频| 欧美性猛交xxxx乱大交| 韩国三级hd中文字幕| 麻豆专区一区二区三区四区五区| 亚洲午夜精品久久久中文影院av| 婷婷久久免费视频| 欧美精品少妇videofree| 亚洲精品一区二区三区四区| 亚洲va国产天堂va久久en| 国产精品边吃奶边做爽| 日韩中文字幕亚洲一区二区va在线| 日本中文不卡| 在线日韩三级| 午夜精品一区二区三区视频免费看 | 日韩欧美视频第二区| 欧美日韩在线精品一区二区三区激情综合 | 亚洲午夜在线观看视频在线| 亚洲熟女一区二区| 首页综合国产亚洲丝袜| 欧美aaa在线观看| 久久99精品国产自在现线 | 日日夜夜综合| 久久久久久一区二区三区 | 国产农村妇女毛片精品久久麻豆| 日韩精品你懂的| 欧美激情1区2区3区| 精品一区二区三区视频日产| 香蕉成人影院| 欧美高清videos高潮hd| 免费一级在线观看播放网址| 欧美电影一区二区三区| 国产微拍精品一区| 国产精品免费视频网站| 在线观看免费视频国产| 日韩国产在线观看| 日本一本中文字幕| 日韩免费一区| 久久本道综合色狠狠五月| 伊人久久大香伊蕉在人线观看热v| 欧美激情视频给我| √天堂资源地址在线官网| 亚洲成人中文字幕| 中文字幕人妻互换av久久| 亚洲国产精品久久艾草纯爱| a天堂中文字幕| 成人黄色在线视频| 一起操在线视频| 久久久人人人| 美女av免费观看| av一区二区高清| 久久国产精品一区二区三区四区| 99热这里有精品| 国产精品草莓在线免费观看| av在线理伦电影| 久久综合久中文字幕青草| 国产最新视频在线| 亚洲精品久久久久久久久久久| 国产强被迫伦姧在线观看无码| 色综合色狠狠综合色| 激情综合五月网| 国产精品青草久久| 免费观看a级片| 久久中文字幕电影| 亚洲av成人片无码| 成人午夜在线播放| 亚洲精品在线网址| 久久99热这里只有精品| 亚洲 欧美 日韩系列| 国产农村妇女精品一区二区| 中文字幕日韩精品无码内射| 欧美韩日一区| 视频三区二区一区| 精品国产91| 欧美高清性xxxxhd| 亚欧洲精品视频在线观看| 国产精品日韩欧美一区二区三区| 白嫩亚洲一区二区三区| 国产一区二区在线播放| 欧美xnxx| 国产精品网站入口| 999国产精品亚洲77777| 国产精品久久91| 成人高清一区| 国产精品一区二区电影| 欧美日韩女优| 国产精品久久久久久久久久久久久| 手机在线理论片| 欧美在线免费观看| 欧美天堂视频| 国产精品极品美女粉嫩高清在线| 亚洲最大成人| 国产suv精品一区二区三区88区| 天天综合网站| 国产精品美女www爽爽爽视频| 日韩影片中文字幕| 国产精品久久久久久久av电影| 日韩不卡在线| 亚洲最大福利网站| 成人爽a毛片免费啪啪红桃视频| 国产99午夜精品一区二区三区| 老司机成人在线| 欧洲av一区| 日韩一区二区在线免费| 国产精品久久成人免费观看| 欧美私人啪啪vps| 国产资源在线视频| 日韩精品一级二级 | 日韩在线观看视频免费| 中文字幕伦理免费在线视频| 欧美国产日韩一区| 色吧亚洲日本| 91精品久久久久久久久不口人| vam成人资源在线观看| 国产99视频精品免费视频36| 四虎5151久久欧美毛片| 亚洲一区二区三区加勒比 | 免费观看成人在线视频| 蜜桃av噜噜一区二区三区小说| 国产在线观看中文字幕| 成人国产在线观看| 亚洲自拍偷拍图| 亚洲免费观看在线视频| 欧美一区二区激情视频| 欧美日韩电影在线播放| 好吊色一区二区| 中文字幕精品在线| 日本高清成人vr专区| 日本久久久久久久| 国产亚洲高清一区| 欧美精品成人一区二区在线观看| 欧美国产偷国产精品三区| 国产综合中文字幕| 狠狠色狠狠色合久久伊人| 国产黄色三级网站| 综合自拍亚洲综合图不卡区| 日本少妇在线观看| 欧美日精品一区视频| 色婷婷在线视频| 久久综合国产精品台湾中文娱乐网| 性欧美freesex顶级少妇| 3d动漫啪啪精品一区二区免费 | 日韩精品极品在线观看播放免费视频| 91欧美在线视频| 5566日本婷婷色中文字幕97| 精品中文字幕一区二区三区四区| 免费看污久久久| 黄色在线一区| 欧美高清精品一区二区| 久久精品一区二区三区不卡| 精品处破女学生| 欧美高清视频在线高清观看mv色露露十八 | 黄网av在线| 国产日韩欧美夫妻视频在线观看| 欧美重口另类| 加勒比成人在线| 国产精品一卡二| 三级黄色在线观看| 欧美综合一区二区| 日韩三级电影网| 97视频在线观看播放| 日韩精品成人在线观看| 在线观看日本一区| 蜜臀99久久精品久久久久久软件| 亚洲国产精品无码久久久久高潮| 一区二区三区四区亚洲| 一级片在线免费观看视频| 亚洲午夜久久久久久久| 亚洲小少妇裸体bbw| 国产一区不卡在线观看| 伊人久久大香线蕉综合四虎小说 | 男女激烈动态图| 老司机一区二区| 国产一二三四视频| 欧美在线制服丝袜| 国产在线观看黄| 青青精品视频播放| 国产毛片一区二区三区| 18禁男女爽爽爽午夜网站免费| 成人18精品视频| 日韩三级av在线| 亚洲精品xxx| 国产福利片在线观看| 狠狠色狠狠色综合人人| 日韩亚洲国产欧美| 欧美在线一级片| 欧美日韩亚洲一区二| 亚洲欧美综合在线观看| 欧美一区二区三区精品电影| 亚洲精品动态| 无码人妻精品一区二区三区66| 国产校园另类小说区| 日韩国产亚洲欧美| 色悠悠国产精品| 亚洲精品aa| 成人午夜免费在线视频| 成人免费视频一区| 日日噜噜噜噜人人爽亚洲精品| 精品亚洲一区二区三区| 99久久亚洲国产日韩美女| 午夜精品视频在线观看一区二区| 奇米亚洲午夜久久精品| 国产人与禽zoz0性伦| 日韩女优av电影| 波多野一区二区| 日本一区二区精品视频| 久久99精品久久久久久| 国产高清在线免费观看| 亚洲精品国产福利| av免费在线一区| 成人午夜视频免费观看| 91在线你懂得| 在线观看免费视频a| 欧美国产日本在线| 天天躁日日躁狠狠躁欧美| 亚洲成人av免费看| 亚洲三级在线免费| 午夜视频免费看| 国产精品久久久久999| 这里只有精品在线| 国产精品嫩草av| 欧美日韩成人在线一区| 免费在线看污片| 亚洲va久久久噜噜噜久久狠狠| 91在线播放观看| 在线综合亚洲欧美在线视频| 久久国产精品黑丝| 欧美专区一二三 | 加勒比久久综合| 精品久久久av| 欧美aa视频| 黄色一级视频播放| 久久综合资源网| 国产免费叼嘿网站免费| 奇米成人av国产一区二区三区 | 国产91在线亚洲| 国产欧美精品一区aⅴ影院| 午夜精品久久久久久久96蜜桃| 清纯唯美日韩制服另类|