国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

Flexus X 實例 C#/.Net Core 結合(git 代碼管理、docker 自定義鏡像)快速發布部署 - 讓你的項目飛起來~

jf_21561199 ? 來源:jf_21561199 ? 作者:jf_21561199 ? 2024-12-25 21:15 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

前言

???云端部署新體驗,C# Web API 遇上 Git Docker,828 B2B 企業節特惠來襲!Flexus X 實例,為您的 C#應用提供強大支撐,結合 Git 版本控制與 Docker 容器化部署,實現代碼高效管理與無縫遷移。即刻行動,讓您的 Web 服務更加穩定、高效,領跑數字化轉型之路!

???本實驗深入演示了如何在 Ubuntu 環境中,利用 Git 進行版本控制管理代碼,并通過 Docker 技術自定義構建鏡像,從而實現項目從代碼到應用的快速構建、打包與部署流程。這一流程不僅提升了開發效率,還確保了環境的一致性與可重復性。

環境準備

購買服務器配置

本次實驗使用的是 Flexus 云服務器 X 實例 服務器。

wKgZPGdsBXmALG2KAACgmvlB9Hk561.png

在性能設置中我選擇了自定義模式,使用了 4vCPUs | 12GiB,鏡像我選用的是最高版本的 ubuntu

wKgZO2dsBXqAV5RzAAECo10_NbQ658.png

打開 xshell,使用購買的服務器的公網 IP 地址,和設置的密碼,連接上我們的服務器。

wKgZPGdsBXqAS1FJAAM3QAKAdTA860.png

項目部署

項目準備(Dockerfile 文件)

我這里以 c#為例,新建一個 .net8.0 的 Web API 項目

wKgZO2dsBXqADCYuAAIcuQ2rRRQ461.png

這個新建的官網的 webApi 項目自帶一個接口 weatherforecast 接口,可以獲取到最近的天氣,因為本篇主要目的是如何使用 git+docker 在服務器上發布,因此不做太多改動。本地啟動一下,成功訪問到,我們稍后將這個程序部署到服務器上。

wKgZPGdsBXuAIdYJAAFR6UZiexs157.png

因為我們后面采用 Git 方式來發布應用,因此在 gitee 上新建倉庫,將代碼上傳上去。

在項目路徑下新建一個 Dockerfile 文件,內容如下(根據自己的解決方案名稱、構建環境,如.net 6.0、7.0 等版本,亦或是其他語言,對以下代碼就行調整,本部署方式適用于其他編程語言或其他版本的.net)

wKgZO2dsBXuAEWlDAAJsuq55yWA280.png

FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS baseUSER $APP_UIDWORKDIR /appEXPOSE 8080FROM mcr.microsoft.com/dotnet/sdk:8.0 AS buildARG BUILD_CONFIGURATION=ReleaseWORKDIR /srcCOPY ["WebApplication1/WebApplication1.csproj", "WebApplication1/"]RUN dotnet restore "WebApplication1/WebApplication1.csproj"COPY . .WORKDIR "/src/WebApplication1"RUN dotnet build "WebApplication1.csproj" -c $BUILD_CONFIGURATION -o /app/buildFROM build AS publishARG BUILD_CONFIGURATION=ReleaseRUN dotnet publish "WebApplication1.csproj" -c $BUILD_CONFIGURATION -o /app/publish /p:UseAppHost=falseFROM base AS finalWORKDIR /appCOPY --from=publish /app/publish .ENTRYPOINT ["dotnet", "WebApplication1.dll"]

這段 Dockerfile 用于構建一個 ASP.NET Core 應用程序的 Docker 鏡像

FROM mcr.microsoft.com/dotnet/aspnet:8.0 AS base:從 Microsoft Container Registry (MCR) 拉取 ASP.NET Core 8.0 的官方運行時鏡像作為基礎鏡像,并將其標記為 base。這個鏡像包含了運行 ASP.NET Core 應用程序所需的一切,但不包含構建工具。

FROM mcr.microsoft.com/dotnet/sdk:8.0 AS build:從 Microsoft Container Registry 拉取 ASP.NET Core 8.0 的官方 SDK 鏡像,用于構建應用程序。這個鏡像包含了構建.NET 應用程序所需的一切工具。

