当前位置: 首页 > 编程日记 > 正文

基于Netty实现的轻量级分布式服务框架

对分布式技术比较感兴趣,于是在闲暇时间写了一个简单的RPC框架娱乐一下,项目持续更新中......

GitHub项目地址: Pudding

如果感觉Pudding对你有帮助可以顺手点个Star哦......哈哈

直接看一下示例代码吧

第一步: 启动注册中心

public class RegistryTest {public static void main(String[] args) {// 创建服务注册中心ServiceRegistry registry = new DefaultServiceRegistry();// 启动注册中心registry.startRegistry(20000);}
}

第二步: 启动服务提供者

public class ProviderTest {public static void main(String[] args) {// 创建服务提供者和服务包装器ServiceProvider provider = new DefaultServiceProvider();ServiceWrapper serviceWrapper = new DefaultServiceWrapper();// 连接注册中心provider.connectRegistry("127.0.0.1:20000");// 创建服务MyService myService = new MyServiceImpl();// 包装服务为ServiceMetaService service = serviceWrapper.build(myService, "127.0.0.1:30001");// 启用服务provider.startService(service);// 发布所有已启用的服务provider.publishAllService();}
}

第三步: 启动服务消费者

同步调用

public class SyncConsumerTest {public static void main(String[] args) {// 创建服务消费者ServiceConsumer serviceConsumer = new DefaultServiceConsumer();// 连接注册中心serviceConsumer.connectRegistry("127.0.0.1:20000");// 订阅服务serviceConsumer.subscribeService(MyService.class);// 创建同步服务代理MyService myService = ProxyFactory.createSyncProxy(MyService.class);try {// 发起调用int result = myService.add(100, 200);System.out.println("调用结果: " + result);} catch (InvokeTimeoutException e) {System.out.println("远程调用超时");} catch (InvokeFailedException e) {System.out.println("远程调用失败");}}
}

异步调用

public class AsyncConsumerTest {public static void main(String[] args) {// 创建服务消费者ServiceConsumer serviceConsumer = new DefaultServiceConsumer();// 连接注册中心serviceConsumer.connectRegistry("127.0.0.1:20000");// 订阅服务serviceConsumer.subscribeService(MyService.class);// 创建同步服务代理MyService myService = ProxyFactory.createAsyncProxy(MyService.class);// 发起调用myService.add(100, 200);// 监听调用结果InvokeFuture.addInvokeFutureListener(new InvokeFutureListener<Integer>() {@Overridepublic void success(Integer result) {System.out.println("调用结果: " + result);}@Overridepublic void failure(Exception e) {e.printStackTrace();}});}
}

相关文章:

在分页状态下删除纪录的问题

在使用DataGrid分页的时候&#xff0c;正常情况下&#xff0c;绑定数据库列表纪录时会自动产生分页的效果&#xff0c;然而我发觉在删除纪录的时候总会发生"无效的 CurrentPageIndex 值。它必须大于等于 0 且小于 PageCount。"的异常&#xff0c;其实解决这个问题很简…

老码农90%的程序猿都是瞎努力,这份路线教你成为高手!

数据正在变得越来越常见&#xff0c;小到我们每个人的社交网络、消费信息、运动轨迹……&#xff0c;大到企业的销售、运营数据&#xff0c;产品的生产数据&#xff0c;交通网络数据……如何从海量数据中获得别人看不见的知识&#xff0c;如何利用数据来武装营销工作、优化产品…

android 365手机秘书源代码

2019独角兽企业重金招聘Python工程师标准>>> 应用到的知识还算挺多的&#xff0c;网络编程&#xff0c;xml解析&#xff0c;通知&#xff0c;广播&#xff0c;联系人&#xff0c;服务等&#xff0c;希望对新手有帮助 运行环境&#xff1a; 在android 2.3.3 运行…

centos安装及网络配置

感谢老师传授&#xff0c;共同学习&#xff01;谢谢&#xff01;仅供自己日后复习之用&#xff01;centos安装关键点&#xff1a;创建分区&#xff1a;/ 系统分区/boot 启动分区SWAP 交换分区&#xff0c;虚拟内存。主要是缓解物理内存不足。虚拟化软件&#xff1a;VMware work…

使用DataGrid动态绑定DropDownList

简单的使用模板列绑定DropDownList&#xff0c;初学者想必都会了&#xff0c;但有时候&#xff0c;我们要做的就是在编辑的时候想让某一列定制为DropDownList&#xff0c;并且根据正常情况下显示的值自动变换DropDownList中所选的值&#xff0c;然后保存选择后的值到数据库或XM…

隐私数据在隐私AI框架中的安全流动

作者 | Rosetta技术团队责编 | 晋兆雨出品 | AI科技大本营本文中&#xff0c;我们将介绍为了保护用户的隐私数据&#xff0c;在隐私 AI 框架的计算任务全流程中&#xff0c;数据是如何以密文形式流动&#xff0c;同时仍正确完成加法、乘法等计算步骤的。隐私 AI 系统存在的目…

MS Sql Server 作业编辑报错以及不显示历史记录

如下图&#xff1a; 解决方法&#xff1a; 1.开始->运行&#xff0c;输入dcomcnfg.exe 2.打开组件服务器->计算机->我的电脑->DCOM配置&#xff1b; 3.找到Microsoft Office Excel或者Microsoft Office Word点击右键->属性 4.选择安全&#xff0c;将启动和激活权…

基于Guava实现的文件复制

需求&#xff1a;现需要将文件D:\A\B\C\abc.txt进行一下操作 1.在文件夹D:\A\B\C下&#xff0c;没有以abc命名的文件夹则创建 2.将目标文件D:\A\B\C\abc.txt复制到abc下 实现代码&#xff1a; /*** 以目标文件名创建文件夹&#xff0c;并将目标文件复制到该文件夹下** param sr…

破局传统算法痛点,腾讯安全首提基于跨模态检索的二进制代码-源代码匹配

整理 | 高卫华出品 | AI科技大本营头图 | CSDN付费下载自视觉中国近日&#xff0c;在NeurIPS 2020正式发布的论文入选名单中&#xff0c;腾讯安全科恩实验室聚焦解决二进制安全问题的《CodeCMR: Cross-Modal Retrieval For Function-Level Binary Source Code Matching》&#…

DataGrid删除确认及Item颜色交替

有时候我们需要在删除DataGrid中Item相对应的数据时&#xff0c;需要弹出一个确认对话框来提示使用者&#xff0c;其实这个功能非常简单&#xff0c;下面的代码可以在DataGrid的Item 中产生颜色交替的效果。 private void dg_ItemDataBound(object sender, DataGridItemEve…

SharePoint 2010 自定义日志

7/6/2012 How to log to the SharePoint ULS Logs(Clean Debugging and Error Logging broken down into steps) By: Philip Stathis 原文地址 http://www.thesharepointblog.net/Lists/Posts/Post.aspx?ID122 This article is meant to introduce a simple error logging rou…

使用Bot Service创建Bot Framework

创建Bot Service&#xff1a;进入至Azure控制台中&#xff0c;新建Bot Service&#xff0c;如不知道Bot Service在哪个选项中&#xff0c;可以先查找Bot Service再创建 在弹出的查询结果中&#xff0c;选择Bot Service&#xff0c;点击后会进入至下一个步骤 在弹出的Bot Servic…

[转]大三下,我们该做什么?一篇被转万次的日志,你值得一看

大三下&#xff0c;我们该做什么&#xff1f;一篇被转万次的日志&#xff0c;你值得一看 还有几个月&#xff0c;你就不得不参加考研、就业大军了&#xff0c;你做好准备了么&#xff1f;你知道211学校、985学校和非211、985的主要区别么&#xff1f;找工作机会一定是不均等的。…

如何在DataGrid里面产生滚动条而不滚动题头

作者Blog&#xff1a;http://blog.csdn.net/cuike519/ 我们在开发的时候一定遇到&#xff0c;使用DataGrid的时候由于不想分页&#xff08;数据没有那么多&#xff09;但是又显示不在一页里面&#xff0c;此时我们希望在DataGrid里面出现一个滚动条&#xff0c;可以上下滚动Dat…

“小霸王学习机”再现?树莓派400正式发布,售价70美元

整理 | 高卫华出品 | AI科技大本营头图 | CSDN 下载自视觉中国11月2日&#xff0c;树莓派 4 的制造商正式推出了树莓派 400&#xff0c;这是一款集成了 4GB 内存树莓派 4 的紧凑型键盘。有了树莓派 400&#xff0c;只需使用其两个微型HDMI端口之一&#xff0c;将其插入电视或显…

display的block、none、inline属性及解释

常会用到display对应值有block、none、inline这三个值 参数&#xff1a; block :块对象的默认值。用该值为对象之后添加新行。之前也添加一行。 none :隐藏对象。与visibility属性的hidden值不同&#xff0c;其不为被隐藏的对象保留其物理空间 inline :内联对象的默认值。用该值…

datagrid分页问题(前后跳页)《控件版》

在ASCX中写的。 在CSDN上看了很多的DATAGRID分页问题&#xff0c;当然DATAGRID有自己的分页项&#xff0c;功能是很有限的&#xff0c;我也在CSDN上看了很多自己分页的代码&#xff0c;发现都是用C#写的&#xff0c;我写了一个用ASP。NET中VB语言写的。以下代码供大家参考。 HT…

F5第一个10000台

F5中国第一个累积销售10000台&#xff0c;花了整整9年时间。下一个累积销售10000台需要多少时间&#xff0c;5年&#xff0c;3年&#xff0c;甚至更短的时间&#xff1f;让我们拭目以待。转载于:https://blog.51cto.com/f5555/1126095

java内存溢出的情况解决方法

内存溢出虽然很棘手&#xff0c;但也有相应的解决办法&#xff0c;可以按照从易到难&#xff0c;一步步的解决。  第一步&#xff0c;就是修改JVM启动参数&#xff0c;直接增加内存。这一点看上去似乎很简单&#xff0c;但很容易被忽略。JVM默认可以使用的内存为64M&#xff…

DataGrid基于Access的快速分页法

DataGrid基于Access的快速分页法撰文/ 黎波DataGrid是一个功能非常强大的ASP.NET Web服务器端控件&#xff0c;它除了能够方便地按各种方式格式化显示表格中的数据&#xff0c;还可以对表格中的数据进行动态的排序、编辑和分页。使Web开发人员从繁琐的代码中解放。实现DataGrid…

urlrewrite使用小结

urlrewrite顾名思义&#xff0c;就是对URL进行重写&#xff0c;用户得到的全部都是经过处理后的URL地址&#xff0c;这样做我觉得好处有三&#xff1a;一&#xff1a;提高安全性&#xff0c;可以有效的避免一些参数名、ID等完全暴露在用户面前&#xff0c;如果用户随便乱输的话…

性能超越图神经网络,将标签传递和简单模型结合实现SOTA

译者 | 刘畅出品 | AI科技大本营头图 | CSDN付费下载自视觉中国图神经网络&#xff08;GNNs&#xff09;是图学习中一种主流的技术。然而&#xff0c;对于GNN为什么在实际使用中很成功以及它们是否是优异性能所必需的技术&#xff0c;了解相对较少。本文展示了许多标准的传导节…

模仿VIMD的模式的简化代码示例

按numpad0来切换模式&#xff0c;按t显示不同的结果&#xff1b; Numpad0:: tfmode:!tfmode aaa:(tfmode1?"AAAA":"BBBB") SplashImage Off SplashImage, "",X500 Y500 W200 B fs10 CT00FFFF CW000000,%aaa%, , 切换模式提示 WinSet, Tr…

DataGrid连接Access的快速分页法(1)——需求与现状

作者&#xff1a;黎波一、需求分析 DataGrid是一个功能强大的ASP.NET Web服务器端控件&#xff0c;它除了能够按各种方式格式化显示数据&#xff0c;还可以对数据进行动态的排序、编辑和分页。大大减轻了广大Web程序员的工作量。实现DataGrid的分页功能一直是很多入门者感到棘手…

CSDN公众号新功能上线,居然还能搜出小姐姐???

为了给各位打工人更好的搜索体验CSDN总是在学习新技能这次CSDN公众号又给大家带来了一项全新的搜索技能在CSDN旗下的公众号内回复消息就能自动回复想搜索的内容啦小编来给大家演示一下&#xff0c;在公众号内输入“mysql安装教程”&#xff0c;就能得到CSDN全站内关于mysql安装…

p2v、v2v 转换-windows篇

问题&#xff1a;如何把 xenserver的虚拟机转成Esxi的虚拟机 如何把物理机转成Esxi的虚拟机答案&#xff1a;↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓首先介绍一下实验环境。一台xenserver主机上两台虚拟机 win03和win08 转到Esxi5.0的一台主机上。Esxi5.0在某个…

WebViewJavascriptBridge原理解析

基本说明 我们的项目是一个OC与javascript重度交互的app&#xff0c;OC与javascript交互的那部分是在WebViewJavascriptBridge的github地址的基础上修改的&#xff0c;WebViewJavascriptBridge应该是当前最流行最成功的OC与Web交互实现了。最近看了一下他的实现原理&#xff0c…

DataGrid连接Access的快速分页法(2)——SQL语句的选用(升序与降序)

作者&#xff1a;黎波 一、相关概念 在 ACCESS 数据库中&#xff0c;一个表的主键&#xff08;PRIMARY KEY&#xff0c;又称主索引&#xff09;上必然建立了唯一索引&#xff08;UNIQUE INDEX&#xff09;&#xff0c;因此主键字段的值是不会重复的。并且索引页依据索引列的值…

从谷歌AutoML到百度EasyDL,AI大生产时代,调参师不再是刚需

出品 | AI科技大本营头图 | 付费下载于视觉中国2018 年&#xff0c;Google Cloud 宣布将 AutoML 作为机器学习产品的一部分。至此&#xff0c;AutoML 开始进入大众的视野。 实际上&#xff0c;2013 年AutoWEKA的发布可以算作AutoML的开端&#xff1b;2014 年&#xff0c;ICML开…