thrift多平台安装
thrift支持多语言的RPC,一直都想深入学习了解thrift,最近有空,就上网查了些资料,学习了一下,对它的使用有了一些了解。本篇是写thrift的安装,使用方法会另起一篇来写。
本文使用thrift的版本是0.9.1。
1.windows平台安装
直接下载编译好的exe文件,就可以使用了。
下载链接在这里
新建目录,C:\Program Files\thrift,把下载好的thrift-0.9.1.exe文件放在里面。把C:\Program Files\thrift添加到windows下面的环境变量,如下图
现在使用thrift官网的例子来试试thrift是否正确安装。
example.thrift文件里面的内容是:
struct UserProfile {
1: i32 uid,
2: string name,
3: string blurb
}
service UserStorage {
void store(1: UserProfile user),
UserProfile retrieve(1: i32 uid)
}
使用命令,thrift-0.9.1 --gen erl example.thrift来产生erlang的代码文件。从下图可以看出,它会在目录下面产生一个gen-erl文件夹,里面就是我们需要的代码文件了。
大家可以试一下其他语言,例如go,js,php,cpp。
到这里,windows下面的thrift安装就完成了。
2.debian/ubuntu下面源码编译安装thrift
源码编译安装就是麻烦一点,首先要安装thrift的依赖包。
主要参考Debian or Ubuntu setup, 以及Building from source
安装依赖:
apt-get install libboost-dev libboost-test-dev libboost-program-options-dev libevent-dev automake libtool flex bison pkg-config g++ libssl-dev
在ubuntu 13.04或者更高版本可以使用下面命令来安装所有依赖包:
apt-get build-dep thrift-compiler -y
安装erlang包,编译需要启用erlang支持:
wget https://packages.erlang-solutions.com/erlang-solutions_1.0_all.deb
dpkg -i erlang-solutions_1.0_all.deb
apt-get update
apt-get install erlang
在debian平台可能会报错:
证书所有者与主机名 “packages.erlang-solutions.com” 不符
可以使用下面命令来下载
wget --no-check-certificate -c https://packages.erlang-solutions.com/erlang-solutions_1.0_all.deb
在安装的过程中,输入wheezy。
erlang-solutions的erlang版本版本是最新的,而且可以根据你的linux系统来设置软件源,更新erlang包方便很多。
使用git下载thrift源码
git clone -b 0.9. https://github.com/apache/thrift thrift-0.9.1
特意使用git下载,而不是直接下载apache打包好的tar包,是因为apache在打源码包的时候,出现了一些其他问题。[O]Ubuntu 13.10 thrift-0.9.1 安装 介绍到这个问题。我自己也是遇到了这个坑,才会使用这个方法下载源码。
./bootstrap.sh
./configure --with-cpp=no --with-python=no
make
make check
make install
上面configure不启动cpp以及python支持,原因有2个:
原因1,在make check段,总是报错,通不过测试。我发现部分原因是有些测试代码缺失,没完成,例如变量没填上。对于没有通过测试用例的代码,我自己总是持怀疑态度。
原因2,我自己没使用cpp以及python。
当然,如果你不关注测试用例,你可以直接make && make install
编译安装完毕后,在/usr/lib/erlang/lib/thrift-0.9.1里面就是thrift对erlang语言的代码支持包。里面有thrift的erlang代码,大家可以看看。
使用thrift --gen erl example.thrift就可以产生我们需要的代码文件。
3.centos安装thrift
在centos源码安装thrift 0.9.1版本麻烦,我自己是没有成功。
在CentOS setup介绍了centos的编译方法,我照着做,但是autoconf的版本不给力,比thrift要求的版本要低。可怜我使用的是centos 6.5,是最新的centos版本了,这可咋整?
在经过编译安装最新版autoconf折腾后,编译thrift还是报错。我放弃编译了,改为直接使用其他人的二进制包。
centos的rpm包就是多,我搜索了n久,终于发现了下面这个链接,里面就有编译好的thrift包。
http://download.opensuse.org/repositories/home:/jblunck:/messaging/CentOS_CentOS-6/
好,下载repo文件,直接下载安装thrift
cd /etc/yum.repos.d/
wget -c http://download.opensuse.org/repositories/home:/jblunck:/messaging/CentOS_CentOS-6/home:jblunck:messaging.repo
yum makecache
yum install thrift
安装过程中会要求你确认是否安装,这是因为包没有签名,没有关系,我直接回答y。
使用这种方法安装的thrift跟windows下安装的thrift差不多,只能产生多语言的代码文件,但是缺少里面的语言的驱动代码文件。
至此,thrift的安装步骤完成,下篇会介绍如何根据thrift来写一个具体的erlang项目。
thrift多平台安装的更多相关文章
- rpc框架之 thrift 学习 1 - 安装 及 hello world
thrift是一个facebook开源的高效RPC框架,其主要特点是跨语言及二进制高效传输(当然,除了二进制,也支持json等常用序列化机制),官网地址:http://thrift.apache.or ...
- Xamarin C# Android for Visual Studio 平台安装
原文:Xamarin C# Android for Visual Studio 平台安装 Xamarin是基于Mono的平台,目前主要有以下产品(更具体请见:http://xamarin.com/pr ...
- Cordova WP8 平台安装部署
原文:Cordova WP8 平台安装部署 Cordova是一个开放源码移动开发框架. 它允许您使用标准的 web 技术如 HTML5. CSS3 和 JavaScript 进行跨平台开发,避免每个移 ...
- Linux平台安装MongoDB及使用Docker安装MongoDB
一.Linux平台安装MongoDB MongoDB 提供了 linux 各发行版本 64 位的安装包,你可以在官网下载安装包. 下载地址:https://www.mongodb.com/downlo ...
- Windows平台安装配置mysql数据库
Windows平台安装配置mysql数据库 作者:Eric 微信:loveoracle11g 去下载mysql软件 https://www.mysql.com/downloads/ https://d ...
- Web 平台安装程序 5.0(Microsoft Web Platform Installer) 由于修改常用选择不正确导致打开就报错
如图: 解决方案.第一步先卸载 Web 平台安装程序 5.0 第二步 将你添加配的文件删除 第三步:重新安装就可以了
- 你使用 Web 平台安装程序命令行工具
你使用 Web 平台安装程序命令行工具 获取的软件由其所有者授权给你.Microsoft 未授予你第三方软件的任何权利.已成功加载主源: https://go.microsoft.com/?linki ...
- Window 平台安装 Python:
Window 平台安装 Python: 打开WEB浏览器访问http://www.python.org/download/ 在下载列表中选择Window平台安装包,包格式为:python-XYZ.ms ...
- XXL-JOB分布式任务调度平台安装与部署
配XXL-JOB分布式任务调度平台安装与部署
随机推荐
- 使用Scala开发Apache Kafka的TOP 20大好用实践
本文作者是一位软件工程师,他对20位开发人员和数据科学家使用Apache Kafka的方式进行了最大限度得深入研究,最终将生产实践环节需要注意的问题总结为本文所列的20条建议. Apache Kafk ...
- 【转载++】C/C++错误分析errno,perror,strerror和GetLastError()函数返回的错误代码的意义
本文是上一篇“fopen返回0(空指针NULL)且GetLastError是0”的侧面回应.听赶来多么地正确和不容置疑,返回NULL时调用GetLastError来看看报错啊,但当时却返回了0,大家都 ...
- Vue 生产环境部署
简要:继上次搭建vue环境后,开始着手vue的学习;为此向大家分享从开发环境部署到生产环境(线上)中遇到的问题和解决办法,希望能够跟各位VUE大神学习探索,如果有不对或者好的建议告知下:*~*! 一. ...
- C/S与B/S 区别以及优缺点
1.什么是C/S结构 C/S (Client/Server)结构,即客户机和服务器结构.它是软件系统体系结构,通过它可以充分利用两端硬件环境的优势,将任务合理分配到Client端和Server端来实现 ...
- 成都优步uber司机第五组奖励政策
7月14日,成都优步uber团队发布了第五组用户分组.在传言要推出第四组的时候,心想事不过三吧,意外,现在第五组都出来了.一起看看成都优步司机第五组的详细内容!滴滴快车单单2.5倍,注册地址:http ...
- mysql主从集群搭建;(集群复制数据)
1.搭建mysql 5.7环境chown mysql:mysql -R /data/groupadd mysqluseradd -g mysql mysql yum install numactlrp ...
- 抽样分布(3) F分布
定义 设U~χ2(n1), V~χ2(n2),且U,V相互独立,则称随机变量 服从自由度为(n1,n2)的F分布,记为F~F(n1,n2),其中n1叫做第一自由度,n2叫做第二自由度. F分布的概率密 ...
- 容器云技术:容器化微服务,Istio占C位出道
在精彩的软件容器世界中,当新项目涌现并解决你认为早已解决的问题时,这感觉就像地面在你的脚下不断地移动.在许多情况下,这些问题很久以前被解决,但现在的云原生架构正在推动着更大规模的应用程序部署,这就需要 ...
- 关联分析FPGrowth算法在JavaWeb项目中的应用
关联分析(关联挖掘)是指在交易数据.关系数据或其他信息载体中,查找存在于项目集合或对象集合之间的频繁模式.关联.相关性或因果结构.关联分析的一个典型例子是购物篮分析.通过发现顾客放入购物篮中不同商品之 ...
- selenium,unittest——两个class连续运行
将多个class放在一个文件内一起运行,这是一个多用例不同网站进行测试的方法 #encoding=utf-8from selenium import webdriverimport time,unit ...