通過這種方式,Dockerfile 利用了 Docker 的多階段構建特性,確保了構建過程中只包含必要的工具(在構建階段使用 SDK,在最終鏡像中僅包含運行時),從而減小了最終鏡像的大小。

Git 部署并拉取代碼

安裝 Git

打開終端,然后輸入以下命令來安裝 Git

sudo apt update sudo apt install git

配置 Git 用戶信息

在安裝 Git 后,建議配置你的用戶名和電子郵件地址。這些信息將用于你的 Git 提交,并幫助你識別代碼更改的源頭。

git config --global user.name "你的名字" git config --global user.email "你的郵箱地址"

SSH 密鑰

雖然你可以通過 HTTPS URL 克隆倉庫,但使用 SSH 密鑰可以更安全地訪問你的倉庫。

檢查是否已存在 SSH 密鑰:

ls -al ~/.ssh

如果控制臺輸入結果像我一樣

wKgZPGdsBXyAPn0xAAANOB5hzzY027.png

.ssh文件夾是存在的,沒有看到 id_rsa和 id_rsa.pub文件,說明沒有包含任何 SSH 密鑰。那么你需要生成一個新的 SSH 密鑰對。

chmod 700 /root/.ssh//更改 /root/.ssh 目錄的權限,700 意味著只有目錄的所有者 ssh-keygen -t rsa -b 4096 -C "你的郵箱地址"

命令執行后,它會詢問你“Enter file in which to save the key (/root/.ssh/id_rsa):”,這是在詢問你希望將生成的私鑰保存在哪個文件中。默認情況下,它會建議你保存在/root/.ssh/id_rsa

直接按回車鍵,它會接受默認的文件名/root/.ssh/id_rsa來保存私鑰

接下來,會要求你輸入一個密碼(passphrase)來保護私鑰。這是一個可選步驟,如果你不想設置密碼,只需再次按回車鍵即可跳過此步驟

wKgZO2dsBXyAN6DeAAAsoINA_RU996.png

再次輸入 ls -al ~/.ssh,可以看到.ssh 目錄下已經生成 id_rsa.pub 等文件了。

wKgZPGdsBXyAZkboAAAP3jQzGOU277.png

輸入以下命令,公鑰內容將被輸出到終端,然后我們復制這些內容。

cat /root/.ssh/id_rsa.pub

這里以 gitee 為例,我們將公鑰添加到安全設置的 SSH 公鑰中。

wKgZO2dsBX2AFMdGAAHmuQu86wM518.png

添加完成后我們就可以在控制臺執行命令將我們的項目代碼克隆下來了。

wKgZPGdsBX6AYn2wAAJoi3aqtI0057.png

安裝 docker

Docker 在 Ubuntu 上依賴一些軟件包,需要先行安裝。

sudo apt install apt-transport-https ca-certificates curl software-properties-common gnupg lsb-release

添加 Docker GPG 密鑰

這是為了驗證從 Docker 倉庫下載的軟件包的完整性。

#官方 GPG key (可能國內訪問會存在問題)curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg# 阿里源(推薦使用)curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg

添加 Docker 官方軟件源

接下來,需要將 Docker 的官方軟件源添加到你的 Ubuntu 系統中。運行以下命令(根據你的 Ubuntu 版本,$(lsb_release -cs)會自動替換為你的 Ubuntu 代號,如 focal、jammy 等):

#Docker 官方源 echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null#阿里 apt 源 echo "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null

再次更新軟件包列表

添加完軟件源后,再次運行更新命令以確保你的軟件包列表是最新的:

sudo apt updatesudo apt-get update

安裝 docker

#安裝最新版本的 Dockersudo apt install docker-ce docker-ce-cli containerd.io#查看 Docker 版本 docker version#查看所有容器 docker ps -a

項目運行

構建鏡像

cd 到我們使用 git 拉下來的項目,如下,包含 Dockerfile 的目錄下

wKgZO2dsBX6ATTPaAAAPaIZEphI565.png

執行命令構建一個新的 Docker 鏡像

