Blazor Dapr K8s微服务之服务调用

目录

1.1  Dapr环境配置

1.1.1        在开发机安装Docker Desktop并启用Kubernetes

1.1.2        在开发机安装Dapr Cli

1.1.3        为开发机配置Dapr

1.1.4        为K8s配置Dapr

1.2         创建项目

1.2.1        创建Blazor WebAssembly项目

1.2.2        向解决方案添加Asp.net Core WebApi项目

1.3         直接调用微服务

1.3.1         引用Refit包

1.3.2        修改相关代码

1.4         通过Dapr调用微服务

1.4.1        引用Dapr.Client包

1.4.2        修改相关代码

1.4.3        在Dapr中运行项目

1.5         在K8s中运行项目

1.5.1        添加Docker文件生成镜像

1.5.2        部署Docker镜像到K8s


1.1  Dapr环境配置

1.1.1        在开发机安装Docker Desktop并启用Kubernetes

安装过程略,安装好后效果如下:(左下角两个绿色指示Docker和K8s正在运行)

1.1.2        在开发机安装Dapr Cli

安装命令:

powershell -Command 'iwr -useb https://raw.githubusercontent.com/dapr/cli/master/install/install.ps1 | iex'

将会安装到如下目录:

验证安装命令:

dapr

1.1.3        为开发机配置Dapr

配置命令:

dapr init

验证命令:

dapr --version

命令:docker ps 可以看到多了Dapr自动加了三个容器:

1.1.4        为K8s配置Dapr

配置命令:

dapr init -k

验证命令:

kubectl get pods --namespace dapr-system

可通过命令:

kubectl port-forward deploy/dapr-dashboard --namespace dapr-system 8080:8080

访问Dapr Dashbord

1.2         创建项目

1.2.1        创建Blazor WebAssembly项目

注意选择Asp.net Core hosted

1.2.2        向解决方案添加Asp.net Core WebApi项目

添加完如图,我增加了两个解决方案文件夹BlazorWeb和ServiceAPI以方便区分前端和后端。

启动DaprTest1.Server Project运行:启动端口配置为8000

1.3         直接调用微服务

当前解决方案中,DaprTest1.Client Blazor 项目的Fetch data 功能会调用DaprTest1.Server项目的WeatherForecastController.cs  中的Get接口以获取天气预报信息。

我们需要修改为:在DaprTest1.Server项目的的Get接口不再直接返回天气预报信息,而是调用DaprTest1.ServiceApi1项目的WeatherForecastController中的Get 接口获取天气预报。

1.3.1         引用Refit包

在项目DaprTest1.Server中安装Refit 包。

1.3.2        修改相关代码

在项目DaprTest1.ServiceApi1中引用DaprTest1.Shared项目,并删除原来的Wheatherforcast.cs实体类。

在项目DaprTest1.Server 中新增文件ICallServiceApi1.cs,并添加如下代码:

  1. public interface ICallServiceApi1
  2. {
  3. [Get('/WeatherForecast')]
  4. Task<IEnumerable<WeatherForecast>> GetWeatherForecast();
  5. }

在项目DaprTest1.Server 的Startup.cs 中新增如下代码,其中http://localhost:8001 是ServiceApi1接口访问地址

  1. // 注入httpClient
  2. services.AddHttpClient('HttpClient')
  3. .AddTypedClient(client =>
  4. {
  5. client.BaseAddress = new Uri('http://localhost:8001');
  6. return RestService.For<ICallServiceApi1>(client);
  7. });

修改项目DaprTest1.Server  WeatherForecastController.cs  中的Get接口如下:

  1. public class WeatherForecastController : ControllerBase
  2. {
  3. private readonly ILogger<WeatherForecastController> _logger;
  4. private readonly ICallServiceApi1 _callServiceApi1;
  5. public WeatherForecastController(ILogger<WeatherForecastController> logger, ICallServiceApi1 callServiceApi1)
  6. {
  7. _logger = logger;
  8. _callServiceApi1 = callServiceApi1;
  9. }
  10. [HttpGet]
  11. public async Task<IEnumerable<WeatherForecast>> Get()
  12. {
  13. return await _callServiceApi1.GetWeatherForecast();
  14. }
  15. }

分别启动DaprTest1.Server 和 DaprTest1.ServiceApi1项目,访问http://localhost:8000/ 可看到效果, 效果图略。

1.4         通过Dapr调用微服务

我们需要修改为:在DaprTest1.Server中不直接调用DaprTest1.ServiceApi1的接口地址获取天气预报信息,而是通过Dapr调用DaprTest1.ServiceApi1 的服务ID来获取天气预报信息.

1.4.1        引用Dapr.Client包

在项目DaprTest1.Server中安装Dapr.Client包

1.4.2        修改相关代码

在项目DaprTest1.Server 的Startup.cs 中修改如下代码: 本代码参考了 张善友大神的

