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文件里面的内容是:

  1. struct UserProfile {
  2. 1: i32 uid,
  3. 2: string name,
  4. 3: string blurb
  5. }
  6. service UserStorage {
  7. void store(1: UserProfile user),
  8. UserProfile retrieve(1: i32 uid)
  9. }

使用命令,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

安装依赖:

  1. 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或者更高版本可以使用下面命令来安装所有依赖包:

  1. apt-get build-dep thrift-compiler -y

安装erlang包,编译需要启用erlang支持:

  1. wget https://packages.erlang-solutions.com/erlang-solutions_1.0_all.deb
  2. dpkg -i erlang-solutions_1.0_all.deb
  3. apt-get update
  4. apt-get install erlang

在debian平台可能会报错:

  1. 证书所有者与主机名 packages.erlang-solutions.com 不符

可以使用下面命令来下载

  1. wget --no-check-certificate -c https://packages.erlang-solutions.com/erlang-solutions_1.0_all.deb

在安装的过程中,输入wheezy。

erlang-solutions的erlang版本版本是最新的,而且可以根据你的linux系统来设置软件源,更新erlang包方便很多。

使用git下载thrift源码

  1. 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 安装 介绍到这个问题。我自己也是遇到了这个坑,才会使用这个方法下载源码。

  1. ./bootstrap.sh
  2. ./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包。

  1. http://download.opensuse.org/repositories/home:/jblunck:/messaging/CentOS_CentOS-6/

好,下载repo文件,直接下载安装thrift

  1. cd /etc/yum.repos.d/
  2. wget -c http://download.opensuse.org/repositories/home:/jblunck:/messaging/CentOS_CentOS-6/home:jblunck:messaging.repo
  3. yum makecache
  4. yum install thrift

安装过程中会要求你确认是否安装,这是因为包没有签名,没有关系,我直接回答y。

使用这种方法安装的thrift跟windows下安装的thrift差不多,只能产生多语言的代码文件,但是缺少里面的语言的驱动代码文件。

至此,thrift的安装步骤完成,下篇会介绍如何根据thrift来写一个具体的erlang项目。

thrift多平台安装的更多相关文章

  1. rpc框架之 thrift 学习 1 - 安装 及 hello world

    thrift是一个facebook开源的高效RPC框架,其主要特点是跨语言及二进制高效传输(当然,除了二进制,也支持json等常用序列化机制),官网地址:http://thrift.apache.or ...

  2. Xamarin C# Android for Visual Studio 平台安装

    原文:Xamarin C# Android for Visual Studio 平台安装 Xamarin是基于Mono的平台,目前主要有以下产品(更具体请见:http://xamarin.com/pr ...

  3. Cordova WP8 平台安装部署

    原文:Cordova WP8 平台安装部署 Cordova是一个开放源码移动开发框架. 它允许您使用标准的 web 技术如 HTML5. CSS3 和 JavaScript 进行跨平台开发,避免每个移 ...

  4. Linux平台安装MongoDB及使用Docker安装MongoDB

    一.Linux平台安装MongoDB MongoDB 提供了 linux 各发行版本 64 位的安装包,你可以在官网下载安装包. 下载地址:https://www.mongodb.com/downlo ...

  5. Windows平台安装配置mysql数据库

    Windows平台安装配置mysql数据库 作者:Eric 微信:loveoracle11g 去下载mysql软件 https://www.mysql.com/downloads/ https://d ...

  6. Web 平台安装程序 5.0(Microsoft Web Platform Installer) 由于修改常用选择不正确导致打开就报错

    如图: 解决方案.第一步先卸载  Web 平台安装程序 5.0 第二步   将你添加配的文件删除 第三步:重新安装就可以了

  7. 你使用 Web 平台安装程序命令行工具

    你使用 Web 平台安装程序命令行工具 获取的软件由其所有者授权给你.Microsoft 未授予你第三方软件的任何权利.已成功加载主源: https://go.microsoft.com/?linki ...

  8. Window 平台安装 Python:

    Window 平台安装 Python: 打开WEB浏览器访问http://www.python.org/download/ 在下载列表中选择Window平台安装包,包格式为:python-XYZ.ms ...

  9. XXL-JOB分布式任务调度平台安装与部署

    配XXL-JOB分布式任务调度平台安装与部署

随机推荐

  1. mysql8.0新增用户及密码加密规则修改

    MySQL8.0已经发布GA版,当前最新GA版本为8.0.12.虽然相对于之前版本,MySQL8.0没有加入新元素,但是,经过代码重构,MySQL8.0的优化器更加强大,同时也有一些新特性,如支持索引 ...

  2. linux 编译安装pureFTP

    安装openssl支持 wget -c https://www.openssl.org/source/openssl.org/source/openssl-1.1.0c.tar.gz tar -zxv ...

  3. 【C】switch-case里面,加或不加break的区别

    int test; test = ; switch(test) { : test++; printf("value = 0"); // 打印printf,后续没有break代码,系 ...

  4. Python文本操作2

    # list3 = [# {"name": "alex", "hobby": "抽烟"},# {"name&q ...

  5. ruby中的字符串分隔符--split

    当字符串是以“:”隔开时,可以这样写: column = str.split(/:/) 这样,column就是字符串每栏的值所构成的数组. eg: str = "Ruby in a shel ...

  6. go内建容器-字符和字符串操作

    1.基础定义 在基础语法篇提到过golang的rune相当于其他编程语言的char,其本质是一个int32(四字节),用[]rune来转换一个字符串时,得到的是个解码后的结果,存储在新开辟的[]run ...

  7. LeetCode初级算法的Python实现--排序和搜索、设计问题、数学及其他

    LeetCode初级算法的Python实现--排序和搜索.设计问题.数学及其他 1.排序和搜索 class Solution(object): # 合并两个有序数组 def merge(self, n ...

  8. 为什么我要放弃javaScript数据结构与算法(第七章)—— 字典和散列表

    本章学习使用字典和散列表来存储唯一值(不重复的值)的数据结构. 集合.字典和散列表可以存储不重复的值.在集合中,我们感兴趣的是每个值本身,并把它作为主要元素.而字典和散列表中都是用 [键,值]的形式来 ...

  9. linux如何制作程序桌面快捷方式

    1.生成通过apt或者dpkg安装的程序的桌面快捷方式 他们的快捷方式在/usr/share/applications中,比如我们要生成火狐的桌面快捷方式,执行下列命令 cp /usr/share/a ...

  10. DevExpress通过girdcontrol实现分页

    简介:DevExpress中如何实现GridControl的分页功能, 主要是利用DataNavigator和GridControl组合,自定义事件实现分页功能 接下来,我们就去实现分页功能,先看下效 ...