(二)微服务(grpc/grpc消费者)


文章目录

  • 项目地址
  • 一、grpc介绍
    • 1.1 项目初始化
      • 1. 创建grpc项目
      • 2. 项目结构
  • 二、Discount grpc创建
    • 2.1 实体层
      • 1. Coupon实体
    • 2.2 Protos
      • 1. 创建discount.proto
      • 2. 配置proto
      • 3. 创建DiscountService
      • 4. Program里注册服务
    • 2.3 Seed 数据
      • 1. 创建表和Seed数据
      • 2. 自动migration
    • 2.4 更新Docker
      • 1. 更新Docker file
      • 2. 更新Docker compose
  • 三、消费者
    • 3.1 使用grpc消息
      • 1. 创建grpc的引用
      • 2. 使用grpc消息
      • 3. grpc服务注册
    • 3.2 构建docker
      • 1. 重新构建docker file
      • 2. docker compose


项目地址

  • 教程作者:
  • 教程地址:
  • 代码仓库地址:
  • 所用到的框架和插件:
dbt 
airflow

一、grpc介绍

1.1 项目初始化

1. 创建grpc项目

在这里插入图片描述

2. 项目结构

在这里插入图片描述

  • Protos:用来存放协议文件.proto,协议有三部分组成 1. service 2.rpc 3.message

二、Discount grpc创建

2.1 实体层

在这里插入图片描述

1. Coupon实体

namespace Discount.Grpc.Models;
public class Coupon
{public int Id { get; set; }public string ProductName { get; set; } = default!;public string Description { get; set; } = default!;public int Amount { get; set; }
}

2.2 Protos

在这里插入图片描述

1. 创建discount.proto

  • 创建discount的proto,相当于接口
syntax = "proto3"; //类型
option csharp_namespace = "Discount.Grpc";
package discount; //自定义包名//服务定义
service DiscountProtoService {// Discount CRUD Operationsrpc GetDiscount (GetDiscountRequest) returns (CouponModel); //传入GetDiscountRequest返回CouponModelrpc CreateDiscount (CreateDiscountRequest) returns (CouponModel); //传入CreateDiscountRequest返回rpc UpdateDiscount (UpdateDiscountRequest) returns (CouponModel); //传入UpdateDiscountRequestrpc DeleteDiscount (DeleteDiscountRequest) returns (DeleteDiscountResponse); //传入DeleteDiscountRequest
}//GetDiscountRequest消息
message GetDiscountRequest {string productName = 1;
}
//定义CouponModel
message CouponModel {int32 id = 1;string productName = 2;string description = 3;int32 amount = 4;
}
//Create需要传入完整的CouponModel
message CreateDiscountRequest {CouponModel coupon = 1;
}
// UpdateDiscountRequest需要传入完整的CouponModel
message UpdateDiscountRequest {CouponModel coupon = 1;
}
// DeleteDiscountRequest只需要传入productName
message DeleteDiscountRequest {string productName = 1;
}
// DeleteDiscountResponse只需要返回一个bool值
message DeleteDiscountResponse {bool success = 1;
}

2. 配置proto

在这里插入图片描述

  • 配置成功,项目的配置中可以到
  <ItemGroup><Protobuf Include="Protos\discount.proto" GrpcServices="Server" /></ItemGroup>

3. 创建DiscountService

  • DiscountService.cs:实现Proto的,使用Mapster
