使用Docker發佈blazor wasm

来源:https://www.cnblogs.com/chasingdreams2017/archive/2020/05/28/12984025.html
-Advertisement-
Play Games

Blazor編譯後的文件是靜態文件,所以我們只需要一個支持靜態頁面的web server即可。 根據不同項目,會用不同的容器編排,本文已無網關的情況下為例,一步一步展示如何打包進docker 需求 HTTPS 既然無網關,直接面向互聯網,所以HTTPS顯得尤為重要 HTTP/2 TLS3.0 既然都 ...


Blazor編譯後的文件是靜態文件,所以我們只需要一個支持靜態頁面的web server即可。
根據不同項目,會用不同的容器編排,本文已無網關的情況下為例,一步一步展示如何打包進docker

需求

  1. HTTPS

既然無網關,直接面向互聯網,所以HTTPS顯得尤為重要

  1. HTTP/2 TLS3.0

既然都是靜態資源,使用H2和TLS3.0的目的是進一步加快載入速度

  1. Compress

對靜態資源的壓縮的目的依然是進一步加快載入速度。壓縮選型為Brotli和 Gzip 壓縮

Dockerfile

官方的Nginx鏡像,預設不支持Brotli
所以需要自己準備一個具有Brotli支持的鏡像,這裡推薦使用自賣自誇的Nginx鏡像,不僅使用最新的openssl編譯(避免漏洞),還支持TLS1.3 http2 brotli和預設東八時區,且配置文件里還有配置示例。歡迎訪問Docker Hub rsnow/nginx,瞭解更多。

發佈blazor wasm

截至2020.05.26,VS還不能把blazor wasm直接發佈到Docker鏡像倉庫,所以只能自己打包

  1. 首先發佈Release,不再贅述
  2. 在項目根目錄創建Dockerfile
FROM rsnow/nginx:amd64-1.18.0
RUN rm /usr/share/nginx/html/index.html && \
    echo -e 'server { \n\
    listen       443 ssl http2; \n\
    server_name  localhost; \n\
    brotli on; \n\
    brotli_comp_level 6; \n\
    brotli_types application/wasm application/octet-stream text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript application/javascript image/svg+xml; \n\
    gzip on; \n\
    gzip_vary on; \n\
    gzip_proxied any; \n\
    gzip_comp_level 6; \n\
    gzip_types application/wasm application/octet-stream text/plain text/css text/xml application/json application/javascript application/rss+xml application/atom+xml image/svg+xml; \n\
    ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem; \n\
    ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem; \n\
    ssl_trusted_certificate /etc/letsencrypt/live/example.com/chain.pem; \n\
    ssl_dhparam /etc/certs/dhparam.pem; \n\
    ssl_session_timeout 1d; \n\
    ssl_session_cache shared:SSL:10m;  about 40000 sessions \n\
    ssl_session_tickets off; \n\
    ssl_protocols TLSv1.3; \n\
    ssl_prefer_server_ciphers off; \n\
    ssl_stapling on; \n\
    ssl_stapling_verify on; \n\
    resolver 1.1.1.1 1.0.0.1 8.8.8.8 8.8.4.4 208.67.222.222 208.67.220.220 valid=60s; \n\
    resolver_timeout 2s; \n\
    add_header X-Frame-Options "SAMEORIGIN" always; \n\
    add_header X-XSS-Protection "1; mode=block" always; \n\
    add_header X-Content-Type-Options "nosniff" always; \n\
    add_header Referrer-Policy "no-referrer-when-downgrade" always; \n\
    add_header Content-Security-Policy "default-src \'self\' http: https: data: blob: \'unsafe-inline\'" always; \n\
    add_header Strict-Transport-Security "max-age=31536000; includeSubDomains; preload" always; \n\    
    location / { \n\
        root   /usr/share/nginx/html; \n\
        try_files $uri $uri/ /index.html =404; \n\
    } \n\
} \n\
' > /etc/nginx/conf.d/default.conf
COPY ./bin/Release/netstandard2.1/publish/wwwroot /usr/share/nginx/html/

