当前位置: 首页 > news >正文

C++GO语言微服务和服务发现

目录

01 03-go-micro简介

02 04-服务发现的简单认识

03 05-consul的安装

04 06-consul常用的命令

05 07-注册服务到consul并验证

06 08-consul健康检查

07 09-consul结合grpc使用-上(只实现grpc远程调用)

08 10-consul结合grpc使用-中(注册服务到consul)

09 11-consul结合grpc使用-下(client从consul获取服务

10 12-consul结合grpc使用-小结

11 13-服务注销


01go-micro简介

# go-Micro 框架## 创建 micro 服务命令:micro new --type srv test66框架默认自带服务发现:mdns。使用consul服务发现:1. 初始consul服务发现: consulReg := consul.NewRegistry()2. 在 NewService 中 添加 服务。 micro.Registry(consulReg ),## 使用 go-micro框架 创建 客户端命令:micro new --type web test77### 补充 http 相关知识:- 路由器:资源分发
- 路由:请求分发。- service.HandleFunc("/test77/call", handler.Test77Call)- 将 /test77/call 这个请求,通过 回到函数 Test77Call() 处理。
- URL:- 组成:https://ip+port/资源路径- https://ip+port/   找到 pc机,找到 对应进程- 资源路径:在代码中,称之为路由。- “/ ” : 代表 主机上进程 对应的默认资源。- http协议,自动找当前目录下的 index.html 文件,做默认页面。

02 服务发现的简单认识

### go-micro 框架 测试使用 分析图![1581907970023](课堂笔记-03.assets/1581907970023.png)# gin 框架go常见的web框架:gin、beego、echo、Iris 。。。### 实现简单的 web http 常用方法与 数据库访问 一一对应。- GET —— 查 —— 获取数据
- Post —— 增 —— 增加数据
- Put —— 改 —— 更新数据
- Delete —— 删 —— 删除数据​	

03 consul的安装

### 使用 gin 框架创建最简单的web ```gofunc main()  {// 1. 初始化路由 -- 官网:初始化 web 引擎router := gin.Default()// 2. 做路由匹配router.GET("/", func(context *gin.Context) {context.Writer.WriteString("hello world!")})// 3. 启动运行router.Run(":8080")
}
```### gin 框架的客户端 与 微服务 对接1.  封装回调函数, 给 router.Get() 设置2.  拷贝 微服务的 “ 密码本” protobuf 到  web 中3.  修改 protobuf文件的 包名。  test66别名  “test66web/proto/test66”4.  实现 回调函数:1. 初始化客户端。    microClient := NewTeset66Sevice(服务名,client.DefaultClient)2. 调用远程服务。    resp, err := microClient.Call(context.TODO, &test66.Request{​						       })3. 将 返回的 数据, 显示到 浏览器。 context.Writer.WriteString(resp.Msg);```go
package mainimport ("github.com/gin-gonic/gin""fmt"test66 "test66web/proto/test66"     // test66 为包的别名."github.com/micro/go-micro/client""context"
)func CallRemote(ctx *gin.Context)  {// 1. 初始化客户端microClient := test66.NewTest66Service("go.micro.srv.test66", client.DefaultClient)fmt.Println()// 2. 调用远程服务resp, err := microClient.Call(context.TODO(), &test66.Request{Name:"xiaowang",})if err != nil {fmt.Println("call err:", err)return}// 为了方便查看, 在打印之前将结果返回给浏览器ctx.Writer.WriteString(resp.Msg)fmt.Println(resp, err)
}

04 consul常用的命令