docker build -t auth .

構建成功后執行 docker images 查看鏡像,如下我名稱為 auth 的鏡像已經構建完成。

wKgZPGdsBX6AIzpGAAANNagVrQs705.png

運行容器

docker run -d -p 8080:8080 --restart=always --name auth auth

-d: 這個標志表示以“分離模式”運行容器,也就是說,容器會在后臺運行。你不會直接看到容器的輸出,除非你使用 docker logs命令或其他方法來查看。

-p 8080:8080: 這個參數用于端口映射。它將容器內的 8080 端口映射到宿主機的 8080 端口上。這樣,任何發送到宿主機 8080 端口的請求都會被轉發到容器的 8080 端口上。

--restart=always: 這個參數指定了容器的重啟策略。always表示無論何時容器停止運行(無論是因為退出還是 Docker 守護進程重啟),Docker 都會自動重啟這個容器。

運行完成后可以執行 docker ps 查看容器:

wKgZO2dsBX-ARPo1AACRobB_KuU123.png

新增安全組

打開服務器控制臺,找到我們當前的服務器,點擊名稱。

wKgZPGdsBX-AbSToAAHMnbGYb_4498.png

進去到詳情后,切換到安全組頁面,點擊配置規則。

wKgZO2dsBYCAPlj6AAEzJVrUasI323.png

在入方向規則下,點擊添加規則,然后加入我們項目的端口號。

wKgZPGdsBYCAFKzWAAG-TKZFYGU160.png

訪問接口

查看我們的服務器的 ip 地址

wKgZO2dsBYGAdc2VAAHD8JfT-uU715.png

打開瀏覽器,訪問我們項目的接口,成功獲取到信息。

wKgZPGdsBYGATetPAAKdLwXbsgo691.png

更新發布

接下來我們將接口調整一下,改為返回一個 hello word!

wKgZO2dsBYGABoaVAADW5i59T8g153.png

提交代碼

wKgZPGdsBYKAO4VvAAGr7AfT9PU446.png

回到服務器控制臺,執行 git pull 拉取最新代碼

wKgZO2dsBYKAB5qqAAAkSiFpryY089.png

使用更新后的代碼重新構建 Docker 鏡像。運行與之前相同的 docker build 命令

docker build -t auth .

停止并刪除舊的容器。

docker stop auth docker rm auth

使用更新后的鏡像啟動一個新容器。

docker run -d -p 8080:8080 --restart=always --name auth auth

刷新一下我們的瀏覽器,頁面中返回的信息是 hello word!

wKgZPGdsBYKATVlQAAA7gtA9Wvs248.png


