介绍 GORM是一个使用Go语言编写的ORM框架.中文文档齐全,对开发者友好,支持主流数据库. GORM官方文档 安装 go get -u github.com/jinzhu/gorm 在kratos中引入GORM框架 在kratos生成的目录internal/data中找到data.go文件, 修改NewData方法并封装数据库客户端 // Data . type Data struct { db *gorm.DB } // NewData . //集成gorm框架 func NewData(…
目录:一.通过Dapr实现一个简单的基于.net的微服务电商系统 二.通过Dapr实现一个简单的基于.net的微服务电商系统(二)--通讯框架讲解 三.通过Dapr实现一个简单的基于.net的微服务电商系统(三)--一步一步教你如何撸Dapr 四.通过Dapr实现一个简单的基于.net的微服务电商系统(四)--一步一步教你如何撸Dapr之订阅发布附录:(如果你觉得对你有用,请给个star)一.电商Demo地址 二.通讯框架地址 前两章介绍了一下Demo本身和Dapr相关以及框架相关的某些设计上的…
今天这篇博文的主要目的是分享一下我设计Saga的实现思路来抛砖引玉,其实Saga本身非常的类似于一个简单的工作流体系,相比工作流不一样的部分在于它没有工作流的复杂逻辑处理机制(比如会签),没有条件分支机制,相对工作流不同的部分在于工作流流程阻塞结束后它多了一个反向补偿的流程.同时相对于工作流通过灵活的配置来实现运行时来讲他的逻辑流转比较固化基本在代码编写阶段就已经完成了流程的配置,编译后运行时一般是不会更改的.下面就从配置.流转.传递模型和异常处理几个方面来讲一下我的实现思路是什么权当抛砖引玉,…
今天开始聊一些微服务的实践,第一块,RPC框架的原理及实践,为什么说要搞定微服务架构,先搞定RPC框架呢? 一.需求缘起 服务化的一个好处就是,不限定服务的提供方使用什么技术选型,能够实现大公司跨团队的技术解耦,如下图: 服务A是欧洲团队提供服务,欧洲团队的技术背景是Java,可以用Java实现服务: 服务B是美洲团队提供服务,可以用C++实现服务: 服务C是中国团队提供服务,可以用Go实现服务: 服务的上游调用方,按照接口.协议即可完成对远端服务的调用. 但实际上,99.9%的公司的团队规模有…
第一章聊了[“为什么要进行服务化,服务化究竟解决什么问题”] 第二章聊了[“微服务的服务粒度选型”] 今天开始聊一些微服务的实践,第一块,RPC框架的原理及实践,为什么说要搞定微服务架构,先搞定RPC框架呢? 一.需求缘起 服务化的一个好处就是,不限定服务的提供方使用什么技术选型,能够实现大公司跨团队的技术解耦,如下图: 服务A是欧洲团队提供服务,欧洲团队的技术背景是Java,可以用Java实现服务: 服务B是美洲团队提供服务,可以用C++实现服务: 服务C是中国团队提供服务,可以用Go实现服务…
今天开始聊一些微服务的实践,第一块,RPC框架的原理及实践,为什么说要搞定微服务架构,先搞定RPC框架呢? 一.需求缘起 服务化的一个好处就是,不限定服务的提供方使用什么技术选型,能够实现大公司跨团队的技术解耦,如下图: 服务A是欧洲团队提供服务,欧洲团队的技术背景是Java,可以用Java实现服务: 服务B是美洲团队提供服务,可以用C++实现服务: 服务C是中国团队提供服务,可以用Go实现服务: 服务的上游调用方,按照接口.协议即可完成对远端服务的调用. 但实际上,99.9%的公司的团队规模有…
kratos简介 Kratos 一套轻量级 Go 微服务框架,包含大量微服务相关功能及工具 本文基于kratos v2.0.3,windows平台,其他系统平台均可借鉴参考 环境搭建 Golang开发包 Protoc编译工具安装 Protoc-gen-go插件安装 开启module模式 并配置GOPROXY 安装kratos go get -u github.com/go-kratos/kratos/cmd/kratos/v2@latest 创建项目 # 创建项目模板 kratos new <Y…
什么是链路追踪 借用阿里云链路追踪文档来解释 分布式链路追踪(Distributed Tracing),也叫 分布式链路跟踪,分布式跟踪,分布式追踪 等等,它为分布式应用的开发者提供了完整的调用链路还原.调用请求量统计.链路拓扑.应用依赖分析等工具,可以帮助开发者快速分析和诊断分布式应用架构下的性能瓶颈,提高微服务时代下的开发诊断效率. 为了应对各种复杂的业务,开发工程师开始采用敏捷开发.持续集成等开发方式.系统架构也从单机大型软件演化成微服务架构.微服务构建在不同的软件集上,这些软件模块可能是…
一  微服务架构概述 1. 单体应用架构存在的问题 结合:https://www.cnblogs.com/jialanshun/p/10637454.html一起看,在该篇博客中搜索“单块架构的优缺点” (1)复杂性高 以笔者经手的一个百万行级别的单体应用为例,整个项目包含的模块非常多.模块的边界模糊.依赖关系不 清晰.代码质量参差不齐.混乱地堆砌在一起整个项目非常复杂.每次修改代码都心惊胆战,甚至添加一个简单 的功能,或者修改一个Bug都会带来隐含的缺陷. (2)技术债务 随着时间推移.需求变…
本文示例基于Spring Boot 1.5.x实现,如对Spring Boot不熟悉,可以先学习我的这一篇:<Spring Boot 1.5.x 基础学习示例>.关于微服务基本概念不了解的童鞋,可以先阅读下始祖Martin Fowler的<Microservice>,本文不做介绍和描述. 一.分布式服务框架的发展 1.1 第一代服务框架 代表:Dubbo(Java).Orleans(.Net)等 特点:和语言绑定紧密 1.2 第二代服务框架 代表:Spring Cloud等 现状:…