成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

React 實踐項目 (五)Docker Nginx 部署 React

EscapedDog / 3516人閱讀

摘要:在上已經(jīng)有接近的數(shù)了,是目前最熱門的前端框架。將整個應(yīng)用打包發(fā)布,自動試用進行壓縮與優(yōu)化。毫無疑問,這些重擔(dān)都將壓在企業(yè)開發(fā)人員身上團隊之間如何高效協(xié)調(diào),快速交付產(chǎn)品,快速部署應(yīng)用,以及滿足企業(yè)業(yè)務(wù)需求,是開發(fā)人員亟需解決的問題。

React在Github上已經(jīng)有接近70000的 star 數(shù)了,是目前最熱門的前端框架。而我學(xué)習(xí)React也有一段時間了,現(xiàn)在就開始用 React+Redux 進行實戰(zhàn)!

React 實踐項目 (一)
React 實踐項目 (二)
React 實踐項目 (三)
React 實踐項目 (四)
React 實踐項目 (五)

這次我們把應(yīng)用部署到服務(wù)器上.

項目到現(xiàn)在麻雀雖小五臟俱全,為了提高我們寫代碼的積極性,自然是選擇部署到服務(wù)器上在小伙伴面前秀一波了.部署 React 應(yīng)用也是非常方便簡單的.

打包應(yīng)用

我們是用Facebook官方的零配置命令行工具 create-react-app 創(chuàng)建的項目,create-react-app 內(nèi)置了打包的npm 命令

在命令行里切換到項目目錄,執(zhí)行 npm run build 命令,代碼會被編譯到build目錄。將整個應(yīng)用打包發(fā)布,自動試用webpack進行壓縮與優(yōu)化。

如上圖所示,我們的應(yīng)用已經(jīng)打包完畢.

安裝 Nginx

Nginx 是一個高性能的HTTP和反向代理服務(wù)器.

在安裝Nginx前需要先介紹下 Docker.

Docker 是一個開源的應(yīng)用容器引擎,讓開發(fā)者可以打包他們的應(yīng)用以及依賴包到一個可移植的容器中,然后發(fā)布到任何流行的 Linux 機器上,也可以實現(xiàn)虛擬化。容器是完全使用沙箱機制,相互之間不會有任何接口。

云計算、大數(shù)據(jù),移動技術(shù)的快速發(fā)展,加之企業(yè)業(yè)務(wù)需求的不斷變化,導(dǎo)致企業(yè)架構(gòu)要隨時更改以適合業(yè)務(wù)需求,跟上技術(shù)更新的步伐。毫無疑問,這些重擔(dān)都將壓在企業(yè)開發(fā)人員身上;團隊之間如何高效協(xié)調(diào),快速交付產(chǎn)品,快速部署應(yīng)用,以及滿足企業(yè)業(yè)務(wù)需求,是開發(fā)人員亟需解決的問題。Docker技術(shù)恰好可以幫助開發(fā)人員解決這些問題。
為了解決開發(fā)人員和運維人員之間的協(xié)作關(guān)系,加快應(yīng)用交付速度,越來越多的企業(yè)引入了DevOps這一概念。但是,傳統(tǒng)的開發(fā)過程中,開發(fā)、測試、運維是三個獨立運作的團隊,團隊之間溝通不暢,開發(fā)運維之間沖突時有發(fā)生,導(dǎo)致協(xié)作效率低下,產(chǎn)品交付延遲, 影響了企業(yè)的業(yè)務(wù)運行。Docker技術(shù)將應(yīng)用以集裝箱的方式打包交付,使應(yīng)用在不同的團隊中共享,通過鏡像的方式應(yīng)用可以部署于任何環(huán)境中。這樣避免了各團隊之間的協(xié)作問題的出現(xiàn),成為企業(yè)實現(xiàn)DevOps目標(biāo)的重要工具。以容器方式交付的Docker技術(shù)支持不斷地開發(fā)迭代,大大提升了產(chǎn)品開發(fā)和交付速度。
此外,與通過Hypervisor把底層設(shè)備虛擬化的虛擬機不同,Docker直接移植于Linux內(nèi)核之上,通過運行Linux進程將底層設(shè)備虛擬隔離,這樣系統(tǒng)性能的損耗也要比虛擬機低的多,幾乎可以忽略。同時,Docker應(yīng)用容器的啟停非常高效,可以支持大規(guī)模的分布系統(tǒng)的水平擴展,真正給企業(yè)開發(fā)帶來福音。

