protocol buffers(protobuf)安装教程
本文按照mac讲解protobuf的安装,windows上比较好安装按照mac的基本流程就可以安装成功,mac上的安装有的时候比较容易出现问题
一、通过brew的方式安装(仅Mac)
需要mac中存在brew,输入命令:brew --version 查看是否存在brew,如不存在就进行安装,安装方法直接百度即可。
1.安装protobuf命令:brew install protobuf
安装指定版本的protobuf命令:brew install protobuf@3.7
2.查看是否安装成功命令:protoc --version
user@C02FP58GML7H bin % protoc --version
libprotoc 3.20.1
3.卸载protobuf命令:brew uninstall protobuf
4.brew安装安装路径
- 配置文件在:
/usr/local/etc下 - 安装文件在:
/usr/local/Cellar下 - 二进制可执行程序的软连接在:
/usr/local/bin下
注意:一般情况通过brew install安装应用最先是放在/usr/local/Cellar/目录下,有些应用会自动创建软链接放在/usr/bin或者/usr/sbin,同时也会将整个文件夹放在/usr/local,忘记的时候或者找不到的时候,可以使用brew list 软件名确定安装位置
二、源码编译方式安装(Mac、Linux)
1.从官方仓库地址下载
protobuf-all-21.6.tar.gz(当前最新版)
2.解压到目的目录下:tar -zxvf protobuf-all-21.6.tar.gz
3.进入到解压后的源码目录下:cd protobuf-all-21.6
4.检测安装环境是否满足条件,生成Makefile:./configure --prefix=/usr/local/protobuf
5.经典的编译安装步骤:make && make install
6.添加环境变量:(Linux需要按照linux的方式配置环境变量)
cd ~
export PROTOBUF=/usr/local/protobuf
export PATH=$PROTOBUF/bin:$PATH
vim .bash_profile
source .bash_profile
7.查看是否安装成功命令:protoc --version
三、压缩包解压方式安装(适合Mac、Windows、Linux)
1.从官方仓库地址下载
- 适用Windows 64位:protoc-21.6-win64.zip
- 适用Windows 32位:protoc-21.6-win32.zip
- 适用Mac 英特尔Intel 64位:protoc-21.6-osx-x86_64.zip
- 适用Mac ARM 64位:protoc-21.6-osx-aarch_64.zip
- 适用Linux 64位:protoc-21.6-linux-x86_64.zip
2.解压到目的目录下
目录结构如下:
- bin目录下的protoc是可执行文件
- include目录下的是gogle定义的.protoc文件,我们使用的就是
import "google/protobuf/timestamp.proto"
user@C02FP58GML7H protoc-3.20.1-osx-x86_64 % tree
.
├── bin
│ └── protoc
├── include
│ └── google
│ └── protobuf
│ ├── any.proto
│ ├── api.proto
│ ├── compiler
│ │ └── plugin.proto
│ ├── descriptor.proto
│ ├── duration.proto
│ ├── empty.proto
│ ├── field_mask.proto
│ ├── source_context.proto
│ ├── struct.proto
│ ├── timestamp.proto
│ ├── type.proto
│ └── wrappers.proto
└── readme.txt
~/.bash_profile (一般在这个文件中添加用户级环境变量)
3.添加环境变量
Mac配置环境变量的地方:
- /etc/profile(建议不修改这个文件):全局(公有)配置,不管是哪个用户,登录时都会读取该文件。
- /etc/bashrc(一般在这个文件中添加系统级环境变量):全局(公有)配置,bash shell执行时,不管是何种方式,都会读取此文件。
- ~/.bash_profile(一般在这个文件中添加用户级环境变量):每个用户都可使用该文件输入专用于自己使用的shell信息,当用户登录时,该文件仅仅执行一次!
- 注意:但有时在.bash_profile文件中的环境变量会无效
当mac中存在zsh,修改环境变量就要在~/.zshrc中修改,本教程就是在此文件中加入如下配置,=后面是文件加压后的路径,自行修改:
alias protoc=/Users/user/Desktop/workspace2/protoc-3.20.1-osx-x86_64/bin/protoc
刷新配置使修改立即生效,需要执行:
source ~/.zshrc
4.Linux中同理适用对应的修改添加环境变量的方法,然后刷新配置,修改方法百度即可
5.Windows中只需要在图形化的配置中加入环境变量即可,具体实现直接百度即可
protocol buffers(protobuf)安装教程的更多相关文章
- Protocol Buffers(Protobuf)开发者指南---概览
Protocol Buffers(Protobuf)开发者指南---概览 欢迎来到protocol buffers的开发者指南文档,protocol buffers是一个与编程语言无关‘.系统平台无关 ...
- Protocol Buffers(Protobuf) 官方文档--Protobuf语言指南
Protocol Buffers(Protobuf) 官方文档--Protobuf语言指南 约定:为方便书写,ProtocolBuffers在下文中将已Protobuf代替. 本指南将向您描述如何使用 ...
- google protobuf安装与使用
google protobuf是一个灵活的.高效的用于序列化数据的协议.相比较XML和JSON格式,protobuf更小.更快.更便捷.google protobuf是跨语言的,并且自带了一个编译器( ...
- Google Protocol Buffers简介
什么是 protocol buffers ? Protocol buffers 是一种灵活.高效的序列化结构数据的自动机制--想想XML,但是它更小,更快,更简单.你只需要把你需要怎样结构化你的数据定 ...
- Go 支持Protocol Buffers的配置
安装 protoc (The protocol compiler)是由C++写的,支持的 C++.Java.Python.Objective-C.C#.JavaNano.JavaScript.Ruby ...
- Protocol Buffers学习教程
最近看公司代码的过程中,看到了很多proto后缀的文件,这是个啥玩意?问了大佬,原来这是Protocol Buffers! 这玩意是干啥的?查完资料才知道,又是谷歌大佬推的开源组件,这玩意完全可以取代 ...
- Protocol Buffers教程
今天想比较下pb和fastjson两个序列化后的大小.再看了一下pb序列化 pb官网:https://developers.google.com/protocol-buffers/ pb是啥 What ...
- protobuf Protocol Buffers 简介 案例 MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
- Ubuntu 14.04 下 安装Protocol Buffers
参考: Protocol Buffers - Google's data interchange format Ubuntu 14.04 下 安装Protocol Buffers 环境 Ubuntu ...
- Centos 6.8 安装 Protocol Buffers , v3.2.0有 BUG ,安装 3.1.0
Centos 6.8 安装 Protocol Buffers , v3.2.0有 BUG ,安装 3.1.0 切换到用户目录 cd ~ 安装 python2.7,须加入zlib wget http ...
随机推荐
- pycharm之激活
激活相关文件: https://github.com/lanlangdeai/develop-kit/tree/master/software/editor/pycharm 一. 激活码激活 步骤: ...
- Jx.Cms开发笔记(三)-Views主题动态切换
效果展示 我们可以在后台动态切换主题 目前Jx.Cms有两个主题,其中一个是默认主题,另一个是仿的Blogs主题. 我们可以通过点击启用按钮来动态切换两个主题. 实现方法 首先写一个实现IViewLo ...
- 理解Hive 不同组件的功能
Hive功能 通过将SQL转换成MR.Spark等任务,来计算HDFS中数据的工具. Hive是基于Hadoop之上的数仓工具.通过HDFS存储真实的数据,通过YARN运行计算任务(MR.Spark等 ...
- vue 使用 application/x-www-form-urlencoded格式提交数据
const params = new URLSearchParams();//前端在传参时需要先新建一个URLSearchParams对象,然后将参数append到这个对象中 params.appen ...
- ASP.NET Core IHostBuilder
HostBuilder 很显然,HostBuildr 就是用来构建 Host 的构建器. IHostBuilder 定义 通过 Build() 方法,构建器返回构建的 IHost 对象实例. 具体怎么 ...
- 理解 ASP.NET Core:Cookie 认证
理解 ASP.NET Core:Cookie 认证 ASP.NET Core 内置提供了基于 Cookie 的认证支持.在使用 Cookie 验证的时候,相关的三要素: 认证模式名称:CookieAu ...
- Server check fail, please check server xxx ,port 9848 is available
[1]如果使用docker安装的nacos服务,2.x版本后增加了 grpc 通信并且增加nacos的集群端口上下偏移1000,创建容器时除了8848还需要把7848.9848都暴露出来.如:-p 7 ...
- Argo CD使用CLI工具修改默认密码
查看默认密码 kubectl -n argocd get secret argocd-initial-admin-secret -o jsonpath="{.data.password}&q ...
- oracle用命令执行sql脚本文件
当sql命令过多(sql文件过大)时,用plsql执行时比较慢而且容易超时,此时可以用sqlplus命令直接执行sql脚本文件,方法如下: 1.sqlplus登录 >sqlplus userna ...
- 转载 Python 存储与读取HDF5文件
HDF5 简介 HDF(Hierarchical Data Format)指一种为存储和处理大容量科学数据设计的文件格式及相应库文件.HDF 最早由美国国家超级计算应用中心 NCSA 开发,目前在非盈 ...