> ### 第二例 gRPC使用例子
* 第二例代碼 : 鏈接:[https://pan.baidu.com/s/1VhfvHols\_lXlaf-gIwEcRA](https://pan.baidu.com/s/1VhfvHols_lXlaf-gIwEcRA)密碼:iq75
* 其它gRPC例子 :[https://gitee.com/winnie\_gss/microService](https://gitee.com/winnie_gss/microService)
* 如果是手動下載golang/protobuf, 需要編譯后將protoc-gen-go.exe文件放在bin目錄下
~~~
go get github.com/golang/protobuf/proto
go get github.com/golang/protobuf/protoc-gen-go
go get github.com/grpc/grpc-go 修改文件名: google.golang.org/grpc
go get github.com/golang/net 修改文件名: golang.org/x/net
go get github.com/golang/text 修改文件名: golang.org/x/text
go get github.com/google/go-genproto 修改文件名:google.golang.org/genproto
~~~
* 編譯.proto文件 (protoc生成Go文件: protoc --go\_out=plugins=grpc:. ./article.proto)
~~~
syntax = "proto3";
//留言板
package article;
option java_package = "source-open.com.messagebox.article";
service Article {
//TODO : 留言板列表頁
rpc ArticleList (ArticleListRequest) returns (ArticleListResponse) {
}
//TODO : 添加留言
//TODO : 獲取一條留言
//TODO : 修改一條留言
//TODO : 觀看一條留言
}
enum RPC_RESULT {
RESULT_FAIL = 0; //失敗
RESULT_SUCCESS = 1; //成功
}
enum ARTICLE_SORT {
ORDER_BY_TIME = 0; //最新時間
ORDER_BY_CLICK = 1; //點擊次數
}
message ArticleStruct {
uint32 id = 1; //文章id
string title = 2; //標題
bytes content = 3; //內容
uint32 viewnum = 4; //點擊次數
uint32 time = 5; //發布時間
}
message ArticleListRequest {
ARTICLE_SORT sort = 1; //排序方式
}
message ArticleListResponse {
RPC_RESULT code = 1; //調用結果
string msg = 2; //錯誤消息
repeated ArticleStruct list = 3; //列表數據
}
~~~
* 客戶端代碼
~~~
package main
import (
"context"
"fmt"
_ "github.com/go-sql-driver/mysql"
"github.com/jmoiron/sqlx"
"google.golang.org/grpc"
"google.golang.org/grpc/reflection"
"log"
pb "messagebox/article/article"
"net"
"runtime"
)
type server struct {
}
type ArticleData struct {
Id uint32 `db:"id"`
Title string `db:"title"`
Content []byte `db:"content"`
Viewnum uint32 `db:"viewnum"`
Time uint32 `db:"time"`
}
func (s *server) ArticleList(ctx context.Context, request *pb.ArticleListRequest) (response *pb.ArticleListResponse, err error) {
orderby := "time"
if request.Sort == pb.ARTICLE_SORT_ORDER_BY_TIME {
orderby = "time"
}
if request.Sort == pb.ARTICLE_SORT_ORDER_BY_CLICK {
orderby = "viewnum"
}
host := "localhost"
dbname := "messagebox"
username := "root"
password := "123456"
db, err := sqlx.Open("mysql", username+":"+password+"@tcp("+host+")/"+dbname+"?charset=utf8")
SimplePanic(err)
defer db.Close()
//定義一個結構重新賦值
var list1 []*ArticleData
var list2 []*pb.ArticleStruct
sql := fmt.Sprintf("select id, title, content, viewnum, time from msg_article order by %s desc limit 10", orderby)
err = db.Select(&list1, sql)
SimplePanic(err)
for _, v := range list1 {
var list *pb.ArticleStruct = &pb.ArticleStruct{
Id: v.Id,
Title: v.Title,
Content: v.Content,
Viewnum: v.Viewnum,
Time: v.Time,
}
list2 = append(list2, list)
}
return &pb.ArticleListResponse{Code: pb.RPC_RESULT_RESULT_SUCCESS, Msg: "", List: list2}, nil
}
func main() {
//綁定和監聽一個端口
listen, err := net.Listen("tcp", "127.0.0.1:9005")
if err != nil {
fmt.Println(err)
}
//創建 gRPC 服務器的一個實例(初始化配置)
s := grpc.NewServer()
//綁定一個實現該gRPC的服務
pb.RegisterArticleServer(s, &server{})
//在gRPC上注冊服務
reflection.Register(s)
//啟動服務(阻塞等待客戶端連接)
if err := s.Serve(listen); err != nil {
log.Fatalf("failed to serve: %v", err)
}
}
func SimplePanic(err error) {
if err != nil {
_, file, line, _ := runtime.Caller(1)
fmt.Println(file, line, err)
runtime.Goexit()
}
}
~~~
* 服務端代碼
~~~
package main
import (
"fmt"
"golang.org/x/net/context" //"context"標準包
"google.golang.org/grpc"
pb "messagebox/article/article"
"time"
)
func main() {
conn, err := grpc.Dial("127.0.0.1:9005", grpc.WithInsecure())
if err != nil {
fmt.Println(err)
}
defer conn.Close()
client := pb.NewArticleClient(conn)
ctx, cancel := context.WithTimeout(context.Background(), time.Second*5)
defer cancel()
response, err := client.ArticleList(ctx, &pb.ArticleListRequest{Sort: pb.ARTICLE_SORT_ORDER_BY_TIME})
if err != nil {
fmt.Println(err)
}
fmt.Println(response)
}
~~~
- 第一例 留言板
- 第二例 gRPC使用例子
- 第三例 基于go-micro做服務注冊和服務發現
- 第四例 聊天室
- 第五例 工具庫 第五例 并發安全字典
- dao
- common
- common.go
- config
- config.go
- gorm
- grom.go
- sqlx
- sqlx.go
- kafka
- kafka.go
- log
- log.go
- log2.go
- redis
- redis.go
- zookeeper
- zookeeper.go
- init
- main.go
- 第六例 原生sql操作
- 第七例 sqlx操作
- 第八例 Redis數據庫(gomodule/redigo)
- 第九例 Redis消息隊列
- 第十例 Redis集群連接
- 第十一例 Zookeeper操作
- 第十二例 Kafka操作
- 第十三例 NSQ操作
- 第十四例 二分查找
- 第十五例 交換排序 - 冒泡排序
- 第十六例 插入排序 - 直接插入排序
- 第十七例 插入排序 - 希爾排序
- 第十八例 交換排序 - 快速排序
- 第十九例 算法求解應用
- 第二十例 pprof性能分析
- 第二一例 CPU信息采集
- 第二二例 Heap信息采集
- 第二三例 Http信息采集
- 第二四例 單元測試(功能測試)
- 第二五例 基準測試(壓力測試/性能測試)
- 第二六例 gdb調試
- 第二七例 json序列化和反序列化
- 第二八例 protobuf序列化和反序列化
- 第二九例 包管理工具 go vendor
- 第三十例 包管理工具 go mod
- 第三一例 zip壓縮
- 第三二例 交叉編譯
- 第三三例 線上環境部署
- 第三四例 業務:實現固定周期維護
- 第三五例 聊天室(精簡版)
- 第三六例 并發安全字典
- 第三七例 導出Excel表格
- 第三八例 導出CSV表格
- 第三九例 聊天室(高并發)
- 第四十例 JWT (Json Web Token)
- 第四一例 雪花算法生成 Id
- 第四二例 對稱加密 AES
- 第四三例 非對稱加密 RSA
- 第四四例 簽名算法 SHA1
- 第四五例 數據庫操作 gorm
- 第四六例 數據庫操作 gorm 集合
- 數據庫連接和創建表
- 查詢 - 分頁
- 查詢所有數據
- 查詢單條數據
- 插入一條或多條數據
- 更新一條或多條數據
- 更新一條或多條數據(有零值)
- 第四七例 RSA(MD5WithRSA 算法)簽名和驗簽方式
- 第四八例 線上部署腳本
- 第四九例 Elasticsearch
- 第五十例 對象池
- 第五十一例 相關閱讀