zoukankan      html  css  js  c++  java
  • 编写第一个 .NET 微服务

    本文翻译自.NET官网 .NET Tutorial - Hello World Microservice

    介绍

    本文的目的是:通过创建一个返回列表的简单服务,并在 Docker 容器中运行该服务,让您熟悉使用 .NET 创建微服务的构建过程。

    安装 .NET SDK

    要开始构建 .NET 应用程序,首先下载并安装 .NET Core SDK(软件开发工具包)。

    根据操作系统的类型下载并安装对应版本的 .NET Core SDK v3.1:.NET SDK (64-位).NET SDK (32-位)

    全部 .NET SDK 下载页面(Download .NET SDKs for Visual Studio):
    https://dotnet.microsoft.com/download/visual-studio-sdks

    检查安装是否正确

    .NET SDK 安装完成后,打开一个命令提示符窗口并运行以下命令:

    dotnet
    

    如果命令运行时,打印出的信息是介绍如何使用 dotnet,说明安装正确。

    创建您的服务

    创建一个应用

    在命令提示符窗口运行以下命令:

    dotnet new webapi -o myMicroservice --no-https
    
    cd myMicroservice
    

    第一行中 dotnet 命令创建了一个 webapi(一个 REST API 终端)类型的“新”应用。

    • 参数 -o 创建一个名为 myMicroservice 的目录,用于存储应用程序。
    • 标记 --no-https 创建一个不需要 HTTPS 证书就可以运行的应用程序,以便简化部署。

    使用 cd myMicroservice 命令进入新建应用程序的目录。

    生成的代码

    可以看到,在 myMicroservice 目录中创建了几个文件,为您提供了一个可以运行的简单服务。

    • myMicroservice.csproj 定义了项目引用的库等。
    • Startup.cs 包含应用程序启动时加载的所有设置和配置。
    • Controllers/WeatherForecastController.cs 有一个简单 API 的代码,可以返回未来 5 天的天气预报(模拟数据)。

    Controllers/WeatherForecastController.cs 文件中代码:

    [ApiController]
    [Route("[controller]")]
    public class WeatherForecastController : ControllerBase
    {
        private static readonly string[] Summaries = new[]
        {
            "Freezing", "Bracing", "Chilly", "Cool", "Mild", "Warm", "Balmy", "Hot", "Sweltering", "Scorching"
        };
    
        private readonly ILogger<WeatherForecastController> _logger;
    
        public WeatherForecastController(ILogger<WeatherForecastController> logger)
        {
            _logger = logger;
        }
    
        [HttpGet]
        public IEnumerable<WeatherForecast> Get()
        {
            var rng = new Random();
            return Enumerable.Range(1, 5).Select(index => new WeatherForecast
            {
                Date = DateTime.Now.AddDays(index),
                TemperatureC = rng.Next(-20, 55),
                Summary = Summaries[rng.Next(Summaries.Length)]
            })
            .ToArray();
        }
    }
    

    运行您的服务

    确保命令提示符定位在 myMicroservice 目录中,运行以下命令:

    dotnet run
    

    命令完成后,在浏览器中打开『http://localhost:5000/WeatherForecast』

    The API endpoint returns JSON data containing weather forecast information

    恭喜,您已经运行了一个简单的服务。

    安装 Docker

    Docker 是一个平台,它可以让你将一个应用程序及其配置和依赖项组合成一个叫作容器的单独的、可独立部署的单元。

    下载并安装 Docker Desktop

    请参阅我之前翻译的 Docker 快速入门(一)

    检查 Docker 是否可用

    安装完成后,打开一个新的命令提示符窗口并运行以下命令:

    docker --version
    

    若命令运行后,显示一个版本信息,那么表示 Docker 安装成功了。

    添加 Docker 元数据

    要运行 Docker 镜像,需要一个 Dockerfile —— 一个文本文件,其中包含如何将应用构建为 Docker 镜像的指令。Docker 镜像包含将您的应用作为 Docker 容器运行所需的所有内容。

    添加 Dockerfile 文件

    myMicroservice 目录中,使用文本编辑器(推荐使用 Visual Studio Code)创建一个名为 Dockerfile 的文件,包含以下内容:

    FROM mcr.microsoft.com/dotnet/core/sdk:3.1 AS build
    WORKDIR /src
    COPY myMicroservice.csproj .
    RUN dotnet restore
    COPY . .
    RUN dotnet publish -c release -o /app
    
    FROM mcr.microsoft.com/dotnet/core/aspnet:3.1
    WORKDIR /app
    COPY --from=build /app .
    ENTRYPOINT ["dotnet", "myMicroservice.dll"]
    

    注意:确保将文件命名为 Dockerfile(没有扩展名),而不是 Dockerfile.txt 或其他名称。

    添加 .dockerignore 文件(可选的)

    .dockerignore 文件可以减少 docker build 过程中使用的文件集,文件越少则构建越快。

    在文本编辑器中创建一个名为 .dockerignore 的文件(这个文件类似于 .gitignore 文件,如果你熟悉的话),包含以下内容:

    Dockerfile
    [b|B]in
    [O|o]bj
    

    创建 Docker 镜像

    运行以下命令:

    docker build -t mymicroservice .
    

    docker build 命令使用 Dockerfile 构建 Docker 镜像。

    • 参数 -t mymicroservice 告诉命令标记(或命名)镜像为 mymicroservice
    • 最后一个参数告诉命令使用哪个目录来查找 Dockerfile (. 指定当前目录)。

    译者注:
    如果是第一次在本机上构建基于 mcr.microsoft.com/dotnet/core/sdk:3.1mcr.microsoft.com/dotnet/core/aspnet:3.1 的镜像,构建 mymicroservice 镜像将会是一个漫长的过程,因为从官方 Docker 注册表拉取镜像实在是太慢了!耐心等待,终会成功的,我已经实践过了。

    等待镜像构建完成,可以运行下面的命令来查看计算机上可用的所有镜像的列表,包括您刚刚创建的 mymicroservice 镜像。

    docker images
    

    运行 Docker 镜像

    您可以使用下面的命令在容器中运行您的应用:

    docker run -it --rm -p 3000:80 --name mymicroservicecontainer mymicroservice
    

    可选地,您可以在单独的新的命令提示符窗口中输入下面的命令查看正在运行的容器:

    docker ps
    

    在运行 docker run 命令后,您可以在浏览器中输入 URL『http://localhost:3000/WeatherForecast』 来访问正在容器中运行的应用程序。

    The API endpoint returns JSON data containing weather forecast information

    恭喜!您已经成功地创建了一个可以使用 Docker 容器部署和缩放的小型、独立的服务。

    以上这些就是微服务的基本构建块。


    作者 : Microsoft 官网
    译者 : 技术译民
    出品 : 技术译站
    链接 : 英文原文

  • 相关阅读:
    Bash简单介绍
    三大框架常遇的错误:hibernate : object references an unsaved transient instance
    第二十八篇: 学习笔记
    oracle表空间查询维护命令大全之二(undo表空间)
    JSON 数据的系统解析
    MySQL字符串函数
    HDU ACM 1025 Constructing Roads In JGShining&#39;s Kingdom-&gt;二分求解LIS+O(NlogN)
    实时竞价RTB广告平台_传漾科技_中国领先的智能数字营销引擎
    秒聘网-产品经理招聘,免费、专注、极速
    “小鸟推送”从DSP做到营销效果最大化,挂牌新三板后正在寻求B轮定增
  • 原文地址:https://www.cnblogs.com/ittranslator/p/13624613.html
Copyright © 2011-2022 走看看