- 批改作业小工具(一)-read report
期末,总是疲于应付各类作业报告批改,搞个小工具,让它帮我一把~~~~(格式)读取报告:importdocxfromdocx.tableimportTabledefextract_experiment_reports(doc_path):"""提取文档中所有实验报告的关键内容"""doc=docx.Document(doc_path)reports=[]#存储所有实验报告fortableindoc.
- 排查解决腾讯云服务器存在对外攻击行为,已阻断该服务器对其他服务器端口(TCP:6379)的访问
【腾讯云】服务违规封禁提醒解决方法来自腾讯客服https://cloud.tencent.com/document/product/296/9604,这是我们给您的建议,建议您排查下您的服务器情况您现在登录上您的服务器了嘛您执行下crontab-l给我看下在执行netstat-ano|egrep"tcp|udp"redis端口这里有问题您执行netstat-tupln给我看下<
- RAG流程中,要怎么对文本进行拆词?
java干货仓库
八股文汇总大模型面试人工智能自然语言处理llama
在RAG(Retrieval-AugmentedGeneration)流程中,对文本的拆词(Tokenization)是影响检索和生成效果的关键步骤。以下是文本拆词的技术细节及优化方法:1.拆词的核心目标检索阶段:确保查询(Query)和文档(Document)的拆词方式一致,提高检索匹配精度。生成阶段:适配大模型的词表,避免生成时的OOV(Out-of-Vocabulary)问题。2.常见拆词方
- !LangChain文档加载器的接口设计与多种格式解析源码深度解析(77)
LangChain文档加载器的接口设计与多种格式解析源码深度解析一、文档加载器概述1.1文档加载器的作用与定位LangChain文档加载器(DocumentLoaders)是整个框架中负责数据输入的核心组件,其主要作用是从不同来源(本地文件、网络资源、数据库等)读取原始文档,并将其转换为LangChain可处理的Document对象格式。在实际应用中,无论是构建问答系统、知识图谱,还是进行文本摘要
- 【STM32】FreeRTOS 任务的创建(二)
这篇文章在于详细解释FreeRTOS中任务的创建过程,包括任务创建的本质过程、API详解、两种创建方式(动态/静态)、任务函数规范、常见错误及实践建议。这里参照:RTOS官方文档:https://www.freertos.org/zh-cn-cmn-s/Documentation/02-Kernel/04-API-references/01-Task-creation/01-xTaskCreate
- Spring 框架中获取 org.w3c.dom.Document 对象的完整流程
探索java
Springjavaspring
引言在Java开发中,XML是一种广泛使用的格式,用于定义配置文件、数据交换等场景。在Spring框架中,XML文件常用于配置应用程序上下文(如applicationContext.xml),或者处理外部系统传输的XML数据。org.w3c.dom.Document是JavaDOMAPI的核心接口,表示一个XML文档的树形结构,允许开发者以编程方式访问和操作XML的内容。Spring框架本身并不直
- QCustomPlot绘图保存成PDF文件
Qt历险记
Qt高级开发工程师pdfqtc++20visualstudio
点击上方"蓝字"关注我们01、QTextDocument>>>QTextDocument是Qt框架中的一个类,用于处理和显示富文本内容。它提供了文本编辑、格式化、布局和渲染等功能。QTextDocument可以包含文本、图像、表格、列表等多种元素,并且可以处理复杂的文本布局和格式。02、QTextObjectInterface>>>QTextObjectInterface是Qt框架中的一个接口,用
- Groupdocs.Viewer for .NET 25.6
sdk大全
AsposeTotalfor.NETGroupdocs
Groupdocs.Viewerfor.NETisaverybasicyetpotenttoolthatallowsdeveloperstorenderdocumentsandenabletheirapplicationstoviewitintheirapplicationswithoutusinganyotherthird-partysoftware,suchasMicrosoftOfficeo
- html+css实战64-综合案例3-图片完成
前端大歌谣
htmlcss前端
Documentbody{background-color:#f5f5f5;}.goods{width:234px;height:300px;background-color:#fff;/*样式居中*/margin:0auto;text-align:center;}img{width:160px;}运行结果
- DOM元素添加技巧全解析
代码的余温
前端
要将一个HTML元素添加到DOM树中,核心方法是先创建元素对象,再将其插入到文档结构中的指定位置。以下是基于常见实践总结的主要技术手段,每种方法均经过验证,确保兼容性和可靠性:1.使用document.createElement()创建并插入元素这是标准且推荐的方式:首先,用document.createElement()创建新元素(如document.createElement('div')),
- canvas入门教学(1)基本认识与了解
WebGIS小智
Canvas专题讲解htmljavascriptcanvaswebgl
从本文章开始,笔者将带大家从0开始,一点一点慢慢的学习canvas。掌握webgl图形渲染的一些底层的原理和逻辑,方便大家后续更容易理解一些gis框架和原理。canvas本质上是一个html元素,和其他html元素一样,本质上也属于document。canvas翻译过来中文叫做画布,顾名思义canvas的设计者最初是希望人们能够在网页上也有绘画的能力。canvas的用途很广,例如游戏,签名类,地图
- Mac 使用Docker安装Elasticsearch、Kibana 、ik分词器、head
风中带血
macosdockerelasticsearch
安装ElasticSearch通过docker安装esdockerpullelasticsearch:7.8.1在本地创建elasticsearch.yml文件mkdir/Users/ky/Documents/learn/es/elasticsearch.yml编辑yml文件内容http:host:0.0.0.0xpack.security.enabled:falsexpack.security.
- SAP-ABAP:SAP中工单号(生产订单号,Order Number)、预留号(Reservation Number)、凭证号(Material Document Number)三者的关系详解
爱喝水的鱼丶
vipSAPABAP运维开发语言
在SAP系统中,工单号(生产订单号,OrderNumber)、预留号(ReservationNumber)和凭证号(MaterialDocumentNumber)三者之间的关联关系贯穿于生产、物料管理和库存操作的全流程。以下是它们的逻辑关系及对应数据库表:1.核心关系流程图工单号(AUFNR)→预留号(RSNUM)→凭证号(MBLNR)工单号驱动预留号的生成(如生产领料需求)。预留号被消耗时生成凭
- SAP-ABAP:SAP DMS(文档管理系统)的详细说明,涵盖其核心功能、架构、配置及实际应用
爱喝水的鱼丶
vipSAPABAP开发语言DMS文档管理系统
1.DMS概述SAPDMS(DocumentManagementSystem)是SAP系统中用于管理企业文档的核心模块,支持文档的全生命周期管理(创建、存储、版本控制、审批、归档)。它与其他模块(如物料管理MM、生产计划PP、设备维护PM)深度集成,确保文档与业务对象的无缝关联。2.DMS核心功能文档存储:支持多种格式(PDF、CAD、图像、Office文档等)。版本控制:跟踪文档变更历史,支持回
- 如何实现打印功能
代码续发
Vue前端
一、AI赋能提供思路基本框架退货单打印内容exportdefault{methods:{handlePrint(){//临时显示打印内容document.getElementById('print-container').style.display='block';//调用打印window.print();//打印完成后隐藏(需延迟执行,确保打印已触发)setTimeout(()=>{docume
- Python删除Elasticsearch指定数据
小李飞刀李寻欢
pythonpythonelasticsearchjenkins
将type类型为keyword的字段为"fw"的数据删除。以下是使用Python删除Elasticsearch中指定数据的实现代码:fromelasticsearchimportElasticsearchdefdelete_fw_documents():#连接到Elasticsearch,根据实际情况修改连接参数es=Elasticsearch(["http://localhost:9200"])
- 2024年前端面试题及答案
2401_84433924
程序员前端
所谓同源是指"协议+域名+端口"三者相同,即便两个不同的域名指向同一个ip地址,也非同源。它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,浏览器很容易受到XSS、CSFR等攻击。3如何解决跨域?能说1,2,7,8就行。1、通过jsonp跨域2、CORS3、document.domain+iframe跨域4、location.hash+iframe5、window.name+iframe跨域
- java解析XML的几种方式
零度anngle
Javajavaxml
第一种:DOM。DOM的全称是DocumentObjectModel,也即文档对象模型。在应用程序中,基于DOM的XML分析器将一个XML文档转换成一个对象模型的集合(通常称DOM树),应用程序正是通过对这个对象模型的操作,来实现对XML文档数据的操作。通过DOM接口,应用程序可以在任何时候访问XML文档中的任何一部分数据,因此,这种利用DOM接口的机制也被称作随机访问机制。DOM接口提供了一种通
- canvas使用
CDwenhuohuo
canva可画
是HTML5引入的一个新标签,它首次出现在2004年的Safari浏览器中,由Apple提出,并在后来的HTML5标准中被正式采纳。IE8及以下❌不支持Canvas的基本用法-WebAPI|MDNvue3import{onMounted}from'vue';onMounted(()=>{constcanvas=document.getElementById('myCanvas');constctx
- Linux 基本命令整理
失因
linux服务器运维开发语言
Linux基本命令整理为了方便初学者快速掌握Linux常用命令,以下是经过分类整理的核心命令及用法说明。目录操作与文件管理pwd核心功能:打印当前工作目录的绝对路径,明确用户所在位置。实操示例:pwd#输出示例:/home/user/documentsls核心功能:列出指定目录中的文件和子目录(默认显示当前目录)。高频选项:-l:长格式显示,包含权限(如-rw-r–r–)、所有者、大小、修改时间等
- 导航系统源码模版,含首页,内页 ,收录提交页
专业软件系统开发
源码下载导航系统源码模版
内容目录一、详细介绍二、效果展示1.部分代码2.效果图展示三、学习资料下载一、详细介绍含首页,内页,收录提交页,到手就可以用,随意接入后台使用,仅供学习无后台版,需要自己傻瓜式接入一下。二、效果展示1.部分代码代码如下(示例):constloginModal=document.getElementById('login-modal');constregisterModal=document.get
- 【亲测免费】 高效TEC温度控制器设计:解锁热电制冷新境界
吴滨柱
高效TEC温度控制器设计:解锁热电制冷新境界【下载地址】高效率TEC温度控制器设计资源下载分享高效率TEC温度控制器设计资源下载项目地址:https://gitcode.com/Open-source-documentation-tutorial/d8924项目介绍在现代科技领域,热电制冷技术(TEC)因其独特的无运动部件、无噪音、无污染等优点,被广泛应用于精密温度控制领域。然而,传统TEC控制器
- java实体类常规校验(字符串不包含空格)
边走、边悟迟早会好1、自定义注解字段内容不能包含空格packagecom.gkfx.farm.space;importjakarta.validation.Constraint;importjakarta.validation.Payload;importjava.lang.annotation.*;//实体类新增修改时不能包含空格@Documented@Constraint(validatedB
- Ascendc helloworld编译问题
1入门ascendc写HelloWorldhttps://www.hiascend.com/document/detail/zh/canncommercial/81RC1/developmentguide/opdevg/Ascendcopdevg/atlas_ascendc_10_0004.html下面是一个简单的AscendC的"HelloWorld"样例,展示了一个AscendC核函数(设备侧
- javascript实现批量打印
十月不到底
javascriptjavascriptweb打印js打印
打印varhtml='你所要打印的html';variframeWindow=document.getElementById("iframePrint");iframeWindow.contentWindow.document.body.innerHTML=html;iframeWindow.contentWindow.print();iframeWindow.contentWindow.loca
- rk3588 rknntoolkit模型转换及部署
Godlovesea
python
cankao参考实时视频取流GNOME桌面—NeardiLinux用户手册v1.1.2documentationhttp://wiki.neardi.com/wiki/linux_guide/zh_CN/docs/demo/demo_gnome.htmlRK3588部署rknntoolkit2进行模型转换_xingman510的博客-CSDN博客以yolov5篇---yolov5训练pt模型并转换
- CSS基础
SMIly_723
css前端
1.css的介绍,什么是cssCSS是CascadingStyleSheets的英文缩写,中文翻译即层叠样式表。css是用于页面布局与美化的,css实现内容与样式分开,这种方式便捷我们的开发。2.css语法css是由选择器,属性,属性值组成的。css有三种引入方式分别是:1.行内样式(内联样式)直接在标签内进行css样式的写入。这是⾏内样式的使⽤⽅式2.内嵌样式(内部样式)Document.tex
- 零基础用Python打造Android字符串资源翻译器(三):读写XML文件
itfitness
目录前言今天主要是使用Python操作xml文件,对xml文件中的字符串进行翻译,效果如下。效果展示关键知识点今天主要是学习了对xml文件的读写操作。xml读取操作:importxml.dom.minidomasminidom#xml读写dom=minidom.parse('strings.xml')root=dom.documentElementstrings=root.getElementsB
- SAP操作手册之 IDOC基础篇
syjf1976_abap
点击蓝字关注我们一前言网上有一个介绍IDOC的文章,讲的非常详细.有兴趣的可以看一下.https://www.cnblogs.com/jiangzhengjun/p/4292135.html#_Toc411677416本文更多的从开发的角度及我的理解去讲解IDOC的一些基础知识,作为一个补充吧.二IDOC是什么IDoc:intermediate(媒介)document.通过特定的方式把接口传递的内
- 操作内联样式-css
虎三呀
#box1{width:100px;height:100px;background-color:red;}window.onload=function(){/**点击按钮以后,修改box1的大小*///获取box1varbox1=document.getElementById("box1");//为按钮绑定单击响应函数varbtn01=document.getElementById("btn01"
- 算法 单链的创建与删除
换个号韩国红果果
c算法
先创建结构体
struct student {
int data;
//int tag;//标记这是第几个
struct student *next;
};
// addone 用于将一个数插入已从小到大排好序的链中
struct student *addone(struct student *h,int x){
if(h==NULL) //??????
- 《大型网站系统与Java中间件实践》第2章读后感
白糖_
java中间件
断断续续花了两天时间试读了《大型网站系统与Java中间件实践》的第2章,这章总述了从一个小型单机构建的网站发展到大型网站的演化过程---整个过程会遇到很多困难,但每一个屏障都会有解决方案,最终就是依靠这些个解决方案汇聚到一起组成了一个健壮稳定高效的大型系统。
看完整章内容,
- zeus持久层spring事务单元测试
deng520159
javaDAOspringjdbc
今天把zeus事务单元测试放出来,让大家指出他的毛病,
1.ZeusTransactionTest.java 单元测试
package com.dengliang.zeus.webdemo.test;
import java.util.ArrayList;
import java.util.List;
import org.junit.Test;
import
- Rss 订阅 开发
周凡杨
htmlxml订阅rss规范
RSS是 Really Simple Syndication的缩写(对rss2.0而言,是这三个词的缩写,对rss1.0而言则是RDF Site Summary的缩写,1.0与2.0走的是两个体系)。
RSS
- 分页查询实现
g21121
分页查询
在查询列表时我们常常会用到分页,分页的好处就是减少数据交换,每次查询一定数量减少数据库压力等等。
按实现形式分前台分页和服务器分页:
前台分页就是一次查询出所有记录,在页面中用js进行虚拟分页,这种形式在数据量较小时优势比较明显,一次加载就不必再访问服务器了,但当数据量较大时会对页面造成压力,传输速度也会大幅下降。
服务器分页就是每次请求相同数量记录,按一定规则排序,每次取一定序号直接的数据
- spring jms异步消息处理
510888780
jms
spring JMS对于异步消息处理基本上只需配置下就能进行高效的处理。其核心就是消息侦听器容器,常用的类就是DefaultMessageListenerContainer。该容器可配置侦听器的并发数量,以及配合MessageListenerAdapter使用消息驱动POJO进行消息处理。且消息驱动POJO是放入TaskExecutor中进行处理,进一步提高性能,减少侦听器的阻塞。具体配置如下:
- highCharts柱状图
布衣凌宇
hightCharts柱图
第一步:导入 exporting.js,grid.js,highcharts.js;第二步:写controller
@Controller@RequestMapping(value="${adminPath}/statistick")public class StatistickController { private UserServi
- 我的spring学习笔记2-IoC(反向控制 依赖注入)
aijuans
springmvcSpring 教程spring3 教程Spring 入门
IoC(反向控制 依赖注入)这是Spring提出来了,这也是Spring一大特色。这里我不用多说,我们看Spring教程就可以了解。当然我们不用Spring也可以用IoC,下面我将介绍不用Spring的IoC。
IoC不是框架,她是java的技术,如今大多数轻量级的容器都会用到IoC技术。这里我就用一个例子来说明:
如:程序中有 Mysql.calss 、Oracle.class 、SqlSe
- TLS java简单实现
antlove
javasslkeystoretlssecure
1. SSLServer.java
package ssl;
import java.io.FileInputStream;
import java.io.InputStream;
import java.net.ServerSocket;
import java.net.Socket;
import java.security.KeyStore;
import
- Zip解压压缩文件
百合不是茶
Zip格式解压Zip流的使用文件解压
ZIP文件的解压缩实质上就是从输入流中读取数据。Java.util.zip包提供了类ZipInputStream来读取ZIP文件,下面的代码段创建了一个输入流来读取ZIP格式的文件;
ZipInputStream in = new ZipInputStream(new FileInputStream(zipFileName));
&n
- underscore.js 学习(一)
bijian1013
JavaScriptunderscore
工作中需要用到underscore.js,发现这是一个包括了很多基本功能函数的js库,里面有很多实用的函数。而且它没有扩展 javascript的原生对象。主要涉及对Collection、Object、Array、Function的操作。 学
- java jvm常用命令工具——jstatd命令(Java Statistics Monitoring Daemon)
bijian1013
javajvmjstatd
1.介绍
jstatd是一个基于RMI(Remove Method Invocation)的服务程序,它用于监控基于HotSpot的JVM中资源的创建及销毁,并且提供了一个远程接口允许远程的监控工具连接到本地的JVM执行命令。
jstatd是基于RMI的,所以在运行jstatd的服务
- 【Spring框架三】Spring常用注解之Transactional
bit1129
transactional
Spring可以通过注解@Transactional来为业务逻辑层的方法(调用DAO完成持久化动作)添加事务能力,如下是@Transactional注解的定义:
/*
* Copyright 2002-2010 the original author or authors.
*
* Licensed under the Apache License, Version
- 我(程序员)的前进方向
bitray
程序员
作为一个普通的程序员,我一直游走在java语言中,java也确实让我有了很多的体会.不过随着学习的深入,java语言的新技术产生的越来越多,从最初期的javase,我逐渐开始转变到ssh,ssi,这种主流的码农,.过了几天为了解决新问题,webservice的大旗也被我祭出来了,又过了些日子jms架构的activemq也开始必须学习了.再后来开始了一系列技术学习,osgi,restful.....
- nginx lua开发经验总结
ronin47
使用nginx lua已经两三个月了,项目接开发完毕了,这几天准备上线并且跟高德地图对接。回顾下来lua在项目中占得必中还是比较大的,跟PHP的占比差不多持平了,因此在开发中遇到一些问题备忘一下 1:content_by_lua中代码容量有限制,一般不要写太多代码,正常编写代码一般在100行左右(具体容量没有细心测哈哈,在4kb左右),如果超出了则重启nginx的时候会报 too long pa
- java-66-用递归颠倒一个栈。例如输入栈{1,2,3,4,5},1在栈顶。颠倒之后的栈为{5,4,3,2,1},5处在栈顶
bylijinnan
java
import java.util.Stack;
public class ReverseStackRecursive {
/**
* Q 66.颠倒栈。
* 题目:用递归颠倒一个栈。例如输入栈{1,2,3,4,5},1在栈顶。
* 颠倒之后的栈为{5,4,3,2,1},5处在栈顶。
*1. Pop the top element
*2. Revers
- 正确理解Linux内存占用过高的问题
cfyme
linux
Linux开机后,使用top命令查看,4G物理内存发现已使用的多大3.2G,占用率高达80%以上:
Mem: 3889836k total, 3341868k used, 547968k free, 286044k buffers
Swap: 6127608k total,&nb
- [JWFD开源工作流]当前流程引擎设计的一个急需解决的问题
comsci
工作流
当我们的流程引擎进入IRC阶段的时候,当循环反馈模型出现之后,每次循环都会导致一大堆节点内存数据残留在系统内存中,循环的次数越多,这些残留数据将导致系统内存溢出,并使得引擎崩溃。。。。。。
而解决办法就是利用汇编语言或者其它系统编程语言,在引擎运行时,把这些残留数据清除掉。
- 自定义类的equals函数
dai_lm
equals
仅作笔记使用
public class VectorQueue {
private final Vector<VectorItem> queue;
private class VectorItem {
private final Object item;
private final int quantity;
public VectorI
- Linux下安装R语言
datageek
R语言 linux
命令如下:sudo gedit /etc/apt/sources.list1、deb http://mirrors.ustc.edu.cn/CRAN/bin/linux/ubuntu/ precise/ 2、deb http://dk.archive.ubuntu.com/ubuntu hardy universesudo apt-key adv --keyserver ke
- 如何修改mysql 并发数(连接数)最大值
dcj3sjt126com
mysql
MySQL的连接数最大值跟MySQL没关系,主要看系统和业务逻辑了
方法一:进入MYSQL安装目录 打开MYSQL配置文件 my.ini 或 my.cnf查找 max_connections=100 修改为 max_connections=1000 服务里重起MYSQL即可
方法二:MySQL的最大连接数默认是100客户端登录:mysql -uusername -ppass
- 单一功能原则
dcj3sjt126com
面向对象的程序设计软件设计编程原则
单一功能原则[
编辑]
SOLID 原则
单一功能原则
开闭原则
Liskov代换原则
接口隔离原则
依赖反转原则
查
论
编
在面向对象编程领域中,单一功能原则(Single responsibility principle)规定每个类都应该有
- POJO、VO和JavaBean区别和联系
fanmingxing
VOPOJOjavabean
POJO和JavaBean是我们常见的两个关键字,一般容易混淆,POJO全称是Plain Ordinary Java Object / Plain Old Java Object,中文可以翻译成:普通Java类,具有一部分getter/setter方法的那种类就可以称作POJO,但是JavaBean则比POJO复杂很多,JavaBean是一种组件技术,就好像你做了一个扳子,而这个扳子会在很多地方被
- SpringSecurity3.X--LDAP:AD配置
hanqunfeng
SpringSecurity
前面介绍过基于本地数据库验证的方式,参考http://hanqunfeng.iteye.com/blog/1155226,这里说一下如何修改为使用AD进行身份验证【只对用户名和密码进行验证,权限依旧存储在本地数据库中】。
将配置文件中的如下部分删除:
<!-- 认证管理器,使用自定义的UserDetailsService,并对密码采用md5加密-->
- mac mysql 修改密码
IXHONG
mysql
$ sudo /usr/local/mysql/bin/mysqld_safe –user=root & //启动MySQL(也可以通过偏好设置面板来启动)$ sudo /usr/local/mysql/bin/mysqladmin -uroot password yourpassword //设置MySQL密码(注意,这是第一次MySQL密码为空的时候的设置命令,如果是修改密码,还需在-
- 设计模式--抽象工厂模式
kerryg
设计模式
抽象工厂模式:
工厂模式有一个问题就是,类的创建依赖于工厂类,也就是说,如果想要拓展程序,必须对工厂类进行修改,这违背了闭包原则。我们采用抽象工厂模式,创建多个工厂类,这样一旦需要增加新的功能,直接增加新的工厂类就可以了,不需要修改之前的代码。
总结:这个模式的好处就是,如果想增加一个功能,就需要做一个实现类,
- 评"高中女生军训期跳楼”
nannan408
首先,先抛出我的观点,各位看官少点砖头。那就是,中国的差异化教育必须做起来。
孔圣人有云:有教无类。不同类型的人,都应该有对应的教育方法。目前中国的一体化教育,不知道已经扼杀了多少创造性人才。我们出不了爱迪生,出不了爱因斯坦,很大原因,是我们的培养思路错了,我们是第一要“顺从”。如果不顺从,我们的学校,就会用各种方法,罚站,罚写作业,各种罚。军
- scala如何读取和写入文件内容?
qindongliang1922
javajvmscala
直接看如下代码:
package file
import java.io.RandomAccessFile
import java.nio.charset.Charset
import scala.io.Source
import scala.reflect.io.{File, Path}
/**
* Created by qindongliang on 2015/
- C语言算法之百元买百鸡
qiufeihu
c算法
中国古代数学家张丘建在他的《算经》中提出了一个著名的“百钱买百鸡问题”,鸡翁一,值钱五,鸡母一,值钱三,鸡雏三,值钱一,百钱买百鸡,问翁,母,雏各几何?
代码如下:
#include <stdio.h>
int main()
{
int cock,hen,chick; /*定义变量为基本整型*/
for(coc
- Hadoop集群安全性:Hadoop中Namenode单点故障的解决方案及详细介绍AvatarNode
wyz2009107220
NameNode
正如大家所知,NameNode在Hadoop系统中存在单点故障问题,这个对于标榜高可用性的Hadoop来说一直是个软肋。本文讨论一下为了解决这个问题而存在的几个solution。
1. Secondary NameNode
原理:Secondary NN会定期的从NN中读取editlog,与自己存储的Image进行合并形成新的metadata image
优点:Hadoop较早的版本都自带,