.netcore应用在WSL中的容器化部署

简介: 前面,我们讲解了如何在wsl中安装数据库,.netcore运行时,以及如何发布一个.netcore应用,为了构成一个完整的小系列,本节,我们来学习一下,如何将.netcore应用在WSL中容器化。
+关注继续查看

环境准备


1.Docker安装

之前,出过一个docker的小系列,请参考

Docker入门之开篇

Docker Desktop及Kubernetes安装

Docker、k8s使用初体验及Dashboard避坑指南!!

通过以上3篇,可以学习到docker的一些基础知识,包括是什么,为什么,怎么用,其中包括,如何构建镜像、启停容器以及一些需要注意的问题。

更多内容请参考相关系列 

https://blog.csdn.net/xiansenlee/category_9929815.html


2.启用相应功能

因为本节内容是基于wsl的,而且最新版本的docker for windows也是支持wsl2的,所以建议安装wsl2,并在docker中启用wsl,启用如下功能

  • 启用WSL 2作为引擎

      image

  • 在集成项下,选择相应的系统

      image

如果你尚未安装wsl环境,或非wsl2环境,请参考前3篇文章。


至此,我们就可以开始本节的正式的内容了。


创建应用


.netcore应用创建

本次,我们创建一个aspnetcore应用,也就是一个web应用,并将其部署到容器中,

首先,我们通过以下命令创建一个web应用并生成

dotnet new web -o DockerTest
dotnet build DockerTest\DockerTest.csproj


然后,再将项目发布到Release路径下,以便再构建镜像的时候应用


dotnet publish DockerTest\DockerTest.csproj -c Release


然后可以,先试运行一下看看效果

dotnet run DockerTest.csproj
dotnet DockerTest.dll


image


Dockerfile创建

在DockerTest.csproj的同级目录下添加Dockerfile文件并且编辑其内容,这里可以使用vs添加该文件,这样会自带默认内容,我们可以通过修改默认内容来达到我们的目标

image


然后选择目标平台为linux.

#See https://aka.ms/containerfastmode to understand how Visual Studio uses this Dockerfile to build your images for faster debugging.

FROM mcr.microsoft.com/dotnet/aspnet:5.0 AS base
WORKDIR /app
EXPOSE 80
EXPOSE 443

FROM mcr.microsoft.com/dotnet/sdk:5.0 AS build
WORKDIR /src
COPY ["DockerTest.csproj", "."]
RUN dotnet restore "./DockerTest.csproj"
COPY . .
WORKDIR "/src/."
RUN dotnet build "DockerTest.csproj" -c Release -o /app/build

FROM build AS publish
RUN dotnet publish "DockerTest.csproj" -c Release -o /app/publish

FROM base AS final
WORKDIR /app
COPY --from=publish /app/publish .
ENTRYPOINT ["dotnet", "DockerTest.dll"]


在该文件中,我们可以看到容器暴露的端口为80 443,项目基于aspnet:5.0,

此时,我们可以启用docker来构建镜像。

docker build -t dockertest -f Dockerfile .
# -t指定镜像的名称,这里要注意只能是小写
# -f指定Dockerfile的路径 .表示当前路径


此时,我们只需要等待执行完毕即可。

image


当镜像构建完毕后,我们可先查看镜像,然后再运行一个容器

docker images #查看所有镜像

docker run -d -p 5060:80 dockertest
#-p表示映射的端口,将本地的5060映射到容器的80端口

docker run -d -p 4446:80 --name 3334 dockertest
#启动特定名称的容器

docker container ls
#查看全部容器


此时,容器即已成功启动,我们可以通过在浏览器中输入地址来验证。

image

表明我们的容器已经部署成功。


避坑指南

到这里,基本上本节内容已经结束了,但这里提一个坑,不注意的话很容易掉进去,按照我们的思路,我们如果想将容器内的应用通过特定的端口暴露出来,只需要修改Dockerfile中的EXPOSE即可。

但是,注意了!!!!

如果只更改端口,是没办法通过浏览器访问到的,然后通过各种调试你会发现,只有暴露80端口并添加映射的时候才能访问到,这是因为啥呢???

其实,这是因为.netcore默认监听的端口是80,因此,容器启动应用时,其实监听的是80端口,要想通过其他端口访问,我们只需要在Dockerfile中添加ENV变量来指定即可


ENV ASPNETCORE_URLS=http://+:5000 #5000是你想用的端口

然后构建出来的镜像,部署到容器后,即可通过这个端口来访问。


相关文章
|
1天前
|
Rust 算法 C#
C#/.NET/.NET Core优秀项目和框架2023年11月简报
C#/.NET/.NET Core优秀项目和框架2023年11月简报
|
1天前
|
开发框架 .NET API
C#/.NET/.NET Core推荐学习书籍(已分类)
C#/.NET/.NET Core推荐学习书籍(已分类)
|
1天前
|
C# 数据安全/隐私保护
一款实用的.NET Core加密解密工具类库
一款实用的.NET Core加密解密工具类库
|
26天前
|
Windows
基于.Net Core实现自定义皮肤WidForm窗口
基于.Net Core实现自定义皮肤WidForm窗口
28 0
|
26天前
|
开发框架 自然语言处理 搜索推荐
基于.NetCore开源的Windows的GIF录屏工具
基于.NetCore开源的Windows的GIF录屏工具
27 0
|
26天前
|
Oracle 前端开发 数据管理
基于.NetCore+Element开源的前后端分离学生管理系统
基于.NetCore+Element开源的前后端分离学生管理系统
23 0
|
26天前
|
数据采集 开发框架 JavaScript
基于.NET Core内置浏览器窗体应用程序界面框架
基于.NET Core内置浏览器窗体应用程序界面框架
19 0
|
26天前
|
设计模式 程序员 数据处理
问ChatGPT:零基础如何学好.Net Core?
问ChatGPT:零基础如何学好.Net Core?
13 0
|
26天前
|
开发框架 前端开发 NoSQL
推荐一个.Net Core开发的Websocket群聊、私聊的开源项目
推荐一个.Net Core开发的Websocket群聊、私聊的开源项目
21 0
|
26天前
|
SQL 监控 NoSQL
一个.Net Core开发的,撑起月6亿PV开源监控解决方案
一个.Net Core开发的,撑起月6亿PV开源监控解决方案
17 0
推荐文章
更多