当前位置: 首页 > news >正文

实现RPC接口的demo记录

1.Thrift RPC 接口实现 Demo

@Service
public class DemoServiceImpl implements DemoService.Iface {private static final Logger logger = LoggerFactory.getLogger(DemoServiceImpl.class);@Overridepublic String sayHello(Context context, String msg) throws TException {logger.info("接收到 RPC 请求, msg: {}", msg);return "Hello " + msg;}
}

2.Thrift RPC 配置 Demo

@Configuration
public class DemoThriftConfiguration {@Value("${rpc.server.port:9090}")private int port;/*** 定义 Thrift Server*/@Beanpublic ServiceBuilder<DemoService.Iface> demoServer(DemoServiceImpl serviceImpl) {return ServiceBuilder.fromInstance(DemoService.Iface.class, port, serviceImpl);}/*** 定义 Thrift Client*/@Beanpublic DemoService.Iface demoClient() {return ClientBuilder.create(DemoService.Iface.class, "excover").withTimeout(2000, TimeUnit.MILLISECONDS)// 直连地址,仅用于本地测试;这里请求服务自己.withDirectHost(HostAndPort.fromParts("127.0.0.1", port)).buildStub();}
}
3.Thrift RPC Client 调用 Demo
@RestController
@RequestMapping("/rpc")
public class DemoThriftController {private static final Logger logger = LoggerFactory.getLogger(DemoThriftController.class);@Resourceprivate DemoService.Iface demoClient;/*** curl http://127.0.0.1:8080/rpc/sayHello\?msg=demo*/@GetMapping("/sayHello")public String sayHello(String msg) {try {return demoClient.sayHello(ContextHelper.getContext(), msg);} catch (TException e) {logger.error("RPC 请求失败: {}", e.getMessage(), e);return "error";}}
}


http://www.mrgr.cn/news/60711.html

相关文章:

  • 代码随想录跟练21天——LeetCode332.重新安排行程, 51. N皇后,37. 解数独
  • 知名数字中国战略布局与新质生产力培训师讲师培训讲师唐兴通数字经济数字化转型专家教授学者大数据AIGC大模型智能化战略数字时代商业模式创新
  • 如何进行Appium实现移动端UI自动化测试
  • 电脑程序变化监控怎么设置?实时监控电脑程序变化的五大方法,手把手教会你!
  • 云服务器数据删除了能恢复吗?
  • Ascend L 闯关记录
  • Windows端口管理与进程控制
  • redis数据类型介绍
  • EXPORT_SYMBOL 底层原理
  • (蓝桥杯C/C++)—— 编程基础
  • Lomda表达式与函数式接口
  • 爬虫ip与反爬虫的“猫鼠游戏”
  • java基础(Object篇)
  • Python 基础语法 - 赋值运算符
  • auto占位符(C++11~C++17)
  • C语言实现高并发编程——线程池
  • Open3D-Geometry-14:Distance Queries距离查询方法将网格生成为隐式表示
  • 【专题】关系模型的基本理论
  • 使用chatglm API处理论文
  • 排序算法简记
  • 五、Hadoop 分布式文件系统(HDFS)的原理与架构专业解析
  • python 数据结构 1
  • 一文贯通RAG的技术介绍和构建(简易版+附详细代码)
  • 2024年【制冷与空调设备安装修理】考试内容及制冷与空调设备安装修理最新解析
  • Java程序设计:spring boot(12)——定时调度集成 - Quartz
  • 怎么把照片恢复至手机?一文读懂详细教程与多种方法!