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

广东住房和城乡建设厅网站北京seo供应商

广东住房和城乡建设厅网站,北京seo供应商,赣州省住房和城乡建设厅网站,杭州高端模板建站背景 在flink系统中,我们为了补充某个流事件成一个完整的记录,经常需要调用外部接口获取一些配置数据,流事件结合这些配置数据就可以组合成一条完整的记录,然而如果同步调用外部系统接口来实现,那么会有很大的性能瓶颈…

背景

在flink系统中,我们为了补充某个流事件成一个完整的记录,经常需要调用外部接口获取一些配置数据,流事件结合这些配置数据就可以组合成一条完整的记录,然而如果同步调用外部系统接口来实现,那么会有很大的性能瓶颈,这种情况下我们一般会使用异步函数提高性能,本文就来记录下使用异步函数的几个注意事项

异步函数的使用

首先看一下官方的例子:

/*** 实现 'AsyncFunction' 用于发送请求和设置回调。*/
class AsyncDatabaseRequest extends RichAsyncFunction<String, Tuple2<String, String>> {/** 能够利用回调函数并发发送请求的数据库客户端 */private transient DatabaseClient client;@Overridepublic void open(Configuration parameters) throws Exception {client = new DatabaseClient(host, post, credentials);}@Overridepublic void close() throws Exception {client.close();}@Overridepublic void asyncInvoke(String key, final ResultFuture<Tuple2<String, String>> resultFuture) throws Exception {// 发送异步请求,接收 future 结果final Future<String> result = client.query(key);// 设置客户端完成请求后要执行的回调函数// 回调函数只是简单地把结果发给 futureCompletableFuture.supplyAsync(new Supplier<String>() {@Overridepublic String get() {try {return result.get();} catch (InterruptedException | ExecutionException e) {// 显示地处理异常。return null;}}}).thenAccept( (String dbResult) -> {resultFuture.complete(Collections.singleton(new Tuple2<>(key, dbResult)));});}
}// 创建初始 DataStream
DataStream<String> stream = ...;// 应用异步 I/O 转换操作
DataStream<Tuple2<String, String>> resultStream =AsyncDataStream.unorderedWait(stream, new AsyncDatabaseRequest(), 1000, TimeUnit.MILLISECONDS, 100);

注意事项如下:
1.在asyncinvoke方法中不能有阻塞的操作,比如这里仅仅是使用Future.thenAccept注册一个回调返回后的处理逻辑,而不会使用Future.get方法进行阻塞操作
2.AsyncDataStream.orderWait和AsyncDataStream.unorderWait方法都能正确的事件时间,也就是说即使是AsyncDataStream.unorderWait,它也能保证记录不会被之后的水位线超越
3.异步函数可以和检查点机制进行集成,也就是那些正在等待响应结果的记录会被写入检查点中,当故障恢复后,可以重新发送请求
4.如果服务端没有提供异步的客户端,我们可以用多线程进行模拟,只要多线程返回future对象即可
5.使用AsyncDataStream可以限制并发数以及如何进行超时处理等

http://www.ritt.cn/news/27692.html

相关文章:

  • 整站优化 快速排名交易平台官网
  • 百度怎么推广网站产品如何推广市场
  • 网站建设新手年度关键词有哪些
  • 网站暂停怎么做网站推广模式
  • 深圳做网站建设网络营销策略存在的问题
  • wordpress注册用户上传权限首页关键词排名优化
  • 小说网站的网编具体做哪些工作百度电脑端网页版入口
  • 防水网站建设焊工培训ppt课件
  • 那个网站做兼职靠谱潍坊百度网站排名
  • 公司网站做二维码网址seo 网站推广
  • 顺德网站制作案例价位武汉seo霸屏
  • 做最最优秀的视频网站有哪些如何做好互联网营销
  • b2c 网站做seo优化360推广登陆入口
  • 苏州市网站建设服务网站编辑seo
  • 网站服务器有什么用seo百度快速排名
  • 网站开发后台需要什么技术网页关键词优化软件
  • 网站建设表格代码企业网站seo平台
  • 网站建设怎么搞国际外贸网络交易平台
  • 餐饮公司 网站建设百度怎么精准搜索
  • 凡科怎么建站教程上海网站seo招聘
  • 襄城县城乡建设管理局网站晋中网站seo
  • 网站开发平台的定义play商店
  • 病理学系列教材的建设与实践 教学成果奖申报网站东莞关键词排名快速优化
  • 怎么注册公司需要多少钱南宁网站seo外包
  • 网站手机版怎么做的google搜索
  • 用微信公众平台做分类广告网站出售友情链接是什么意思
  • 网站如何做中英文双语言自动引流推广软件
  • 本机做web打开网站无法显示网站百度的网站
  • 手机网站开发方案关键词查询网站
  • 扬州网站推广营销推广平台