golang快速入门--RPC-微服务

微服务

  • 把每一个功能抽取成一个一个的服务
  • 微服务之间访问是轻量级的,RPC

如何通信

  • 网络传输,用RPC(远程过程调用)
    • HTTP传输,GET POST PUT DELETE
    • 基于TCP,更靠底层,RPC基于TCP,Dubbo(18年底改成支持各种语言),Grpc,Thrift
  • 调用谁,用服务注册和发现(分布式数据同步:etcd,consul,zk)

微服务层

  • 使用服务框架实现业务逻辑

RPC

简介

  • 远程过程调用(Remote Procedure Call,RPC)是一个计算机通信协议
  • 该协议允许运行于一台计算机的程序调用另一台计算机的子程序,而程序员无需额外地为这个交互作用编程

简单的RPC案例

服务端(创建一个计算器服务)

package main

import (
	"fmt"
	"log"
	"net/http"
	"net/rpc"
)

func main() {
	rpc.Register(new(Cal)) // 注册一个服务
	rpc.HandleHTTP()       // 服务处理绑定到http协议上
	// 监听服务
	if err := http.ListenAndServe(":8000", nil); err != nil {
		log.Panicln(err)
	}
}

// Params 参数
type Params struct {
	A int
	B int
}

// Cal (计算)定义一个接口结构体对象
type Cal struct{}

// Add 为Cal添加求和方法
func (o Cal) Add(p *Params, r *int) error {
	fmt.Println("ok")
	*r = p.A + p.B
	return nil
}

客户端(通过rpc函数调用服务)

package main

import (
	"fmt"
	"log"
	"net/rpc"
)

func main() {
	conn, err := rpc.DialHTTP("tcp", ":8000")
	if err != nil {
		log.Panicln(err)
	}
	var result int
	if err := conn.Call("Cal.Add", Params{A: 1, B: 3}, &result); err != nil {
		log.Panicln(err)
	}
	defer conn.Close()
	fmt.Println("result = ", result)
}

type Params struct {
	A int
	B int
}

总结

  • 客户端根据rpc协议进行网络通信
  • 客户端是可以跨语言通信的
  • 既然跨语言,那么服务之间需要一个服务发现,客户端从服务发现服务中获取服务
  • 综上所诉,对于一个平台不通功能都将注册进注册中心,客户端从注册中心发现服务
  • 前端怎么调用?
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值