總之就是非常好用, linux windows mac上都可以安裝,docker安裝完成后我們先把nginx鏡像下載到本地.

docker pull nginx

為了使用方便,我們用 docker-compose 管理容器.

創(chuàng)建 docker-compose.yml

version: "2"
services:
  # 服務(wù)名稱
  nginx:
    # 鏡像:版本
    image: nginx:latest 
    # 映射容器80端口到本地80端口
    ports:
     - "80:80"
    # 數(shù)據(jù)卷 映射本地文件到容器
    volumes:
    # 映射nginx.conf文件到容器的/etc/nginx/conf.d目錄并覆蓋default.conf文件
    # - ./nginx.conf:/etc/nginx/conf.d/default.conf
    # 映射build文件夾到容器的/usr/share/nginx/html文件夾
     - ./build:/usr/share/nginx/html
    # 覆蓋容器啟動后默認執(zhí)行的命令。
    command: /bin/bash -c "nginx -g "daemon off;""

完成后執(zhí)行 docker-compose up -d 就會自動創(chuàng)建容器并在后臺運行了

常用命令:
docker-compose down 關(guān)閉并刪除容器
docker-compose ps 查看容器狀態(tài)
docker-compose exec SERVICE COMMAND 可以用來進入容器內(nèi)部進行一些操作,
比如 docker-compose exec nginx bash

靜態(tài)資源配置

我們先把打包好的build文件夾上傳至服務(wù)器,和docker-compose.yml 放在一起
docker-compose.yml 文件已經(jīng)配置了會把同目錄的 build 文件夾映射到nginx容器的/usr/share/nginx/html文件夾 這個文件夾就是默認的靜態(tài)資源文件夾

配置 Nginx

nginx鏡像有一個默認的配置文件 default.conf

default.conf

server {
    listen       80;
    server_name  localhost;

    #charset koi8-r;
    #access_log  /var/log/nginx/host.access.log  main;

    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
    }

    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }

    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ .php$ {
    #    proxy_pass   http://127.0.0.1;
    #}

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    #location ~ .php$ {
    #    root           html;
    #    fastcgi_pass   127.0.0.1:9000;
    #    fastcgi_index  index.php;
    #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
    #    include        fastcgi_params;
    #}

    # deny access to .htaccess files, if Apache"s document root
    # concurs with nginx"s one
    #
    #location ~ /.ht {
    #    deny  all;
    #}
}

默認的配置有一個問題, 在非首頁的路由頁面刷新就會報404錯誤
我們使用 react-router 作為路由管理,在開發(fā)端的express服務(wù)器下運行和測試表現(xiàn)均正常,部署到線上的nginx服務(wù)器后,還需要對該應(yīng)用在nginx的配置里作相應(yīng)調(diào)整,否則瀏覽器將不能正常刷新,表現(xiàn)為頁面不顯示或頁面跳轉(zhuǎn)錯誤等異常。原因在于這些react應(yīng)用在運行時會更改瀏覽器uri而又不真的希望服務(wù)器對這些uri去作響應(yīng),如果此時刷新瀏覽器,服務(wù)器收到瀏覽器發(fā)來的uri就去尋找資源,這個uri在服務(wù)器上是沒有對應(yīng)資源,結(jié)果服務(wù)器因找不到資源就發(fā)送403錯誤標(biāo)志給瀏覽器。所以,我們要做的調(diào)整是:瀏覽器在使用這個react應(yīng)用期間,無論uri更改與否,服務(wù)器都發(fā)回index.html這個頁面就行。

創(chuàng)建 nginx.conf 文件

# gzip設(shè)置
gzip on;
gzip_vary on;

gzip_comp_level 6;
gzip_buffers 16 8k;

gzip_min_length 1000;
gzip_proxied any;
gzip_disable "msie6";
#gzip_http_version 1.0;
gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript application/javascript;