func main()  {// 1. 初始化路由 -- 官网:初始化 web 引擎router := gin.Default()// 2. 做路由匹配router.GET("/", CallRemote)// 3. 启动运行router.Run(":8080")
}```![1581911529452](课堂笔记-03.assets/1581911529452.png)### 指定 consul 服务发现到 go-micro 服务和 gin 框架客户端中- mdns服务发现: (组播)支持的服务,必须是本地服务, 局域网内的服务。#### 修改 go-micro 微服务1. consulReg := consul.NewRegistry()   初始化 consul服务发现
2. 添加 服务 service := micro.NewService(micro.Name("go.micro.srv.test66"),micro.Registry(consulReg),micro.Version("latest"),)3. 在命令行,执行 consul agent -dev

05 注册服务到consul并验证

#### 修改 gin 框架 web服务 (客户端)1.  consulReg := consul.NewRegistry()   初始化 consul服务发现
2.  microClinet := micro.NewService( micro.Registry(consulReg ) )
3.  test66.NewTest66Service(“服务名”,microClinet.Client() )测试:浏览器键入: 192.168.6.108:8080  ——> hello xiaowang ![1581922279521](课堂笔记-03.assets/1581922279521.png)# REST REST全称是Representational State Transfer:  表述性 状态 转义本质:一种代码设计风格。  web开发中常用。——遵循风格!使用:一般以 http 4 种请求方法, 来确定对某一资源(URI:标识符。名词)的 固定操作。- 获取数据:GET
- 添加数据:POST
- 修改数据:PUT
- 删除数据:Delete​		满足 REST 设计风格的, 称之为 “RESTful”

06 consul健康检查

# MVC- 是一种常见的 “代码组织架构”, 可以在开发中,对数据进行处理并解耦。- model:模型。 处理数据库相关的文件。- veiw:视图。处理显示相关的文件。 网站:html- controller:控制器。处理具体业务!  联动 m 和 v
- MVC 与语言无关!是常见的 代码组织架构。![1581924280038](课堂笔记-03.assets/1581924280038.png)# 项目准备1. 准备项目环境。1. 创建项目目录  web、service2. 在 web 端 使用 MVC3. 创建项目常用目录: conf 配置文件、utils 工具类、bin可执行文件、test测试目录4. 导入 异常处理error.go5. 导入前端资源 html/ 到 view/ 中2. 开发项目1. 开发 微服务端2. 开发 web 服务(客户端)### http协议错误5 类:1. 1xx	   100		请求成功,需要继续发送请求
2. 2xx       200   201  202    请求被成功接收。
3. 3xx       300 301               请求的资源,指定到对应的 URI上
4. 4xx       404  403              请求端错误
5. 5xx       500 501  502      服务端错误### 网站开发形式:1. 前后端不分离- 前端只负责页面创建,不负责加载数据。- 后台负责主要业务书写,数据操作、加载。—— 需要后端会 web。 css 、js、h5 
2. 前后端分离- 前端负责页面创建 和 数据的加载。- 后端只负责数据处理。  —— 节省时间:服务器优化     1)健壮性 2)并发性。

07 consul结合grpc使用-上(只实现grpc远程调用)

# 获取 session 1.  在 web/main.go 中 , 跟据 gin 框架 使用static() , 设置访问路径
2. F12 浏览器中,查看 NetWork 中 Headers 和  Respose。 得到 url
3. 查看 《接口文档.doc》, 获取 url 、错误码、错误处理函数。
4. 在 web/ 下 遵循 MVC 设计模式创建  controller 目录。添加 user.go
5. 根据 《接口文档.doc》实现错误函数。1. resp[“errno”]2. resp[“errmsg”]3. ctx.Json(200, resp)  // 将 错误消息,进行序列化。返回给浏览器。
6.  url寻址时,都是从 “/‘’ 开始, 产生歧义- router.Static(“/”)    --- 修改为: router.Static(“/home”)7. 浏览器测试: IP:8080/home 

08 consul结合grpc使用-中(注册服务到consul)

09 consul结合grpc使用-下(client从consul获取服务

10 consul结合grpc使用-小结

11 服务注销

http://www.xdnf.cn/news/335125.html

相关文章:

  • mac连接lniux服务器教学笔记
  • c++中的引用
  • C# 方法(输出参数)
  • x64dbg技巧
  • 如何在Vue-Cli中使用Element-UI和Echarts和swiper插件(低版本)
  • 视频编解码学习7之视频编码简介
  • 红黑树详解初版
  • Java数据结构——Queue
  • 使用Deployment部署运行Nginx和Apache服务
  • Java复习笔记-基础
  • Spark缓存--cache方法
  • leetcode 3342. 到达最后一个房间的最少时间 II 中等
  • ​无线手持吸尘器无刷BLDC驱动方案功能介绍---【其利天下】
  • Crawl4AI:高效的开源 Python 网页爬取与数据提取库
  • php java go python面向对象的设计原则和常用设计模式
  • 构建高可维护、易测试的异步任务系统:基于 Celery + Redis + Eventlet 的模块化架构实践
  • AI日报 · 2025年5月08日|Stripe发布全球首个支付AI基础模型
  • 论坛系统开发(0-1) (上 前置知识介绍)
  • 解锁跨平台开发的新时代——Compose Multiplatform
  • Python3 上下文管理器:优雅管理资源的艺术
  • JVM运行时数据区域(Run-Time Data Areas)的解析
  • Linux系统管理与编程15:vscode与Linux连接进行shell开发
  • HTTP Error 500.31 - Failed to load ASP.NET Core runtime
  • GuPPy-v1.2.0安装与使用-生信工具52
  • Asp.Net Core IIS发布后PUT、DELETE请求错误405
  • Docker封装深度学习模型
  • 从知识图谱到精准决策:基于MCP的招投标货物比对溯源系统实践
  • Linux:libc库简单设计
  • Java响应实体【R】
  • JavaScript 性能优化全攻略:从基础到实战