半小时入门Thrift

      当一个单体软件产品体量达到一定程序,都会想到拆分为不同的模块(当今这么流行微服务)。拆分后一定会存在进程之间的交互(简称:PRC),那么thrift就是facebook推出一款开源的rpc框架,且还跨语言。此文章就是来打开thrift的打开(当然这次还是基于.net)。 示例代码下载:https://gitee.com/samtest-project/thrift-test.git

一、准备工作

下载地址:http://archive.apache.org/dist/thrift(可以选择可使用的版本),其中需要下载如下两个文件包:

  • thrift-*.*.exe:此程序是在windows上用的,用于将thrift文件转换为对应语言的代码文件工具
  • thrift-0.11.0.tar.gz:供各语言使用的基类库,c#要编译出对应的dll

1.1 生成Thrift.dll

此点要注意,他分为.net35和.net45两个版本,可以根据需要进行相应的生成

二、生成rpc可使用的文件

2.1 创建hello.thrift文件,并输入如下内容:

struct User{
    1:i32 id
    2:string name
}

service UserService{
    User GetUserById(1:i32 userId)
     list<User> GetAll()
    void add(1:User user)
}

2.2 运行命令进行csharp代码的生成

生成成功后,会有一个gen-csharp文件夹

gen-csharp文件夹中包含的就是我们需要的c#代码。

三、建立项目

项目结构如下

其引用关系为如下:

  • 所有项目都必须引用在在1.1中编译好的Thrift.dll文件
  • Client和Server项目都必须引用Thrift.Services项目
  • 在Server端做接口的实现,接口在对应的Service下
  • UserService的实现代码如下:
public class UserServiceImp : UserService.Iface
    {
        private IList<User> users;

        public UserServiceImp()
        {
            this.users = new List<User>();
        }

        public void add(User user)
        {
            Console.WriteLine(user.Name);
            this.users.Add(user);
        }

        public List<User> GetAll()
        {
            return this.users.ToList();
        }

        public User GetUserById(int userId)
        {
            return this.users.Where(m => m.Id == userId).FirstOrDefault();
        }
    }

四、测试

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏FreeBuf

简析60度CMS的Cookies欺骗漏洞

前言 本篇文章只是为了和大家分享漏洞的挖掘经验和思路,同时让大家认识到 Cookies 欺骗漏洞的危害和严重性。 漏洞发现时间:2017.8.16,因产商无回应...

2738
来自专栏技术博文

redis配置详解

##redis配置详解 # Redis configuration file example. # # Note that in order to read ...

3695
来自专栏喵了个咪的博客空间

[喵咪Redis]Redis-Sentinel

[喵咪Redis]Redis-Sentinel ? 前言 redis-Sentinel 是我们这次来一同学习 redis 的重点,在我们现在的系统已经离不开 r...

3184
来自专栏.NET开发那点事

使用Microsoft Fakes进行单元测试(1)

一:什么是单元测试 单元测试是对软件进行准确性验证的步骤。单元测试并不进行整个软件功能的测试,仅仅是对于最小工作单元的测试。一般最小工作单元就是指方法/函数等...

2286
来自专栏码农阿宇

.Net Core从命令行读取配置文件

最近在学习博客园腾飞(jesse)的.Net Core视频教程,收益匪浅,在此作推荐 : http://video.jessetalk.cn/ 言归正传,.Ne...

3004
来自专栏互联网技术栈

Redis核心概念

Redis 支持简单且易用的主从复制(master-slave replication)功能, 该功能可以让从服务器(slave server)成为主服务器(m...

1684
来自专栏雪胖纸的玩蛇日常

python3+django2 开发易语言网络验证(中)

3467
来自专栏微服务

RabbitMQ入门HelloWorld(C#)(翻译)

介绍 先决条件 本教程假定RabbitMQ已安装并在标准端口(5672)上的本地主机上运行。如果您使用不同的主机,端口或凭据,连接设置将需要调整。 在哪里得到帮...

2769
来自专栏林滨的专栏

ABP 框架 数据库底层迁移 Mysql 集群

我的各种github 开源项目和代码:https://github.com/linbin524

1510
来自专栏分布式系统和大数据处理

HttpModule介绍

Http 请求处理流程 和 Http Handler 介绍 这两篇文章里,我们首先了解了Http请求在服务器端的处理流程,随后我们知道Http请求最终会由实现了...

713

扫码关注云+社区