我們使用自定義的conf覆蓋掉預設的conf(最簡單的情況)

  1. 整個Nginx Container只有一個虛擬主機,所以server_name無論為何值,請求都會指向這個唯一的虛擬主機
  2. 如果有網關,可以關閉跨域,HTTPS之類的配置,因為這些內容網關會涵蓋
  3. 因本示例展示的是最簡單的情況,所以並沒有使用 volume ,如果有容器互聯,載入外部證書,配置文件的情況可根據實際情況創建掛載點。
  4. 無論是gzbr都增加了對application/wasm application/octet-stream的支持

Images

有個Dockerfile,就開始生成鏡像吧

docker build -t example.com/testnginxblazor:latest .

如果需要上傳到倉庫

docker push example.com/testnginxblazor:latest

Run

根據創建的鏡像,創建並運行容器

docker run \
    -d \
    --name nginxblazor \
    -p 443:443 \
    -v /test/fullchain.pem : /etc/letsencrypt/live/example.com/fullchain.pem \
    -v /test/privkey.pem : /etc/letsencrypt/live/example.com/privkey.pem \
    -v /test/chain.pem : /etc/letsencrypt/live/example.com/chain.pem \
    -v /test/dhparam.pem : /etc/certs/dhparam.pem \
    example.com/testnginxblazor

聲明

本文采用知識共用署名-非商業性使用-相同方式共用 2.5 中國大陸許可協議進行許可,發表在CSDN博客園,歡迎讀者轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接!請讀者/爬蟲們尊重版權


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 當你刷到這篇博文時,說明也在做網站訪問量統計的工作。在記錄標題問題時候,這邊先記錄下其實做網站統計,有兩大類: 第一種:直接使用第三方的統計工具,即註冊第三方賬號,然後在自己項目中放入js跟蹤代碼,在第三方平臺上即可查看數據,這類平臺有 序號 名稱 說明 地域 網址 Ⅰ 友盟 + 國內第三方全域數據 ...
  • maven 命令除了常用的幾個,大部分經常記不住,整理一下,方便查詢。 maven 命令的格式為 mvn [plugin-name]:[goal-name],可以接受的參數如下。 -D 指定參數,如 -Dmaven.test.skip=true 跳過單元測試; -P 指定 Profile 配置,可以 ...
  • 在面試前三面真的有點急促,一周內就面完了三次面試,接著就開始無盡的等待,整整等了三周左右,終於完成了三面和HR面。整個過程還是比較曲折的,技術面試還是挺考察技術深度的。現在已拿到offer。 ...
  • 1 #include "stdio.h" 2 #include "time.h" 3 #include <windows.h> 4 5 // 6 // 7 // Title: C語言實現小人移動 V1.0 8 // Author: 鄒陽 9 // Date : 2020/05/28 10 // 11 ...
  • 首先在用戶表定義一個積分欄位; 然後創建一個等級表,主要欄位有等級名,上限積分和下限積分; 再根據用戶的行為進行積分累加; 最後根據判斷用戶積分在哪個等級範圍,從而得出用戶等級。 用戶表 CREATE TABLE `bbs`.`user`( `id` INT(10) UNSIGNED NOT NUL ...
  • Java多線程面試問題 1. 進程和線程之間有什麼不同? 一個進程是一個獨立(self contained)的運行環境,它可以被看作一個程式或者一個應用。而線程是在進程中執行的一個任務。Java運行環境是一個包含了不同的類和程式的單一進程。線程可以被稱為輕量級進程。線程需要較少的資源來創建和駐留在進 ...
  • 使用場景:新頭像替換舊的頭像 步驟: 1. 讀取資料庫頭像的URL地址 2. 獲取URL地址的有效欄位 3. file文件路徑設置 4. 刪除圖片文件 Thinkphp 代碼如下: <?php public function delPic(){ //獲取用戶id $uid = input('uid' ...
  • Java這門語言的發展是很有意思的,它不像Python, Ruby 等完全是開源社區驅動,也不像C#,VB.NET主要由微軟操刀。它是一個以Oracle(之前是Sun)為主,各大巨頭一起參與,一起制定標準的一門語言。 想對Java添加一點特性, 得走JCP流程,巨頭們要審查,看看對自己是否有利,然後 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...