server {
    listen       80;
    server_name  localhost;

    #charset koi8-r;
    #access_log  /var/log/nginx/host.access.log  main;

    location / {
        root   /usr/share/nginx/html;
        index  index.html index.htm;
        # 其作用是按順序檢查文件是否存在,返回第一個找到的文件或文件夾(結(jié)尾加斜線表示為文件夾),如果所有的文件或文件夾都找不到,會進行一個內(nèi)部重定向到最后一個參數(shù)。
        try_files $uri /index.html;
    }

    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }

    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ .php$ {
    #    proxy_pass   http://127.0.0.1;
    #}

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    #location ~ .php$ {
    #    root           html;
    #    fastcgi_pass   127.0.0.1:9000;
    #    fastcgi_index  index.php;
    #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
    #    include        fastcgi_params;
    #}

    # deny access to .htaccess files, if Apache"s document root
    # concurs with nginx"s one
    #
    #location ~ /.ht {
    #    deny  all;
    #}
}

將 docker-compose.yml 里的 # - ./nginx.conf:/etc/nginx/conf.d/default.conf 注釋去掉 用nginx.conf覆蓋默認的配置

docker-compose down
docker-compose up -d

現(xiàn)在我們訪問服務(wù)器的80端口就可以看到我們的應(yīng)用了.比如我的服務(wù)器ip為 139.224.135.86 在瀏覽器輸入 http://139.224.135.86 就可以訪問了.

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/39613.html

相關(guān)文章

  • React 實踐項目Docker Nginx 部署 React

    摘要:在上已經(jīng)有接近的數(shù)了,是目前最熱門的前端框架。將整個應(yīng)用打包發(fā)布,自動試用進行壓縮與優(yōu)化。毫無疑問,這些重擔(dān)都將壓在企業(yè)開發(fā)人員身上團隊之間如何高效協(xié)調(diào),快速交付產(chǎn)品,快速部署應(yīng)用,以及滿足企業(yè)業(yè)務(wù)需求,是開發(fā)人員亟需解決的問題。 React在Github上已經(jīng)有接近70000的 star 數(shù)了,是目前最熱門的前端框架。而我學(xué)習(xí)React也有一段時間了,現(xiàn)在就開始用 React+Red...

    jsyzchen 評論0 收藏0
  • React 實踐項目Docker Nginx 部署 React

    摘要:在上已經(jīng)有接近的數(shù)了,是目前最熱門的前端框架。將整個應(yīng)用打包發(fā)布,自動試用進行壓縮與優(yōu)化。毫無疑問,這些重擔(dān)都將壓在企業(yè)開發(fā)人員身上團隊之間如何高效協(xié)調(diào),快速交付產(chǎn)品,快速部署應(yīng)用,以及滿足企業(yè)業(yè)務(wù)需求,是開發(fā)人員亟需解決的問題。 React在Github上已經(jīng)有接近70000的 star 數(shù)了,是目前最熱門的前端框架。而我學(xué)習(xí)React也有一段時間了,現(xiàn)在就開始用 React+Red...

    ephererid 評論0 收藏0
  • React搭建個人博客(二)consul-template+nginx+docker實現(xiàn)負載均衡

    摘要:前兩個數(shù)據(jù)業(yè)務(wù)相關(guān)的服務(wù)即下圖的,第三個項目就是的實現(xiàn)的負載均衡。這里后臺,前臺項目各啟動了三個實例,用戶訪問的時候,就會根據(jù)配置的負載均衡的策略,訪問其中一個。這一部分與之前我轉(zhuǎn)發(fā)的實現(xiàn)服務(wù)發(fā)現(xiàn)及網(wǎng)關(guān)其實也只是差了個網(wǎng)關(guān)和負載均衡。 一.簡介 上一篇只講了博客的前端問題,這一篇講一下后端的微服務(wù)搭建。項目的后端使用的thinkjs框架,在我之前的博客中已經(jīng)寫過,這里就不重點說明了。后...

    Coding01 評論0 收藏0
  • 我的 2015 年度小結(jié)(技術(shù)方面)

    摘要:因為路由層面受業(yè)務(wù)影響很大,經(jīng)常修改一些功能的行為,所以后來大部分測試都是針對層面的單元測試。在我了解的過程中,我發(fā)現(xiàn)中文網(wǎng)絡(luò)上對的討論非常分散,于是我創(chuàng)建了中文社區(qū),到年末已經(jīng)有個注冊用戶和個帖子了。 https://jysperm.me/2016/02/programming-of-2015/ 從 2014 年末開始開發(fā)的一個互聯(lián)網(wǎng)金融項目終于在今年三月份上線了,這是一個 Node...

    Nosee 評論0 收藏0

發(fā)表評論

0條評論

EscapedDog

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<