- Flink源码-6-JobMaster 启动任务
wending-Y
Flink入门到实践flink
JobMasterjobmaster负责执行整个任务入口类org.apache.flink.runtime.jobmaster.JobMasterpublicCompletableFuturestart(finalJobMasterIdnewJobMasterId)throwsException{//makesurewereceiveRPCandasynccallsstart();returnca
- 2018-10-31
BOOpan
潘蔚~常州新日催化剂有限公司【日精进打卡第九十五天】【知~学习】《六项精进》2遍共123遍《大学》1遍共125遍【经典名句]Knowledgecanchangeyourfateandstudycanaccomplishyourfuture!【行~实践】一、修身:1、和女儿一起读书二、齐家:(对家庭和家人)1、照顾陪伴生病的女儿2、做家务三、建功:(对工作)1、色谱故障处理2、经营独立核算{积善}:
- Netty架构详解
思静语
Netty网络通信
文章目录概述整体结构Netty的核心组件逻辑架构BootStrap&ServerBootStrapChannelPipelineFuture、回调和ChannelHandler选择器、事件和EventLoopChannelHandler的各种ChannelInitializer类图ProtocolSupport协议支持层TransportService传输服务层Core核心层模块netty-com
- 早安心语第12天
豆沙冰冰DS
(1)We'dbetterstruggleforthefutureratherthanregretforthepast.后悔过去,不如奋斗将来。(2)Afterall—Витоге;Все-таки终究(临摹的叶子)
- netty的TCP服务端和客户端实现
nanshaws
tcp/ipudp网络netty后端服务器
第一步:引入依赖io.nettynetty-all4.1.90.Final第二步:实现TCP服务端packageorg.cyl.tcputils;importio.netty.bootstrap.ServerBootstrap;importio.netty.channel.ChannelFuture;importio.netty.channel.ChannelInitializer;importi
- CompletableFuture
scj1022
并发与多线程java
文章目录CompletableFuture一、创建异步任务1、ExecutorService.submit2、supplyAsync/runAsync二、异步回调1、thenApply/thenApplyAsync1)案例12)案例23)案例34)案例42、thenAccept/thenAcceptAsync案例3、thenRun/thenRunAsync案例4、whenComplete/when
- 贾跃亭又有动作:FF91在纽约面世?才造出车贾跃亭还有戏吗?
慕容随风
在中国的互联网市场上,贾跃亭似乎是一个始终无法绕过去的名字,虽然贾跃亭已经出走美国多年,但是中国始终有着他的名字,在法拉第未来要上市之外,贾跃亭又有了新的消息,宣布FF91要在纽约面世,很多人都在疑惑,都到了2021年了,FF91才姗姗来迟,贾跃亭这还有戏吗?一、贾跃亭:FF91将在纽约面世?根据金融界的报道,贾跃亭造车又传来新的消息。5月8日,FaradayFuture官方微博发布消息称,法拉第
- java-8组合式异步编程
AIGPTchina
java开发语言
11.1Future接口Future接口在Java5中被引人,设计初衷是对将来某个时刻会发生的结果进行建模。它建模了一种异步计算,返回一个执行运算结果的引用,当运算结束后,这个引用被返回给调用方。在Future中触发那些潜在耗时的操作把调用线程解放出来,让它能继续执行其他有价值的工作,不再需要呆呆等待耗时的操作完成。打个比方,你可以把它想象成这样的场景:你拿了一袋子衣服到你中意的干洗店去洗。干洗店
- 关于Future的使用
韩_师兄
技能点javawindows数据库
关于Future的使用1说明2使用在日常处理业务中,在某些定时任务处理数据时,因待处理数据量较大,如上千上万数据处理.虽然可以使用线程池异步处理,但是线程池处理速度和队列存放能力有限,为保护线程池稳定,需要控制数据处理频率,常见如分批次处理数据,在多线程处理中分批次,一般可使用CountDownLatch,Future等.1说明常见两种创建线程的方式:1直接继承Thread类.2实现Runnabl
- 异步编程——CompletableFuture用法详解
TheManba
java多线程异步编程
文章目录前言1.Future+线程池2.什么是CompletableFuture前言我们异步执行一个任务时,需要用线程池Executor去创建,有两种方式:如果不需要有返回值,任务继承Thread类或实现Runnable接口;如果需要有返回值,任务实现Callable接口,调用Executor的submit方法执行任务,再使用Future.get()获取任务结果。当我们得到包含结果的Future时
- 【高并发】两种异步模型与深度解析Future接口
冰河团队
大家好,我是冰河~~本文有点长,但是满满的干货,以实际案例的形式分析了两种异步模型,并从源码角度深度解析Future接口和FutureTask类,希望大家踏下心来,打开你的IDE,跟着文章看源码,相信你一定收获不小!一、两种异步模型在Java的并发编程中,大体上会分为两种异步编程模型,一类是直接以异步的形式来并行运行其他的任务,不需要返回任务的结果数据。一类是以异步的形式运行其他任务,需要返回结果
- 2018-09-07《小狗钱钱》读后感
姜湖郎中
第一次读《小狗钱钱》在读书营,清单主题营,十天读十本书,相比《未来简史》这样的大部头,读到这本书时,内心是极其喜悦的,文字表达相当友好,内容亲民易懂。第二次读《小狗钱钱》是参加花花的future计划的训练营,这是花花要求在开营前大伙认真读的书,据说她本人也是读了n遍,这本书带给她很多指引。第三次读是在这个理财训练营里,感觉这本书真是太有魅力了,用简单的表达形式,说出了实用、实战性强的内容,而且老少
- PyCharm 调试过程中控制台 (Console) 窗口内运行命令 - 实时获取中间状态
Yongqiang Cheng
PyCharmPyCharm控制台窗口内运行命令实时获取中间状态
PyCharm调试过程中控制台[Console]窗口内运行命令-实时获取中间状态1.yongqiang.py2.Debugger->Console3.ShowPythonPromptReferences1.yongqiang.py#!/usr/bin/envpython#-*-coding:utf-8-*-#yongqiangchengfrom__future__importabsolute_im
- 33、商城系统(十五):线程基本使用,CompletableFuture处理线程间的执行顺序以及执行结果
鹏哥哥啊Aaaa
从头开始做项目java算法
目录一、线程的基本使用1.thread使用2.runnable3.callable4.线程池二、CompletableFut
- MTR++论文阅读
ZHANG8023ZHEN
论文阅读
https://zhuanlan.zhihu.com/p/654070149文章亮点:DenseFuturePredictionforAllAgent:将预测的结果也encode起来,用于平衡障碍物之间的预测结果。不过在infer的时候这一部分不会进行用数据集聚类获得query轨迹点(goal点):将goal点也进行Transformer,并且让上一帧模型的结果用于下一帧的模型推理,可以使模型的推
- 关于报错java.lang.reflect.InaccessibleObjectException: Unable to make field private java.util.concurrent
m0_60198984
javajvm
java.lang.reflect.InaccessibleObjectException:Unabletomakefieldprivatejava.util.concurrent.Callablejava.util.concurrent.FutureTask.callableaccessible:modulejava.basedoesnot"opensjava.util.concurrent"t
- 10-OpenFeign-实现异步调用
宣晨光
openfeign异步调用
通常我们在使用openfeign发起服务调用时,需要同步等待调用结束。某些场景下,我们需要实现异步调用。1、使用java8的CompletableFuture异步工具@ResourceOauthFeignoauthFeign;@GetMapping("/get")publicObjectget(){CompletableFuturecompletableFuture=CompletableFutu
- java中Future的使用
flydean程序那些事
java中Future的使用Future是java1.5引入的一个interface,可以方便的用于异步结果的获取。本文将会通过具体的例子讲解如何使用Future。创建Future正如上面所说,Future代表的是异步执行的结果,意思是当异步执行结束之后,返回的结果将会保存在Future中。那么我们什么时候会用到Future呢?一般来说,当我们执行一个长时间运行的任务时,使用Future就可以让我
- java通过接口开启和停止定时任务
织梦少年666
1.思路说明(a)首先这里我们需要重新认识一个类ThreadPoolTaskScheduler:线程池任务调度类,能够开启线程池进行任务调度。(b)ThreadPoolTaskScheduler.schedule()方法会创建一个定时计划ScheduledFuture,在这个方法需要添加两个参数,Runnable(线程接口类)和CronTrigger(定时任务触发器)(c)在ScheduledFu
- C++11常用新特性(一)
程序员编程指南
c++c语言人工智能
最近工作中,遇到一些问题,使用C++11实现起来会更加方便,而线上的生产环境还不支持C++11,于是决定新年开工后,在组内把C++11推广开来,整理以下文档,方便自己查阅,也方便同事快速上手。(对于异步编程十分实用的Future/Promise以及智能指针等,将不做整理介绍,组内使用的框架已经支持并广泛使用了,用的是自己公司参考boost实现的版本)最近学习人工智能的时候,发现了一个很好的学习网站
- vllm的SamplingParams参数
致Great
算法
vllm部署示例fromvllmimportLLM,SamplingParams#Sampleprompts.prompts=["Hello,mynameis","ThepresidentoftheUnitedStatesis","ThecapitalofFranceis","ThefutureofAIis",]#Createasamplingparamsobject.sampling_param
- 在Windows PC上安装FTDI驱动程序编程
代码幻想花园
windows单片机stm32编程
FTDI(FutureTechnologyDevicesInternational)提供了一系列的USB转串口芯片和驱动程序,使得在Windows操作系统上使用串口通信变得更加便捷。本文将详细介绍如何在WindowsPC上安装FTDI驱动程序并进行编程。步骤1:下载FTDI驱动程序首先,我们需要下载适用于Windows操作系统的FTDI驱动程序。你可以在FTDI官方网站(https://www.f
- 基于python,用django框架,搭建最简单的网站,适合初学者入门
依然风yrlf
pythondjango开发语言
前端页面信息录入页面客户基本信息录入{%csrf_token%}客户的名字:  客户的手机号:客户的身份证:客户的地址:  后台程序基于djang框架wiews.py内容#-*-coding:utf-8-*-from__future__importunicode_literalsfromdjango.httpimportHttpResponsefromdjango.
- io.netty.buffer.SimpleLeakAwareByteBuf cannot be cast to java.lang.String
故山移
在跟着学习netty的粘包和毡包处理时,使用netty自带编码解码类时遇到的一个小问题,附解决方式.client端importio.netty.bootstrap.Bootstrap;importio.netty.buffer.ByteBuf;importio.netty.buffer.Unpooled;importio.netty.channel.ChannelFuture;importio.n
- 多线程中线程池concurrent future的使用
___大鱼___
fromconcurrent.futuresimportThreadPoolExecutor,as_completed,waitimporttime#线程池为什么要线程池?#主线程中可以获取某一个线程的状态或者某一个任务的状态,以及返回值#当一个线程结束后主线程能立刻知道线程结束了#futures可以让多线程和多进程接口一致defget_html(times):time.sleep(3)print
- 剖析以太坊上的庞氏骗局:识别、分析和影响
卷神
区块链安全防护论文翻译:Bartoletti,Massimo,etal."DissectingPonzischemesonEthereum:identification,analysis,andimpact."FutureGenerationComputerSystems102(2020):259-277.摘要:庞氏骗局是一种以高额利润为诱饵的金融欺诈。实际上,只有新用户加入了庞氏骗局,用户才能得
- Swift Combine 用 Future 来封装异步请求 从入门到精通十一
AI架构师易筋
iOSswift开发语言ioscombinefuturepromise
Combine系列SwiftCombine从入门到精通一SwiftCombine发布者订阅者操作者从入门到精通二SwiftCombine管道从入门到精通三SwiftCombine发布者publisher的生命周期从入门到精通四SwiftCombine操作符operations和Subjects发布者的生命周期从入门到精通五SwiftCombine订阅者Subscriber的生命周期从入门到精通六S
- Python多进程执行测试
知识的宝藏
python
#-*-coding:utf-8-*-importconcurrent.futuresimportloggingimportosimportsubprocessimportpytestprojectPath=os.path.dirname(os.path.abspath(__file__))testcase_path=projectPath+'\\po_pattern\\testcase'repo
- Netty Review - NioServerSocketChannel源码分析
小小工匠
【Netty】nettyserversocket
文章目录概述入口NioServerSocketChannel类继承关系实例化过程中做的事情小结概述入口ChannelFuturechannelFuture=serverBootstrap.bind(9000).sync();我们进入bind方法/***Createanew{@linkChannel}andbindit.*/publicChannelFuturebind(intinetPort){/
- AI创作经典科幻《终结者7》电影宣传片
AI电影院
AI电影终结者AI电影AI绘图
AI创作经典科幻《终结者7》电影宣传片ThefutureisthreatenedastheT-1000risesfromtheashesofSkynet.TheTerminator'slegacycontinuesinanewageofmachinesandmayhem.Thewaragainstthemachineswageson,astheresistancefightsforsurvival
- 遍历dom 并且存储(将每一层的DOM元素存在数组中)
换个号韩国红果果
JavaScripthtml
数组从0开始!!
var a=[],i=0;
for(var j=0;j<30;j++){
a[j]=[];//数组里套数组,且第i层存储在第a[i]中
}
function walkDOM(n){
do{
if(n.nodeType!==3)//筛选去除#text类型
a[i].push(n);
//con
- Android+Jquery Mobile学习系列(9)-总结和代码分享
白糖_
JQuery Mobile
目录导航
经过一个多月的边学习边练手,学会了Android基于Web开发的毛皮,其实开发过程中用Android原生API不是很多,更多的是HTML/Javascript/Css。
个人觉得基于WebView的Jquery Mobile开发有以下优点:
1、对于刚从Java Web转型过来的同学非常适合,只要懂得HTML开发就可以上手做事。
2、jquerym
- impala参考资料
dayutianfei
impala
记录一些有用的Impala资料
1. 入门资料
>>官网翻译:
http://my.oschina.net/weiqingbin/blog?catalog=423691
2. 实用进阶
>>代码&架构分析:
Impala/Hive现状分析与前景展望:http
- JAVA 静态变量与非静态变量初始化顺序之新解
周凡杨
java静态非静态顺序
今天和同事争论一问题,关于静态变量与非静态变量的初始化顺序,谁先谁后,最终想整理出来!测试代码:
import java.util.Map;
public class T {
public static T t = new T();
private Map map = new HashMap();
public T(){
System.out.println(&quo
- 跳出iframe返回外层页面
g21121
iframe
在web开发过程中难免要用到iframe,但当连接超时或跳转到公共页面时就会出现超时页面显示在iframe中,这时我们就需要跳出这个iframe到达一个公共页面去。
首先跳转到一个中间页,这个页面用于判断是否在iframe中,在页面加载的过程中调用如下代码:
<script type="text/javascript">
//<!--
function
- JAVA多线程监听JMS、MQ队列
510888780
java多线程
背景:消息队列中有非常多的消息需要处理,并且监听器onMessage()方法中的业务逻辑也相对比较复杂,为了加快队列消息的读取、处理速度。可以通过加快读取速度和加快处理速度来考虑。因此从这两个方面都使用多线程来处理。对于消息处理的业务处理逻辑用线程池来做。对于加快消息监听读取速度可以使用1.使用多个监听器监听一个队列;2.使用一个监听器开启多线程监听。
对于上面提到的方法2使用一个监听器开启多线
- 第一个SpringMvc例子
布衣凌宇
spring mvc
第一步:导入需要的包;
第二步:配置web.xml文件
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5"
xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi=
- 我的spring学习笔记15-容器扩展点之PropertyOverrideConfigurer
aijuans
Spring3
PropertyOverrideConfigurer类似于PropertyPlaceholderConfigurer,但是与后者相比,前者对于bean属性可以有缺省值或者根本没有值。也就是说如果properties文件中没有某个bean属性的内容,那么将使用上下文(配置的xml文件)中相应定义的值。如果properties文件中有bean属性的内容,那么就用properties文件中的值来代替上下
- 通过XSD验证XML
antlove
xmlschemaxsdvalidationSchemaFactory
1. XmlValidation.java
package xml.validation;
import java.io.InputStream;
import javax.xml.XMLConstants;
import javax.xml.transform.stream.StreamSource;
import javax.xml.validation.Schem
- 文本流与字符集
百合不是茶
PrintWrite()的使用字符集名字 别名获取
文本数据的输入输出;
输入;数据流,缓冲流
输出;介绍向文本打印格式化的输出PrintWrite();
package 文本流;
import java.io.FileNotFound
- ibatis模糊查询sqlmap-mapping-**.xml配置
bijian1013
ibatis
正常我们写ibatis的sqlmap-mapping-*.xml文件时,传入的参数都用##标识,如下所示:
<resultMap id="personInfo" class="com.bijian.study.dto.PersonDTO">
<res
- java jvm常用命令工具——jdb命令(The Java Debugger)
bijian1013
javajvmjdb
用来对core文件和正在运行的Java进程进行实时地调试,里面包含了丰富的命令帮助您进行调试,它的功能和Sun studio里面所带的dbx非常相似,但 jdb是专门用来针对Java应用程序的。
现在应该说日常的开发中很少用到JDB了,因为现在的IDE已经帮我们封装好了,如使用ECLI
- 【Spring框架二】Spring常用注解之Component、Repository、Service和Controller注解
bit1129
controller
在Spring常用注解第一步部分【Spring框架一】Spring常用注解之Autowired和Resource注解(http://bit1129.iteye.com/blog/2114084)中介绍了Autowired和Resource两个注解的功能,它们用于将依赖根据名称或者类型进行自动的注入,这简化了在XML中,依赖注入部分的XML的编写,但是UserDao和UserService两个bea
- cxf wsdl2java生成代码super出错,构造函数不匹配
bitray
super
由于过去对于soap协议的cxf接触的不是很多,所以遇到了也是迷糊了一会.后来经过查找资料才得以解决. 初始原因一般是由于jaxws2.2规范和jdk6及以上不兼容导致的.所以要强制降为jaxws2.1进行编译生成.我们需要少量的修改:
我们原来的代码
wsdl2java com.test.xxx -client http://.....
修改后的代
- 动态页面正文部分中文乱码排障一例
ronin47
公司网站一部分动态页面,早先使用apache+resin的架构运行,考虑到高并发访问下的响应性能问题,在前不久逐步开始用nginx替换掉了apache。 不过随后发现了一个问题,随意进入某一有分页的网页,第一页是正常的(因为静态化过了);点“下一页”,出来的页面两边正常,中间部分的标题、关键字等也正常,唯独每个标题下的正文无法正常显示。 因为有做过系统调整,所以第一反应就是新上
- java-54- 调整数组顺序使奇数位于偶数前面
bylijinnan
java
import java.util.Arrays;
import java.util.Random;
import ljn.help.Helper;
public class OddBeforeEven {
/**
* Q 54 调整数组顺序使奇数位于偶数前面
* 输入一个整数数组,调整数组中数字的顺序,使得所有奇数位于数组的前半部分,所有偶数位于数组的后半
- 从100PV到1亿级PV网站架构演变
cfyme
网站架构
一个网站就像一个人,存在一个从小到大的过程。养一个网站和养一个人一样,不同时期需要不同的方法,不同的方法下有共同的原则。本文结合我自已14年网站人的经历记录一些架构演变中的体会。 1:积累是必不可少的
架构师不是一天练成的。
1999年,我作了一个个人主页,在学校内的虚拟空间,参加了一次主页大赛,几个DREAMWEAVER的页面,几个TABLE作布局,一个DB连接,几行PHP的代码嵌入在HTM
- [宇宙时代]宇宙时代的GIS是什么?
comsci
Gis
我们都知道一个事实,在行星内部的时候,因为地理信息的坐标都是相对固定的,所以我们获取一组GIS数据之后,就可以存储到硬盘中,长久使用。。。但是,请注意,这种经验在宇宙时代是不能够被继续使用的
宇宙是一个高维时空
- 详解create database命令
czmmiao
database
完整命令
CREATE DATABASE mynewdb USER SYS IDENTIFIED BY sys_password USER SYSTEM IDENTIFIED BY system_password LOGFILE GROUP 1 ('/u01/logs/my/redo01a.log','/u02/logs/m
- 几句不中听却不得不认可的话
datageek
1、人丑就该多读书。
2、你不快乐是因为:你可以像猪一样懒,却无法像只猪一样懒得心安理得。
3、如果你太在意别人的看法,那么你的生活将变成一件裤衩,别人放什么屁,你都得接着。
4、你的问题主要在于:读书不多而买书太多,读书太少又特爱思考,还他妈话痨。
5、与禽兽搏斗的三种结局:(1)、赢了,比禽兽还禽兽。(2)、输了,禽兽不如。(3)、平了,跟禽兽没两样。结论:选择正确的对手很重要。
6
- 1 14:00 PHP中的“syntax error, unexpected T_PAAMAYIM_NEKUDOTAYIM”错误
dcj3sjt126com
PHP
原文地址:http://www.kafka0102.com/2010/08/281.html
因为需要,今天晚些在本机使用PHP做些测试,PHP脚本依赖了一堆我也不清楚做什么用的库。结果一跑起来,就报出类似下面的错误:“Parse error: syntax error, unexpected T_PAAMAYIM_NEKUDOTAYIM in /home/kafka/test/
- xcode6 Auto layout and size classes
dcj3sjt126com
ios
官方GUI
https://developer.apple.com/library/ios/documentation/UserExperience/Conceptual/AutolayoutPG/Introduction/Introduction.html
iOS中使用自动布局(一)
http://www.cocoachina.com/ind
- 通过PreparedStatement批量执行sql语句【sql语句相同,值不同】
梦见x光
sql事务批量执行
比如说:我有一个List需要添加到数据库中,那么我该如何通过PreparedStatement来操作呢?
public void addCustomerByCommit(Connection conn , List<Customer> customerList)
{
String sql = "inseret into customer(id
- 程序员必知必会----linux常用命令之十【系统相关】
hanqunfeng
Linux常用命令
一.linux快捷键
Ctrl+C : 终止当前命令
Ctrl+S : 暂停屏幕输出
Ctrl+Q : 恢复屏幕输出
Ctrl+U : 删除当前行光标前的所有字符
Ctrl+Z : 挂起当前正在执行的进程
Ctrl+L : 清除终端屏幕,相当于clear
二.终端命令
clear : 清除终端屏幕
reset : 重置视窗,当屏幕编码混乱时使用
time com
- NGINX
IXHONG
nginx
pcre 编译安装 nginx
conf/vhost/test.conf
upstream admin {
server 127.0.0.1:8080;
}
server {
listen 80;
&
- 设计模式--工厂模式
kerryg
设计模式
工厂方式模式分为三种:
1、普通工厂模式:建立一个工厂类,对实现了同一个接口的一些类进行实例的创建。
2、多个工厂方法的模式:就是对普通工厂方法模式的改进,在普通工厂方法模式中,如果传递的字符串出错,则不能正确创建对象,而多个工厂方法模式就是提供多个工厂方法,分别创建对象。
3、静态工厂方法模式:就是将上面的多个工厂方法模式里的方法置为静态,
- Spring InitializingBean/init-method和DisposableBean/destroy-method
mx_xiehd
javaspringbeanxml
1.initializingBean/init-method
实现org.springframework.beans.factory.InitializingBean接口允许一个bean在它的所有必须属性被BeanFactory设置后,来执行初始化的工作,InitialzingBean仅仅指定了一个方法。
通常InitializingBean接口的使用是能够被避免的,(不鼓励使用,因为没有必要
- 解决Centos下vim粘贴内容格式混乱问题
qindongliang1922
centosvim
有时候,我们在向vim打开的一个xml,或者任意文件中,拷贝粘贴的代码时,格式莫名其毛的就混乱了,然后自己一个个再重新,把格式排列好,非常耗时,而且很不爽,那么有没有办法避免呢? 答案是肯定的,设置下缩进格式就可以了,非常简单: 在用户的根目录下 直接vi ~/.vimrc文件 然后将set pastetoggle=<F9> 写入这个文件中,保存退出,重新登录,
- netty大并发请求问题
tianzhihehe
netty
多线程并发使用同一个channel
java.nio.BufferOverflowException: null
at java.nio.HeapByteBuffer.put(HeapByteBuffer.java:183) ~[na:1.7.0_60-ea]
at java.nio.ByteBuffer.put(ByteBuffer.java:832) ~[na:1.7.0_60-ea]
- Hadoop NameNode单点问题解决方案之一 AvatarNode
wyz2009107220
NameNode
我们遇到的情况
Hadoop NameNode存在单点问题。这个问题会影响分布式平台24*7运行。先说说我们的情况吧。
我们的团队负责管理一个1200节点的集群(总大小12PB),目前是运行版本为Hadoop 0.20,transaction logs写入一个共享的NFS filer(注:NetApp NFS Filer)。
经常遇到需要中断服务的问题是给hadoop打补丁。 DataNod