namespace Discount.Grpc.Services;public class DiscountService(DiscountContext dbContext, ILogger<DiscountService> logger): DiscountProtoService.DiscountProtoServiceBase
{    public override async Task<CouponModel> GetDiscount(GetDiscountRequest request, ServerCallContext context){//使用EF Core从数据库中获取折扣信息var coupon = await dbContext.Coupons.FirstOrDefaultAsync(x => x.ProductName == request.ProductName);if (coupon is null)coupon = new Coupon { ProductName 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/web/82109.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

InfluxQL 数据分析实战:聚合、过滤与关联查询全解析

InfluxQL 作为时序数据库的专用查询语言&#xff0c;在处理时间序列数据时展现出独特优势。本文深入探讨 聚合计算、数据过滤和跨测量关联 三大核心操作&#xff0c;通过真实代码示例展示如何从海量时序数据中提取关键洞察。文中涵盖从基础平均值计算到复杂多维度分析的完整流程…

TDengine 运维——巡检工具(安装前检查)

简介 本文档旨在介绍 TDengine 安装部署前后配套的巡检工具。 相关工具的功能简介&#xff1a; 工具名称功能简介安装前检查部署前对 TDengine 安装部署的依赖要素进行安装前检查安装前预配置部署前对 TDengine 安装部署的依赖要素进行安装前预配置安装部署指定环境安装部署…

大语言模型(LLM)入门 - (1) 相关概念

文章来自&#xff1a;大语言模型(LLM)小白入门自学项目-TiaoYu-1 GitHub - tiaoyu1122/TiaoYu-1: For People! For Freedom!For People! For Freedom! Contribute to tiaoyu1122/TiaoYu-1 development by creating an account on GitHub.https://github.com/tiaoyu1122/TiaoYu…

LearnOpenGL-笔记-其十一

Normal Mapping 又到了介绍法线贴图的地方&#xff0c;我感觉我已经写了很多遍了... 法线贴图用最简单的话来介绍的话&#xff0c;就是通过修改贴图对应物体表面的法线来修改光照效果&#xff0c;从而在不修改物体实际几何形状的前提下实现不同于物体几何形状的视觉效果。 因…

Spring Boot 读取.env文件获取配置

Spring Boot 读取.env文件获取配置 在Resouce 目录下创建.env文件 # DEEP SEEK TOKEN DEEP_SEEK_TOKENyour_deep_seek_key # 阿里云百炼 TOKEN ALI_BAILIAN_TOKENyour_ali_bailian_keyyml引入.env文件 spring:config:import: optional:classpath:.env[.properties]使用.env文…

【C++高级主题】命令空间(三):未命名的命名空间

目录 一、未命名的命名空间的基本概念 1.1 定义与特点 1.2 基本语法 1.3 访问方式 1.4 未命名的命名空间的作用 二、未命名的命名空间与静态声明的比较 2.1 静态声明的作用 2.2 未命名的命名空间的优势 2.3 示例代码比较 2.4. 未命名的命名空间的作用域和链接属性 三…

【Unity】AudioSource超过MaxDistance还是能听见

unity版本&#xff1a;2022.3.51f1c1 将SpatialBlend拉到1即可 或者这里改到0 Hearing audio outside max distance - #11 by wderstine - Questions & Answers - Unity Discussions

多个vue2工程共享node_modules

手头有多个vue2项目&#xff0c;它们每个都需要一个node_modules&#xff0c;拷贝起来超级麻烦。于是想到能否共享一个node_modules呢&#xff1f;&#xff1f; 方法其实挺多&#xff0c;我选择了一个较简单的&#xff1a;符号连接法(win11平台) 创建方法很简单&#xff1a;比…

C语言-10.字符串

10.1字符串 10.1-1字符串 字符数组 char word[] = {‘H’,‘e’,‘l’,‘l’,‘o’,‘!’}; word[0]Hword[1]eword[2]lword[3]lword[4]oword[5]!这不是C语言的字符串,因为不能用字符串的方式做计算 字符串 char word[] = {‘H’,‘e’,‘l’,‘l’,‘o’,‘!’}; word[0]Hwo…

Python训练营打卡Day41(2025.5.31)

知识回顾 数据增强卷积神经网络定义的写法batch归一化&#xff1a;调整一个批次的分布&#xff0c;常用与图像数据特征图&#xff1a;只有卷积操作输出的才叫特征图调度器&#xff1a;直接修改基础学习率 卷积操作常见流程如下&#xff1a; 1. 输入 → 卷积层 → Batch归一化层…

乐观锁:高效并发无锁方案

4.乐观锁 这一章主要介绍乐观锁。前面的管程部分讲了悲观锁&#xff0c;现在做一些总结&#xff1a; 悲观锁&#xff08;Pessimistic Lock&#xff09;&#xff1a;悲观锁认为数据在多线程或多进程环境下总是容易发生冲突/冲突的概率高&#xff0c;所以在数据操作前&#xff…

山海鲸轻 3D 渲染技术深度解析:预渲染如何突破多终端性能瓶颈

在前期课程中&#xff0c;我们已系统讲解了山海鲸两大核心渲染模式——云渲染与端渲染的技术特性及配置方法。为满足复杂场景下的差异化需求&#xff0c;山海鲸创新推出轻3D渲染功能&#xff0c;本文将深度解析该技术的实现原理与操作实践。 一、轻3D功能研发背景 针对多终端协…

【合集】Linux——31个普通信号

Linux普通信号总表&#xff08;1-31&#xff09;​​ ​编号​​信号名​​触发原因​​默认动作​1SIGHUP终端连接断开&#xff08;如SSH会话终止&#xff09;或守护进程重载配置&#xff08;如nginx -s reload&#xff09;终止进程2SIGINT用户输入CtrlC中断前台进程终止进程…

小程序使用npm包的方法

有用的链接 npm init -y 这个命令很重要, 会初始化 package.json 再重新打开微信小程序开发工具 选择工具中npm构建 在程序中引用时在main.js中直接使用包名的方式引用即可 如安装的是generator包&#xff0c;npm构建后就会生成 const myPackage require(***-generato…

腾讯云推出云开发AI Toolkit,国内首个面向智能编程的后端服务

5月28日&#xff0c;腾讯云开发 CloudBase 宣布推出 AI Toolkit&#xff08;CloudBase AI Toolkit&#xff09;&#xff0c;这是国内首个面向智能编程的后端服务&#xff0c;适配 Cursor 等主流 AI 编程工具。 云开发 AI Toolkit旨在解决 AI 辅助编程的“最后一公里”问题&…

系统是win11+两个ubuntu,ubuntu20.04和ubuntu22.04,想删除ubuntu20.04且不用保留数据

在 Ubuntu 22.04 的终端里运行这些命令: 重启电脑&#xff0c;选择启动 Ubuntu 22.04&#xff1b;打开终端&#xff1b;从 lsblk 开始操作。 如果你不确定当前启动的是哪个系统&#xff0c;可以在终端输入&#xff1a; lsb_release -a它会输出&#xff1a; Distributor ID: …

大模型应用开发第三讲:大模型是Agent的“大脑”,提供通用推理能力(如GPT-4、Claude 3)

大模型应用开发第三讲&#xff1a;大模型是Agent的“大脑”&#xff0c;提供通用推理能力&#xff08;如GPT-4、Claude 3&#xff09; 资料取自《大模型应用开发&#xff1a;动手做AI Agent 》。 查看总目录&#xff1a;学习大纲 关于DeepSeek本地部署指南可以看下我之前写的…

第十四篇:MySQL 运维中的故障场景还原与排查实战技巧

本篇通过典型故障场景的还原与分析&#xff0c;帮助你掌握高效、系统的 MySQL 故障排查与应急处理方法&#xff0c;构建稳定可靠的数据库运维体系。 一、故障排查的基本思路 快速定位问题入口&#xff1a; 错误日志、连接报错、监控告警&#xff1b; 确认影响范围&#xff1a…

MySQL 分页查询优化

目录 前言1. LIMIT offset, count 的性能陷阱&#xff1a;为什么它慢&#xff1f;&#x1f629;2. 优化策略一&#xff1a;基于排序字段的“跳跃式”查询 (Seek Method) &#x1f680;3. 优化策略二&#xff1a;利用子查询优化 OFFSET 扫描 (ID Subquery)4. 基础优化&#xff1…

使用curlconverter网站快速生成requests请求包

在python写requests请求的时候&#xff0c;抓包后需要复制粘贴包的内容&#xff0c;然后手动修改和写代码。 最近发现一个好的网站 https://curlconverter.com/python/ 可以复制curl(bash)数据后&#xff0c;直接生成数据包&#xff0c;非常便捷。 举例说明&#xff1a; 选…