中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么啟動http服務和rpc服務

發布時間:2020-06-04 10:15:13 來源:億速云 閱讀:643 作者:Leah 欄目:編程語言

怎么啟動http服務和rpc服務?這篇文章運用了實例代碼展示,代碼非常詳細,可供感興趣的小伙伴們參考借鑒,希望對大家有所幫助。

開啟http服務

老規矩,先添加配置,順便把rpc的配置也寫進去,config.json:

  "http_config": {
    "addr": ":8080"
  },
  "rpc_config": {
    "addr": ":8081"
  }

config.go:

type HttpConfig struct {
    Addr string `json:"addr"`
}

type RpcConfig struct {
    Addr string `json:"addr"`
}

接著,來看看process/http/http.go的內容:

package http

import (
    "github.com/gin-gonic/gin"
    "go.uber.org/zap"
    "os"
)

var engine *gin.Engine

//啟動http服務
func StartHttpServer(addr string) {
    engine = gin.Default()
    Route()
    if err := engine.Run(addr); err != nil {
        zap.Error(err)
        os.Exit(1)
    }
}

//路由
func Route() {
    engine.GET("/server_time", GetServerTime)
}

我用了gin來提供http服務,具體路由分發的方法寫在了dispatch.go里面,這里寫了一個簡單的示例接口,獲取服務器系統時間:

type Request struct {
}

type Response struct {
    Code int         `json:"code"`
    Msg  string      `json:"msg"`
    Data interface{} `json:"data"`
}

func GetServerTime(ctx *gin.Context) {
    resp := Response{}
    resp.Data, resp.Code, resp.Msg = controller.GetServerTime()
    ctx.JSON(resp.Code, resp)
}

我定義了一個請求結構體和返回結構體來統一一下,請求和返回的數據格式。GetServerTime調用了controller.GetServerTime()方法。我希望有個數據處理層來隔離接口。

rpc服務

我現在想對外提供rpc服務,和http服務提供一樣的數據。我用的是grpc。

使用grpc

  1. 從 https://github.com/google/protobuf/releases下載對應的安裝包,然后解壓,把protoc的執行文件放到PATH里;

  2. 安裝 golang protobuf
    go get -u github.com/golang/protobuf/proto // golang protobuf 庫
    go get -u github.com/golang/protobuf/protoc-gen-go //protoc 轉換go工具

  3. 安裝 gRPC-go
    go get google.golang.org/grpc

編寫protobuf文件

我在process/rpc/server目錄下,創建了一個server.proto文件來定義接口協議:

syntax = "proto3"; //語法聲明

package server; //包名

service Server {
    rpc GetServerTime (ServerTimeRequest) returns (ServerTimeResponse);
}

message ServerTimeRequest {
}

message ServerTimeResponse {
    uint32 code = 1;
    string msg = 2;
    ServerTimeResponseData data = 3;
}

message ServerTimeResponseData {
    uint64 server_time = 1;
}

接著,進到process/rpc/server目錄,并執行生成go文件的命令,會生成一個go文件:

$ cd process/rpc/server
$ protoc --go_out=plugins=grpc:. server.proto

然后,我們寫一下我們的rpc服務端:

package rpc

import (
    "context"
    "github.com/TomatoMr/awesomeframework/process/controller"
    "github.com/TomatoMr/awesomeframework/process/rpc/server"
    "net"
)
import "google.golang.org/grpc"

type Server struct {
}

//啟動rpc服務
func StartRpcServer(addr string) {
    lis, err := net.Listen("tcp", addr)
    if err != nil {

    }
    s := grpc.NewServer() 
    server.RegisterServerServer(s, &Server{})
    if err := s.Serve(lis); err != nil {

    }
}

func (rp *Server) GetServerTime(ctx context.Context, request *server.ServerTimeRequest) (*server.ServerTimeResponse, error) {
    data, code, msg := controller.GetServerTime()
    resp := &server.ServerTimeResponse{}
    respData := &server.ServerTimeResponseData{}
    resp.Msg = msg
    resp.Code = uint32(code)
    respData.ServerTime = uint64(data.ServerTime)
    resp.Data = respData
    return resp, nil
}

調整入口文件

main.go

    //啟動http服務
    go http.StartHttpServer(config.GetConfig().HttpConfig.Addr)

    //啟動rpc服務
    go rpc.StartRpcServer(config.GetConfig().RpcConfig.Addr)

    logger.GetLogger().Info("Init success.")

    select {}

main.go添加了這幾行代碼,以go routine啟動了http服務和rpc服務,因此,在最后用一個select來阻塞程序退出。

測試一下

寫一個rpc客戶端的test如下:

package main

import (
    "context"
    "github.com/TomatoMr/awesomeframework/process/rpc/server"
    "google.golang.org/grpc"
    "log"
    "time"
)

const (
    Addr = "127.0.0.1:8081"
)

func main() {
    conn, err := grpc.Dial(Addr, grpc.WithInsecure())
    if err != nil {
        log.Fatalf("did not connect: %v", err)
    }
    defer conn.Close()
    c := server.NewServerClient(conn)

    ctx, cancel := context.WithTimeout(context.Background(), time.Second)
    defer cancel()
    r, _ := c.GetServerTime(ctx, &server.ServerTimeRequest{})

    log.Printf("Data: %v", r.Data.ServerTime)
}

編譯:

$ go build

運行:

$ awesomeframework --config=./config/config.json

測試:

$ curl localhost:8080/server_time
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
100    56  100    56    0     0  18666      0 --:--:-- --:--:-- --:--:-- 28000
{"code":200,"msg":"","data":{"server_time":1579597891}}

測試rpc接口的文件我放在了process/rpc/test/request.go

$ go run request.go
2020/01/21 17:18:08 Data: 1579598288

關于就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

宁安市| 本溪| 十堰市| 扎囊县| 读书| 济源市| 汝南县| 嫩江县| 左云县| 陇南市| 利川市| 铁岭县| 古蔺县| 龙川县| 东丽区| 福建省| 柳林县| 项城市| 疏勒县| 铜陵市| 眉山市| 临颍县| 兴城市| 普兰县| 滨州市| 阿瓦提县| 万宁市| 伊金霍洛旗| 上饶县| 贡山| 麻城市| 哈密市| 伊宁市| 连云港市| 阜康市| 娄底市| 宝山区| 灵武市| 桐城市| 济宁市| 丘北县|