Dapr 客户端 搭配 WebApiClientCore 玩耍服务调用

  1. services.AddScoped<InvocationHandler>();
  2. // 注入httpClient
  3. services.AddHttpClient('HttpClient').AddHttpMessageHandler<InvocationHandler>()
  4. .AddTypedClient(client =>
  5. {
  6. client.BaseAddress = new Uri('http://serviceapi1');
  7. return RestService.For<ICallServiceApi1>(client);
  8. });

1.4.3        在Dapr中运行项目

分别在DaprTest1.Server和DaprTest1.ServiceApi1项目中添加文件dapr-selfhosted.ps1

文件内容分别为:

  1. dapr run `
  2. --app-id blazorweb `
  3. --app-port 8000 `
  4. --dapr-http-port 3600 `
  5. --dapr-grpc-port 60000 `
  6. dotnet run
  7. dapr run `
  8. --app-id serviceapi1 `
  9. --app-port 8001 `
  10. --dapr-http-port 3601 `
  11. --dapr-grpc-port 60001 `
  12. dotnet run

PowerShell分别启动DaprTest1.Server 和 DaprTest1.ServiceApi1项目下面的dapr-selfhosted.ps1文件, 访问 http://localhost:8000/ 即可看到效果

1.5         在K8s中运行项目

1.5.1        添加Docker文件生成镜像

分别在DaprTest1.Server和DaprTest1.ServiceApi1项目中添加Docker文件dockerfile, 并修改文件内容如下:

  1. ARG NET_IMAGE=5.0-buster-slim
  2. FROM mcr.microsoft.com/dotnet/aspnet:${NET_IMAGE} AS base
  3. WORKDIR /app
  4. EXPOSE 5000
  5. FROM mcr.microsoft.com/dotnet/sdk:${NET_IMAGE} AS build
  6. WORKDIR /src
  7. COPY ['Server/DaprTest1.Server.csproj', 'Server/']
  8. COPY ['Shared/DaprTest1.Shared.csproj', 'Shared/']
  9. COPY ['Client/DaprTest1.Client.csproj', 'Client/']
  10. RUN dotnet restore 'Server/DaprTest1.Server.csproj'
  11. COPY . .
  12. WORKDIR '/src/Server'
  13. RUN dotnet build 'DaprTest1.Server.csproj' -c Release -o /app/build
  14. FROM build AS publish
  15. RUN dotnet publish 'DaprTest1.Server.csproj' -c Release -o /app/publish
  16. FROM base AS final
  17. WORKDIR /app
  18. COPY --from=publish /app/publish .
  19. ENTRYPOINT ['dotnet', 'DaprTest1.Server.dll']
  1. #See https://aka.ms/containerfastmode to understand how Visual Studio uses this Dockerfile to build your images for faster debugging.
  2. ARG NET_IMAGE=5.0-buster-slim
  3. FROM mcr.microsoft.com/dotnet/aspnet:${NET_IMAGE} AS base
  4. WORKDIR /app
  5. EXPOSE 5000
  6. FROM mcr.microsoft.com/dotnet/sdk:${NET_IMAGE} AS build
  7. WORKDIR /src
  8. COPY ['ServiceApi/DaprTest1.ServiceApi1/DaprTest1.ServiceApi1.csproj', 'ServiceApi/DaprTest1.ServiceApi1/']
  9. COPY ['Shared/DaprTest1.Shared.csproj', 'Shared/']
  10. RUN dotnet restore 'ServiceApi/DaprTest1.ServiceApi1/DaprTest1.ServiceApi1.csproj'
  11. COPY . .
  12. WORKDIR '/src/ServiceApi/DaprTest1.ServiceApi1'
  13. RUN dotnet build 'DaprTest1.ServiceApi1.csproj' -c Release -o /app/build
  14. FROM build AS publish
  15. RUN dotnet publish 'DaprTest1.ServiceApi1.csproj' -c Release -o /app/publish
  16. FROM base AS final
  17. WORKDIR /app
  18. COPY --from=publish /app/publish .
  19. ENTRYPOINT ['dotnet', 'DaprTest1.ServiceApi1.dll']

在解决方案根目录增加文件build-docker-images.ps1 以生成Docker image,文件内容如下:

  1. docker build -t dapr-test1/blazorweb:1.0 -f Server/Dockerfile .
  2. docker build -t dapr-test1/serviceapi1:1.0 -f ServiceApi/DaprTest1.ServiceApi1/Dockerfile .

在解决方案根目录执行build-docker-images.ps1后, 可看到生成的两个镜像:

1.5.2        部署Docker镜像到K8s

在解决方案根目录新建文件夹 Deploy, 放置k8s部署文件

其中deploy.ps1 为部署命令,内容如下:

  1. kubectl apply `
  2. -f namespace.yaml `
  3. -f dapr-config.yaml `
  4. -f blazorweb.yaml `
  5. -f serviceapi1.yaml

部署完成后,可通过端口转发给node看到效果.

代码地址:iamxiaozhuang/dapr-test (github.com)

(0)

相关推荐