- 18scala笔记
sorry_maker
笔记scala
Scala2.12视频地址1入门1.1发展历史…1.2Scala和JavaScala=Java++编写代码使用scalac编译成.class字节码文件scala+.class文件执行代码1.3特点1.4安装视频地址注意配置好环境变量简单代码1.5编译文件编译scala文件会产生两个.class文件使用java命令执行scala编译出的class文件,报错:正确方法如下1.6IDEA使用创建mave
- IntelliJ IDEA 2023.2 主要更新了什么?(纯文本介绍版)
猫头虎
高效办公工具专区#IDEA专栏intellij-ideajavaide
博主猫头虎带您GotoNewWorld.✨博客首页——猫头虎的博客《面试题大全专栏》文章图文并茂生动形象简单易学!欢迎大家来踩踩~《IDEA开发秘籍专栏》学会IDEA常用操作,工作效率翻倍~《100天精通Golang(基础入门篇)》学会Golang语言,畅玩云原生,走遍大小厂~希望本文能够给您带来一定的帮助文章粗浅,敬请批评指正!文章目录摘要:主要更新用户体验JavaScala性能运行/调试版本控
- 初试python
Truman_9d15
弄完javascala,再来弄python何时才有入门的体验Numbers(数字):int(有符号整型)long(长整型[也可以代表八进制和十六进制])float(浮点型)complex(复数)String(字符串)List(列表)list=[1,2.0,“sss”]Tuple(元组)tuple=(1,2.0,“sss”)相当于只读列表Dictionary(字典)tinydict={'name':
- IntelliJ IDEA 2023.1 最新变化 【附带ChatGPT教程】
一个小浪吴啊
intellij-ideascalajava
ChatGPT开源公众号:https://gitee.com/wy521a/astar-weixin-mp最新变化2023.1主要更新用户体验编辑器JavaScala分析器版本控制系统构建工具运行/调试框架和技术DockerKubernetes远程开发和协作Web开发其他在浏览器中打开IntelliJIDEA2023.1最新变化主要更新PreviousNext新UI增强测试版根据有关IDE新UI的
- spark异常处理
简约AI
sparkscala
spark异常处理类javascala可以写成类似java的异常处理模式,如果是读取本地文件,importjava.io.FileReaderimportjava.io.FileNotFoundExceptionimportjava.io.IOExceptionobjectDemo{defmain(args:Array[String]){try{valf=newFileReader("input.
- java-scala 高效混合开发
AndyMocan
javascalaspringboot
javascala混合开发知名应用Kafka(消息系统)Spark(计算引擎)Play(新一代web全栈框架)Akka(高可伸缩性的Java和Scala的Actor模型应用)scala优点Scala是一种有趣的语言。它一方面吸收继承了多种语言中的优秀特性,一方面又没有抛弃Java这个强大的平台,它运行在Java虚拟机(JavaVirtualMachine)之上,轻松实现和丰富的Java类库互联互通
- Java 获取所有子类信息
weixin_30925411
我以前的博客(JavaScala获取注解的类信息)介绍过通过Reflections工具通过使用特定注解的类的信息,其实本工具也可以获取接口,抽象类,类等的所有子类信息。使用方法如下:Reflectionsreflections=newReflections("my.project");Set>subTypes=reflections.getSubTypesOf(SomeType.class);下面
- 考试总结
weixin_38677730
二简述题题目一:scala源于java但高于javaScala的类和方法的修饰符与java不同Scala默认是publicjava默认是protectedJava支持接口scala不支持接口采用traitScala支持函数式编程题目二:rdd不支持sparlsqlDataFrame=rdd+schemaDataset=rdd+schemaDataFrame=Dataset[Row]题目三:自定义分
- Scala与Java语言的差异
WongKyunban
Scala
1、源文件后缀名Java:.javaScala:.scala2、变量Java:intparam1=100;intparam2Scala:格式:varVariableName:DataType[=InitialValue]示例:varparam1:String="HelloScala"varparam2="helloscala"//编译器会根据值来推断参数类型varparam3:String//局部
- 记一次 HDFS NameNode GC 调优
秦夏
没有碰到过GC问题的人生对写Java的人来说是不完整的。大数据生态圈的框架大都以JVM系语言开发(JavaScala为主),毕竟生态成熟嘛要啥有啥。HDFS作为大数据领域的默认分布式文件系统,其运作方式导致了非常容易碰到GC问题:大量的元数据需要保存在内存中,使得很容易就需要几十G甚至100多G的堆大量且高并发的文件读写操作使得频繁地产生新对象下面就举两个例子,简单分享下我们做的一些调优。案例一有
- Flink学习 - 2. Flink之WordCount
Jerome丶子木
Flinkflink
Flink学习-2.Flink之WordCountFlink项目要求Flink项目模板基于java实现的项目模板MavenarchetypeQuickStart基于Scala实现的项目模板MavenarchetypeQuickStart构建Flink项目Maven依赖java项目scala项目项目代码javascala执行过程中问题Flink项目要求Maven3.0.4(或者更高)Java8.xF
- Scala基本语法(一)
心_的方向
认识Scala同样是以JVM环境运行Scala语言底层就是JavaScala命令行学习语法整数相加res0是scala中的shell给出的一个默认的变量名称,用来存储这个结果的,冒号后面即为这个结果的类型。输出文本println是scala预定义导入的类。写helloworld程序//object表示这是一个单例对象objectHelloWorld{//args为参数名,Array[String]
- linux 管道命令
Helen_Cat
linux的管道命令说实话应该是linux最大的亮点,主要是是扩展性真的很强大,任何一种语言强大之处,大部分是因为他的可扩展性灵活性,C族语言的指针,C#的委托,Java的反射,Scala的Implicit,golang的管道协程,python的短小精悍。我这次想说的就是linux管道和python调试经常写javascala的童鞋,都习惯于在IDE中调试,尤其是IDEA,主要是可以看到每一个变量
- 变量的声明
lehuai
打开cmd,输入scala,进入交互模式scala>vala=123a:Int=123scala>vars="java"s:String=javascala>s="scala"s:String=scalascala>sres0:String=scalascala>vala:Int=123a:Int=123scala>vars:String="scala"s:String=scala
- sparkdl && tensorframes python 版 安装 mac
Helen_Cat
image.png在我们使用tensorflow和spark结合的时候,肯定非常激动,关键我们打算使用哪一种语言建构我们的机器学习代码,最主要的的有四种,pythonjavascalaR,当然python是门槛较低的。使用javascala一般人不一定能hold的住,所以我们首先讲python版的工具链首先假设你已经有了一台macpro安装了python3.5或者3.6jdk8,最好不要用jdk9
- 工程师日记-浅谈一位后台工程师的成长路程-20181105
Allen同学
最近软文看的有点多,没学什么新技术,主要是把之前学的知识串起来。本片只介绍一个初级工程师到1/2中级工程师的成长路程。正常来说,一名初级工程师成长到中级工程师,需要三年时间。大概就是20170801到20181115这段时间内我的技能栈的扩展。2017年先说一下我的技能栈:编程语言javamysql:基本语句+存储过程+函数+视图级联更新redisngnix2018年javascala的一点皮毛s
- 【Spark】简单入门——HelloWorld
quit3e
环境IntelliJIDEA+Maven+Spark_2.1.1JDK_1.8.0_131Scala_2.11.0语言JavaScala目的读取README.md文件并显示文件内容过程新建工程:File->NewProject,选择MavenNewProject1点Next进入下一步输入GroupId和ArtifactIdNewProject2点Next进入下一步NewProject3点Finis
- 2.Scala语言基础
nxf_rabbit75
一、编程范式命令式编程没有办法充分利用多核CPU;函数式编程很多变量是不可修改的。二、Scala简介特点scala运行在JVM上,兼容现有的Java程序;面向对象的编程语言;一门函数式语言三、Scala的安装1.windows系统安装Scala第一步:安装JavaScala程序需要运行在JVM(Java虚拟机)上,因此,在安装Scala之前,需要在Windows系统中安装Java环境。可以到Jav
- scala-1-简介
晏十一的实验室
日常基础scala
1、Scala语言介绍1.1、语言类型scala是面向对象语言。是函数式编程语言。是静态类型语言,不提供冗余类型的信息。大多数情况下,不需要指定类型。scala运行在JVM上。scala编译器将scala代码编译成java字节代码,然后通过scala命令执行。scala可以执行java代码。scala可以做并发和同步处理。1.2、Scala与Javascala具有与java完全不同的一组功能,如下
- Java 获取所有子类信息
BarryW
我以前的博客(JavaScala获取注解的类信息)介绍过通过Reflections工具通过使用特定注解的类的信息,其实本工具也可以获取接口,抽象类,类等的所有子类信息。使用方法如下:Reflectionsreflections=newReflections("my.project");Set>subTypes=reflections.getSubTypesOf(SomeType.class);下面
- jyputer notebook 与pyspark在本地windows的环境配置
maketubu7
sparkpython
1、下载anacond并安装,可以选择自动配置环境变量,也可以后面手动配置环境变量2、http://spark.apache.org/downloads.html下载spark的对应版本3、解压到一个指定的你想要存放的本地spark目录,自己创建,方便以后管理4、设置各种环境变量,如下这里javascala的环境配置不必要但是还是需要配置一下,特别注意这里的PYSPARK_PYTHONPYSPAR
- 十六,与java交互
苏门学士
scala
结合scala和javascala和java高度兼容,因此可以进行互操作,大多数情况下结合这两种语言时并不需要太多顾虑,尽管如此,有时你还是会遇到一些结合java和scala的问题。基本上,scala使用java代码相对于java使用scala代码更容易一些。scala代码如何被翻译:scala的实现方式是将代码翻译为标准的java字节码。scala的特性尽可能地直接映射为相对等的java特性。但
- Spark编程指南(三)
steanxy
Spark
共享变量广播变量累加器部署到集群从JavaScala运行Spark作业单元测试共享变量通常,当一个函数传递给在远程集群节点上执行的Spark操作(如map或reduce)时,函数使用的是所有变量的独立副本。这些变量会拷贝到每台机器上,并且远程机器上的变量没有更新到驱动程序中。跨任务读写共享变量是无效的。Spark为两种常见的使用模式提供两种类型的共享变量:广播变量和累加器。广播变量广播变量允许开发
- spark本地模式和Standalone配置
lm709409753
spark
local模式非常适合作业的开发调试,配置也很简单,把编译好的文件解压,然后配置即可使用。使用自己编译产生的tgz压缩包步骤:前提:安装Scala(2.10.4)和JDK(1.7.x+)-解压ln-sspark-1.6.0-bin-2.5.0/spark-修改相关参数到/spark/conf目录下修改文件vimspark-env.shJAVA_HOME=/opt/modules/javaSCALA
- 导航
-Finley-
时光荏苒转眼间这个博客我已经写了三年之久,为了方便读者也方便自己查询故编写本索引。笔者才疏学浅,另有部分文章成文较早笔者无力一一校正可能包含较多错误,请各位不吝赐教。非另有说明,本博客原创内容采用创作共享:署名(BY)-非商业性(NC)-相同方式共享(SA)3.0版本授权。后端机器学习编程语言JavaScala后端RedisKV型内存数据库RedisRedis集群Redis持久化机制Redis分布
- 低延迟系统的最佳实践
大糊涂
1.选择正确的语言脚本语言不能使用,尽管它们可以运行得更快更快,当你寻找对几毫秒延迟都不能忍受时,就不能有解释语言的开销,你希望有一个强大的内存模型,能够无锁编程,可选语言有JavaScala和C11或Go。2.将一切放在内存中I/O会杀死你的延迟,确保你所有的数据都在内存中,这就意味着你自己要管理你的数据结构,以及维护一个持久日志,这样,你才能在机器重新启动后重建原来内存状态,持久日志的选择有:
- NetBeans 时事通讯(刊号 # 60 - Jun 21, 2009)
javasalatu
Netbeans
项目新闻NetBeansIDE6.7RC3发布了NetBeans.org宣布了NetBeansIDE6.7RC3已经可用来。NetBeans6.7最大的焦点是互联性的增强,它使得开发者之间的协作更为简单。这里查看该版本细节,下载并试用NetBeans6.7RC3,并告诉我们您的想法吧!文章Scala与JavaScala运行于JVM上,它能与Java进行非常好的混合编程,特别是使用NetBeansI
- NetBeans 时事通讯(刊号 # 60 - Jun 21, 2009)
DL88250
HibernatescalaNetbeansgroovyJavaFX通讯
项目新闻NetBeansIDE6.7RC3发布了NetBeans.org宣布了NetBeansIDE6.7RC3已经可用来。NetBeans6.7最大的焦点是互联性的增强,它使得开发者之间的协作更为简单。这里查看该版本细节,下载并试用NetBeans6.7RC3,并告诉我们您的想法吧!文章Scala与JavaScala运行于JVM上,它能与Java进行非常好的混合编程,特别是使用NetBeansI
- 遍历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