IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> C# 使用 thrift-0.15.0 实现RPC协议 -> 正文阅读

[网络协议]C# 使用 thrift-0.15.0 实现RPC协议

到了网络时代,大家的电脑都连起来了。以前程序只能调用自己电脑上的进程,能不能调用其他机器上的进程呢?于是就程序员就把IPC扩展到网络上,这就是RPC(远程过程调用)了。现在不仅单机上的进程可以相互通信,多机器中的进程也可以相互通信了.

所用到的演示软件和文本:https://download.csdn.net/download/weixin_43542114/43118953
文件目录
打开 gen-netstd 文件中生成的C# 类 然后创建 中间通信类

在这里插入图片描述
创建服务端
核心代码:

using System;
using Thrift;
using Thrift.Processor;
using Thrift.Server;
using Thrift.Transport;
using Thrift.Transport.Server;
using static Mr.Wang.Contract.UserService;

namespace ConsoleAppThrift_Service
{
    class Program
    {
        static void Main(string[] args)
        {
            Console.WriteLine("Hello World!" + "thrift——server Start。。。");
            TConfiguration config = new TConfiguration();
            config.RecursionLimit = 100;
            TServerTransport transport = new TServerSocketTransport( 9500,new TConfiguration() {  RecursionLimit=10});
            ITAsyncProcessor asyncProcessor = new AsyncProcessor(new UserServiceImpl());
            TServer server = new TThreadPoolAsyncServer(asyncProcessor, transport);
            server.ServeAsync(new System.Threading.CancellationToken());
            Console.ReadLine();
            server.Stop();

        }
    }
}

客户端核心代码:

using Mr.Wang.Contract;
using System;
using System.Collections.Generic;
using System.Net;
using System.Net.Sockets;
using Thrift;
using Thrift.Protocol;
using Thrift.Transport;
using Thrift.Transport.Client;

namespace ConsoleApp_Thrift_Client
{
    class Program
    {
        static void Main(string[] args)
        {
            //IPEndPoint endPoint = new IPEndPoint(IPAddress.Parse("127.0.0.1"), 9501);
            //TcpClient tcpClient = new TcpClient(endPoint);
            //TConfiguration cfg = new TConfiguration();

            using TTransport transport = new TSocketTransport("127.0.0.1",9500, null,10);
            
            using TProtocol protocol = new TBinaryProtocol(transport);
            using var client = new UserService.Client(protocol);
            client.OpenTransportAsync().Wait();

            var u = client.Get(2).Result;

            List<User> allUsers = client.GetAll().Result;
            allUsers.ForEach(user => { Console.WriteLine($"ID:{user.Id} Name:{user.Name}  Age:{user.Age}"); });

            Console.WriteLine("Hello World!");
            Console.ReadKey();
        }
    }
}

服务类需要实现,Contract 中间类接口 。

  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2021-11-18 11:30:16  更:2021-11-18 11:31:13 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 6:36:53-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码