- Leetcode 518. Coin Change II
小白菜又菜
Leetcode动态规划(DP)解题报告leetcode算法
ProblemYouaregivenanintegerarraycoinsrepresentingcoinsofdifferentdenominationsandanintegeramountrepresentingatotalamountofmoney.Returnthenumberofcombinationsthatmakeupthatamount.Ifthatamountofmoneycan
- JVM调优-学习篇
m0_74825172
面试学习路线阿里巴巴jvm学习
概述公司的江南白衣写了一篇关键业务系统的JVM参数推荐(2016热冬版)的文章,大牛的文章总是需要细细品读。这篇文章介绍大量的JVM调优参数,内容也比较多,本文只是列出我自己能理解的一些参数,暂时理解不了的参数就只能等以后自己实力到家了,再慢慢补充上来。性能调优参数-XX:AutoBoxCacheMaxJAVA进程启动的时候,会加载rt.jar这个核心包的,rt.jar包里的Integer自然也是
- C++学习指南
月眠老师
c++java算法
一、引言C++是一种功能强大的高级编程语言,它融合了面向过程编程和面向对象编程的特性。由于其效率高、可移植性强等优点,广泛应用于系统开发、游戏编程、嵌入式系统等诸多领域。对于想要深入学习C++的人来说,需要全面掌握其语法、编程范式、数据结构、算法以及相关的开发工具等多方面的知识。二、C++基础语法(一)基本数据类型整型(Integer)在C++中有多种整型类型,如int(通常为32位有符号整数)、
- 2024年Java面试:必备的易错面试题及答案整理
ToLoveCode
java面试开发语言
理论基础面试易错题Java基础知识:变量及其作用范围:理解变量的作用域和生命周期,特别是在不同块级作用域中的表现。基本数据类型及其包装类:熟悉Java的基本数据类型(如int、float、char等)及其对应的包装类(如Integer、Float、Character等),以及它们之间的转换。装箱和拆箱:理解Java中的装箱(Boxing)和拆箱(Unboxing)过程,以及它们在自动装箱和拆箱中的
- Day19 第六章 二叉树part07
TAK_AGI
算法力扣
一.学习文章及资料530.二叉搜索树的最小绝对差501.二叉搜索树中的众数236.二叉树的最近公共祖先二.学习内容1.二叉搜索树的最小绝对差递归法:二叉搜索树中序遍历后,其实就是一个有序数组。在一个有序数组上求两个数最小差值,可以用一个pre节点记录一下cur节点的前一个节点,然后计算差值,每一次有更小的就更新minclassSolution{intmin=Integer.MAX_VALUE;;T
- PostgreSQL 数据类型详解
优秀码农哥
数据库postgresql数据库
数字类型PostgreSQL提供了多种数字类型,用于存储不同范围和精度的数值数据。以下是一些常用的数字类型:整数类型:smallint(占用2字节)、integer(占用4字节)、bigint(占用8字节)小数类型:numeric(precision,scale)(用于精确数值计算,根据需要设置精度和小数位数)、decimal(precision,scale)(与numeric类型相同)浮点数类型
- bash 浮点运算_Bash Shell中的浮点
cuma2369
pythonjava大数据linux编程语言
bash浮点运算IntegersarenativelysupportedinBashshell.However,whatifweusefloatingpointinBashshell?Bashshell本机支持整数。然而,如果我们使用浮什么点中的Bashshell?Theshortanddirectanswerisusing‘bc‘command–“Anarbitraryprecisioncalc
- LeetCode Hot100 - 子串篇
搞笑症患者
力扣hot100leetcode算法子串
前言挑战一个月刷完力扣的hot100,记录一下每题的思路~这次是子串相关的题目(1)560.和为K的子数组①暴力枚举,使用一个变量sum记录以l开头r结尾的情况classSolution{publicintsubarraySum(int[]nums,intk){intres=0;//枚举每种情况for(intl=0;lmap=newHashMappq=newPriorityQueueInteger
- C++中函数的调用
ElseWhereR
C++基础学习c++开发语言
*************C++topic:callfunctions*************Havesomebusyworksrecently.Ihaveadoubtsthecallfunctions.firsttakeaddtwointegersfunctionasanexample.Thefunctioniswrittenastheform.函数类型函数名(参数类型参数名){函数体}int
- java lambda表达式编译_什么是Java 8 Lambda表达式编译?
我是一只萤火虫呀
javalambda表达式编译
参见英文答案>HowwillJavalambdafunctionsbecompiled?考虑下面的Java8代码段。publicstaticvoidmain(String[]args){Listintegers=Arrays.asList(1,2,3,4,5);Consumerconsumer=x->System.out.print(x);integers.forEach(consumer);}什
- 关于atomic 是否是线程安全的问题
gp103
ios
在Objective-C里,atomic特性并不能保证对象是完全线程安全的,下面从其基本原理、部分线程安全场景以及局限性来详细说明:先看一个例子#import@interfaceMyClass:NSObject@property(atomic,assign)NSIntegercount;@end@implementationMyClass-(void)incrementCount{self.cou
- 力扣动态规划-28【算法学习day.122】
南宫生
#动态规划算法算法leetcode动态规划java学习
前言###我做这类文章一个重要的目的还是记录自己的学习过程,我的解析也不会做的非常详细,只会提供思路和一些关键点,力扣上的大佬们的题解质量是非常非常高滴!!!习题1.执行操作可获得的最大总奖励I题目链接:3180.执行操作可获得的最大总奖励I-力扣(LeetCode)题面:附上灵神代码:importjava.math.BigInteger;classSolution{publicintmaxTot
- 月薪30k 的Java面试题,哭着也要背完!(附答案)
spring架构师1776
javajvm面试spring架构
最近整理了一份面试题,只要你能好好地背,找工作就妥妥的稳。话不多说,请看题。注意:文章有点长。Java基础Java语言有哪些特点面向对象和面向过程的区别面向对象编程三大特性八种基本数据类型的大小,以及他们的封装类说说你对JDK、JRE、JVM的理解说说标识符的命名规则熟悉instanceof关键字的作用吗?说说Java自动装箱与拆箱说说重载和重写的区别Integera=127与Integerb=1
- 数据结构-1.Java. 初始包装类与泛型
薯条不要番茄酱
Java数据结构java数据结构后端开发语言学习方法程序人生
本节目标:学习包装类与泛型为阅读java集合源码打下基础.1.包装类在Java中,由于基本类型不是继承自Object,为了在泛型代码中可以支持基本类型,Java给每个基本类型都对应了一个包装类型.1.1基本数据类型对应包装类基本数据类型包装类byteByteshortShortintIntegerfloatFloatdoubleDoublecharCharacterbooleanBooleanlo
- leetcode - 442. Find All Duplicates in an Array
KpLn_HJL
OJ题目记录leetcode算法职场和发展
DescriptionGivenanintegerarraynumsoflengthnwherealltheintegersofnumsareintherange[1,n]andeachintegerappearsonceortwice,returnanarrayofalltheintegersthatappearstwice.YoumustwriteanalgorithmthatrunsinO(
- LeetCode --- 2200. Find All K-Distant Indices in an Array 解题报告
杨鑫newlfe
PythonLeetCode算法leetcode数据结构算法python面试
Question:Youaregivena0-indexedintegerarraynumsandtwointegerskeyandk.Ak-distantindexisanindexiofnumsforwhichthereexistsatleastoneindexjsuchthat|i-j|kand|0-5|>k
- map 转 list、int[] 转 List、String[] 转 List
弧失七
java类型转换
一、map转listMapmap=Maps.newHashMap();Listlist=newArrayList(map.values());二、int[]转Listint[]id={1,2,3,4,5,6,7,8,9,10};Listlist=Arrays.stream(id).boxed().collect(Collectors.toList());三、String[]转Long[]Strin
- rdian是一个结构体,pdian=^Rdian,list泛型做什么用?
ljklxlj
delphi
不明白不让编译的原因,记录下之遇到注意原油。varmylist:TList;mylist1:TList;mydian:Pdian;i:Integer;mylist2:TList;mydian2:rdian;arr:arrayofRdian;beginmylist:=TList.Create;mylist.add('ljk');mylist[0]:='ljkk';mylist.free;mylist
- spring boot接收请求常用注解
Lzehui
springbootjava数据库
@RequestBody用于将HTTP请求体(例如JSON、XML等)中的数据绑定到控制器方法的参数上示例:@PostMapping("/status/{status}")publicResultstartOrStop(@PathVariable("status")Integerstatus,Longid){categoryService.startOrStop(status,id);return
- Python一切皆对象
weixin_30768661
pythonjava
Python从设计之初就是一门面向对象的语言,它有一个重要的概念,即一切皆对象。Java虽然也是面向对象编程的语言,但是血统没有Python纯正。比如Java的八种基本数据类型之一int,在持久化的时候,就需要包装成Integer类对象。但是在python中,一切皆对象。数字、字符串、元组、列表、字典、函数、方法、类、模块等等都是对象,包括你的代码。对象的概念究竟何谓对象?不同的编程语言以不同的方
- Java开发中常用的包详解
猿享天开
Java开发从入门到精通java网络windows开发语言
Java开发中常用的包详解Java编程语言提供了丰富的标准库,通过合理的包分类和功能划分,能够帮助开发者快速找到所需的功能模块。以下是Java开发中常用的包及其详细介绍:1.基础核心包:java.lang描述:这是Java语言的核心包,包含了基本的类,如String、Integer、Math等。这个包的类在Java程序中几乎无处不用,是自动导入的。常用类:String:字符串操作Integer/D
- Java中List去重和Stream去重的示例分析
广州的程序猿
javajavaservletjvm
首先,给出我们要排序的对象User@Data@Builder@AllArgsConstructorpublic class User { private Integer id; private String name;}List users = Lists.newArrayList( new User(1, "a"), new User(1, "b"), new User(2,
- Gym 101532 contest (未完)
佑月、
个人总结,如果有错的地方,欢迎大佬纠正。A-SubarraysBeauty(二进制+贡献)Youaregivenanarrayaconsistingofnintegers.Asubarray(l, r)fromarrayaisdefinedasnon-emptysequenceofconsecutiveelementsal, al + 1, ..., ar.Thebeautyofasubarray
- 2020最全的BAT大厂面试题整理改版 (2)
2401_86963927
javajvm开发语言
一、java面试题熟练掌握java是很关键的,大公司不仅仅要求你会使用几个api,更多的是要你熟悉源码实现原理,甚至要你知道有哪些不足,怎么改进,还有一些java有关的一些算法,设计模式等等。(一)java基础面试知识点java中==和equals和hashCode的区别int、char、long各占多少字节数int与integer的区别谈谈对java多态的理解String、StringBuffe
- 定时任务线程池ScheduledThreadPoolExecutor
immdwbs
java多线程java
1、创建最大线程数设为Integer.MAX_VALUE,非核心线程空闲时间设置为0。2、方法packageThreadPool;importjava.time.LocalDateTime;importjava.time.format.DateTimeFormatter;importjava.util.concurrent.Executors;importjava.util.concurrent.
- Java程序员必看!10个让你深夜加班的开发深坑,第5个几乎人人都踩过
Java先进事迹
javapython开发语言
引言Java作为一门“成熟稳重”的语言,总能让开发者产生“一切尽在掌握”的错觉。然而,真实的开发战场上,无数程序员在深夜对着屏幕咬牙切齿:“这代码为什么又崩了?!”本文揭露10个Java开发中看似简单却杀伤力极强的陷阱,附赠避坑指南,建议反复背诵!1.空指针的“替身攻击”:自动拆箱的暗箭错误示例java代码解读复制代码Integertotal=null;intresult=total;//自动拆箱
- TypeError: ‘decimal.Decimal‘ object cannot be interpreted as an integer
废废的棍仔
python
这里直接翻译了一下。。。TypeError:'decimal.Decimal'对象不能被解释为一个整数然后把range()函数中用到的num,直接定义为int类型,就好像OK了?这算是解决了这个问题了吗?反正运行起来是没报错了,也不知道对不对,笑哭。print("——拼手气红包——")fromdecimalimport*importrandomtotal=input("请输入红包总金额:")num
- Java泛型深度解析(JDK23)
代数狂人
Javajava开发语言
第一章泛型革命1.1类型安全的进化史前泛型时代的类型转换隐患代码的血泪史(Java1.4版示例):ListrawList=newArrayList();rawList.add("Java");rawList.add(Integer.valueOf(42));//编译通过//灾难在运行时爆发StringfirstElement=(String)rawList.get(0);//正常Stringsec
- 【hot100】141环形链表
鱼力舟
HOT100链表数据结构
一、思路题目较为简单,主要运用了HashSet存储地址以及不重复的特性其中较为绕的是存储的是地址,那常规数值(Integer、int)的时候为什么可以判定重复,以下是文心一言的答复问题1:HashSet如果存的是地址,那为什么可以判断两个数字的重复在Java中,HashSet是一个基于哈希表的数据结构,用于存储不重复的元素。HashSet内部实际上是通过HashMap来实现的,其中每个元素都作为H
- PySpark学习笔记5-SparkSQL
兔子宇航员0301
数据开发小白成长笔记学习笔记
sparkSql的数据抽象有两种。一类是dataset适用于java和Scala一类是dataframe适用于java,Scala,python将rdd转换为dataframe#方式一df=spark.createDataFrame(rdd,schema=['name','age'])#方式二schema=Structtype().add('id',integertype(),nullable=F
- 算法 单链的创建与删除
换个号韩国红果果
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较早的版本都自带,