審核編輯 黃宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • Git
    Git
    +關注

    關注

    0

    文章

    207

    瀏覽量

    16933
  • 云服務器
    +關注

    關注

    0

    文章

    837

    瀏覽量

    14687
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    KubePi:開源Kubernetes可視化管理面板,集群管理如此簡單

    。 擴展性強 :設計上考慮了可擴展性,允許通過插件或自定義功能來擴展其能力。 三、安裝部署:多種方式快速上手 KubePi提供了靈活的部署方式,適合從個人體驗到生產環境的各種場景。 3
    發表于 02-11 12:53

    采用匯編指示符來使用自定義指令

    * 使用riscv-nuclei-elf-objdump -d a.out > main.dump命令查看反匯編代碼,結果如下所示 如圖所示,在指定位置插入了自定義的指令數據。 2
    發表于 10-28 06:02

    如何在e203 SOC中添加自定義外設

    外設的基地址和連接e203_soc_top信號使用,并將自定義的外設正確實例化在此對外接口口模塊中。 3、在e203_soc_top中正確實例化第2步中的對外接口模塊 4、在system頂層模塊中正確
    發表于 10-20 10:38

    中國企業飛向世界,金山辦公+華為聯手造了“AI協同直升機”

    AI協同辦公,企業數智化飛起來
    的頭像 發表于 09-16 00:44 ?3296次閱讀
    <b class='flag-5'>讓</b>中國企業飛向世界,金山辦公+華為聯手造了“AI協同直升機”

    【M-K1HSE開發板免費體驗】相關源碼之閱讀和分析1-使用XComponent + Vsync 實現自定義動畫

    自定義繪制。 結合您提供的文件結構截圖和 CMakeLists.txt 內容,我們可以非常清晰地梳理出這個項目的實現流程、執行環境和核心邏輯。 一、 項目概述與目標 從
    發表于 09-03 16:05

    【VisionFive 2單板計算機試用體驗】1. 環境搭建與代碼整編

    /what-is-lll-lock-wait-private-and-what-can-cause-a-hang-while-malloc-consolida 創建一個文件夾存放docker項目D:\\\\docker_pro\
    發表于 07-08 23:07

    創龍 瑞芯微 RK3562 國產 2GHz 四核A53 工業開發板—Docker容器部署方法說明

    不會有任何接口。使用Docker,可像管理應用程序一樣管理基礎結構。通過利用Docker快速發布
    的頭像 發表于 07-03 11:00 ?571次閱讀
    創龍 瑞芯微 RK3562 國產 2GHz 四核A53 工業開發板—<b class='flag-5'>Docker</b>容器<b class='flag-5'>部署</b>方法說明

    完整指南:如何使用樹莓派5、Hailo AI Hat、YOLO、Docker進行自定義數據集訓練?

    今天,我將展示如何使用令人印象深刻的HailoAIHat在樹莓派5上訓練、編譯和部署自定義模型。注意:文章內的鏈接可能需要科學上網。HailoAIHat根據的設置,在樹莓派5的CPU上運行YOLO
    的頭像 發表于 06-28 08:23 ?4403次閱讀
    完整指南:如何使用樹莓派5、Hailo AI Hat、YOLO、<b class='flag-5'>Docker</b>進行<b class='flag-5'>自定義</b>數據集訓練?

    KiCad 中的自定義規則(KiCon 演講)

    “ ?Seth Hillbrand 在 KiCon US 2025 上為大家介紹了 KiCad 的規則系統,并詳細講解了自定義規則的設計與實例。? ” ? 演講主要圍繞 加強 KiCad 中的自定義
    的頭像 發表于 06-16 11:17 ?2141次閱讀
    KiCad 中的<b class='flag-5'>自定義</b>規則(KiCon 演講)

    HarmonyOS應用自定義鍵盤解決方案

    自定義鍵盤是一種替換系統默認鍵盤的解決方案,可實現鍵盤個性化交互。允許用戶結合業務需求與操作習慣,對按鍵布局進行可視化重構、設置多功能組合鍵位,使輸入更加便捷和舒適。在安全防護層面,自定義鍵盤可以
    的頭像 發表于 06-05 14:19 ?2400次閱讀

    參考STM32 MPU生態資源利用Yocto構建STM32MP2芯片鏡像運行docker

    X-LINUX-AZURE_Distribution_Package指南 https://wiki.stmicroelectronics.cn/stm32mpu/wiki/X-LINUX-AZURE_Distribution_Package
    發表于 05-10 16:47

    custom.c自定義代碼無法自動保存怎么解決?

    我在custom.c中插入自定義代碼,當我不保存就切換到其他文件時,custom.c中的自定義代碼
    發表于 04-08 06:00

    玩轉C#/LABVIEW,斯撩

    **labview軟件開發 C#軟件開發 C#自定義控件Labview調用 labview和C#組合開發** 斯撩,斯撩
    發表于 04-02 22:44

    如何添加自定義單板

    在開發過程中,用戶有時需要創建自定義板配置。本節將通過一個實例講解用戶如何創建屬于自己的machine,下面以g2l-test.conf為例進行說明。
    的頭像 發表于 03-12 14:43 ?1356次閱讀

    基于Docker鏡像逆向生成Dockerfile

    在本文中, 我們將通過理解Docker鏡像如何存儲數據, 以及如何使用工具查看鏡像方方面面的信息來逆向工程一個Docker鏡像; 以及如何使
    的頭像 發表于 03-10 09:45 ?1549次閱讀
    基于<b class='flag-5'>Docker</b><b class='flag-5'>鏡像</b>逆向生成Dockerfile