gRPC:一个高性能、开源的通用 RPC 框架,基于标准的 HTTP/2 进行传输,默认采用 Protocol Buffers 序列化结构化数据。本文将介绍如何从零搭建一个 Golang 的 gRPC 服务。
准备工作
本文所述的搭建环境基于滴滴云提供的 CentOS 7.2 标准镜像
安装 Golang
下载最新版本的 Golang 安装包
gRPC 依赖于 1.6 以上版本,如果对其他版本有诉求可以在 https://golang.org/dl/
选择下载
$ wget https://dl.google.com/go/go1.11.2.linux-amd64.tar.gz
解压安装包
$ tar zxvf go1.11.2.linux-amd64.tar.gz
配置环境变量
$ mkdir /home/dc2-user/gopath
$ sudo vim /etc/profile.d/go.sh
export GOROOT=/home/dc2-user/go
export GOPATH=/home/dc2-user/gopath
export PATH=$GOROOT/bin:$GOPATH/bin:$PATH
$ source /etc/profile.d/go.sh
检查安装结果
$ go version && go env
出现以下信息则表明安装成功
go version go1.11.2 linux/amd64
GOARCH="amd64"
GOBIN=""
GOCACHE="/home/dc2-user/.cache/go-build"
GOEXE=""
GOFLAGS=""
GOHOSTARCH="amd64"
GOHOSTOS="linux"
GOOS="linux"
GOPATH="/home/dc2-user/gopath"
GOPROXY=""
GORACE=""
GOROOT="/home/dc2-user/go"
GOTMPDIR=""
GOTOOLDIR="/home/dc2-user/go/pkg/tool/linux_amd64"
GCCGO="gccgo"
CC="gcc"
CXX="g++"
CGO_ENABLED="1"
GOMOD=""
CGO_CFLAGS="-g -O2"
CGO_CPPFLAGS=""
CGO_CXXFLAGS="-g -O2"
CGO_FFLAGS="-g -O2"
CGO_LDFLAGS="-g -O2"
PKG_CONFIG="pkg-config"
GOGCCFLAGS="-fPIC -m64 -pthread -fmessage-length=0 -fdebug-prefix-map=/tmp/go-build425133327=/tmp/go-build -gno-record-gcc-switches"
安装 Protocol Buffers
下载最新版本的 Protobuf 安装包
$ wget https://github.com/protocolbuffers/protobuf/releases/download/v3.6.1/protobuf-all-3.6.1.tar.gz
解压安装包
$ tar zxvf protobuf-all-3.6.1.tar.gz
安装 Protobuf
$ cd protobuf-3.6.1/
$ ./configure && make && sudo make install
安装 Protobuf Golang 插件
$ go get -u -v github.com/golang/protobuf/protoc-gen-go
检查安装结果
$ protoc --version && which protoc-gen-go
libprotoc 3.6.1
~/gopath/bin/protoc-gen-go
安装 gRPC
网络环境允许的同学安装 gRPC 非常方便,直接执行以下命令即可安装完成:
$ go get -u -v google.golang.org/grpc