当前位置:   article > 正文

Blazor+Dapr+K8s微服务之服务调用_refit blazor

refit blazor

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
  1. dapr run `
  2. --app-id serviceapi1 `
  3. --app-port 8001 `
  4. --dapr-http-port 3601 `
  5. --dapr-grpc-port 60001 `
  6. 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看到效果.

 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/从前慢现在也慢/article/detail/676812
推荐阅读
相关标签
  

闽ICP备14008679号