- 【每日一词】D33 edge
宠辱不惊的中年少女
1)学习笔记:edge:优势,=advantagebeanabsoluteedge有绝对优势AhasanedgeoverB表示A比B更好maintainone'sedge保持优势loseone'sedge失去优势innovativeedge创新方面的优势2)查字典延伸:A.就工作经验而言,她显然要比我们面试过的其他人都胜出一筹。Intermsofexperience,shedefinitelyha
- 31岁了,转行
YueTan
background经常看到提问,27了学编程晚了吗,28转行来得及吗?我确在31岁的时候开始了一段新的旅途。毕业后一直在外企世界50强工作,论舒服的话真的是很舒服,办公室环境,工作压力,出国出差都是很诱惑的,现在离开了才感受到另一个重要的是品牌的认同感吧,那种一提起公司所有人都知道的品牌那种感觉。experience说起来确是一波三折。前前后后找新工作已经一年了,赶上这两年行业环境一年比一年差。
- ACCA F2重要知识:Planning and Control丨ACCA F2微课堂(2)
ACCA学习帮
干货丨拓展丨趣闻丨指南ACCAF2丨文:EstelleACCAF2把管理活动总结为三个词:planning,controlanddecision-making.这里通过举例讲解一下Planningandcontrol.1.Planning(关键词是objective/goalandstrategy)(i)Establishthecompany’sgoal:increaseprofitby20%in
- Unity3d学习笔记
明月海子
Mecanin动画系统.pngNavigation导航系统.pngShader渲染基础.png面向对象六大原则.png策略模式Strategy.png工厂模式Factory产品工厂.png观察者Observer.png结构设计模式总结.png模板方法模式TemplateMethod.png适配器模式Adapter.png外观模式Facade.png职责连模式ChainofResponsibilit
- 名诗我译(伊丽莎白·布朗宁篇)——Sonnets From The Portuguese(34) 葡萄牙的十四行诗 第34首
臻念
译文:真念一思作者:伊丽莎白·布朗宁Withthesameheart,Isaid,I'llanswertheeAsthose,whenthoushaltcallmebymyname--Lo,thevainpromise!Isthesame,thesame,Perplexedandruffledbylife'sstrategy?Whencalledbefore,ItoldhowhastilyIdro
- vulnhub靶机-DC2-Writeup
含日
靶机linux安全靶机渗透测试安全漏洞
0x01部署靶机地址:https://www.vulnhub.com/entry/dc-2,311/DESCRIPTIONMuchlikeDC-1,DC-2isanotherpurposelybuiltvulnerablelabforthepurposeofgainingexperienceintheworldofpenetrationtesting.AswiththeoriginalDC-1,i
- recover device type disk copy of database 还不会用!!!!
jnrjian
数据库oracle
ImplementingaDualBackupStrategywithBackupstoDiskandRecoveryAppliance(DocID2154461.1)RMAN-HowtoimplementDualBackupstrategy(DocID3003000.1)ZeroDataLossRecoveryApplianceSoftware-Version12.1.0.1.0andlater
- 【软件设计】常用设计模式--策略模式
秦哈哈
软件设计设计模式策略模式
软件设计模式(三)策略模式(StrategyPattern)1.概念2.模式结构3.UML类图4.实现方式C#示例步骤1:定义策略接口步骤2:实现具体策略类步骤3:实现上下文类步骤4:使用策略模式Java示例步骤1:定义策略接口步骤2:实现具体策略类步骤3:实现上下文类步骤4:使用策略模式5.优点6.缺点7.应用场景8.与其他模式的比较小结策略模式变体和实际应用场景1.变体变体1:组合模式与策略模
- 刘亦菲教你读英文
一瓣山河
《StillnessSpeaks》Thoughts,emotions,senseexperiences,andwhateveryouexperience,makeupthecontentofyourlife.“Mylife”iswhatyouderiveyoursenseofselffrom,andmylifeiscontent,orsoyoubelieve“你的生活”是你自我意识的衍生Youco
- 设计模式 -- 策略模式(Strategy Pattern)
xiaoyu❅
设计模式设计模式策略模式
1问题引出1.1鸭子项目有各种鸭子(比如野鸭、北京鸭、水鸭等,鸭子有各种行为,比如叫、飞行等)显示鸭子的信息1.2传统方式其它鸭子,都继承了Duck类,所以fly让所有子类都会飞了,这是不正确的上面说的1的问题,其实是继承带来的问题:对类的局部改动,尤其超类的局部改动,会影响其他部分。会有溢出效应为了改进1问题,我们可以通过覆盖fly方法来解决=>覆盖解决问题又来了,如果我们有一个玩具鸭子ToyD
- latex转word python_分分钟甩Word几条街,Python编辑公式竟可以如此简单
weixin_39553904
latex转wordpython
点击上方"Python人工智能技术"关注,星标或者置顶22点24分准时推送,第一时间送达来自:公众号机器之心|编辑:真经君Python人工智能技术(ID:coder_experience)第221次推文图源:百度上一篇:华科博士201万,西安交大本科生100万!华为「天才少年」校招薪资曝光正文用Word写PDE公式简直是找虐。我们在Word中编辑文本时,遇到超复杂的公式,想想就令人头大,一个不小心
- 设计模式生产环境实践------策略模式
hungteshun
设计模式策略模式
一、业务背景前端有一棵树形结构的目录,需要实现目录层级的拖拽来变换顺序二、定义接口publicinterfaceITreeStructureStrategy{/***操作树形结构*@paramreqDTO*/voidoperate(TreeStructureOperateReqDTOreqDTO);/***策略实现类-操作类型**@return*/IntegergetType();}三、接口实现定
- EasyExcel表格导出自动列宽设定
SheldonChang
POIexcelpoi
EasyExcel表格导出自动列宽设定publicstaticclassAutoColumnWidthStrategyimplementsCellWriteHandler{@OverridepublicvoidbeforeCellCreate(WriteSheetHolderwriteSheetHolder,WriteTableHolderwriteTableHolder,Rowrow,Headh
- 商务英语 Level 3 Unit 2 Part 1 Vocabulary【How to Answer a Call】
流非沫
Vocabulary【HowtoAnsweraCall】Effectivecustomerservicecallsareimportantforincreasingcustomersatisfaction.Whencustomershaveapositiveexperience,theyaremorelikelytobecomeloyalcustomers.Whenansweringacustom
- 工厂模式和策略模式的区别
Stringzhua
每日一问策略模式工厂模式
文章目录工厂模式(FactoryPattern)设计意图适用场景结构优点缺点Java实现案例策略模式(StrategyPattern)设计意图适用场景结构优点缺点Java实现案例对比总结工厂模式(FactoryPattern)设计意图工厂模式的主要目的是将对象的创建与使用分离,通过一个工厂类来负责创建实例。这样,当我们需要创建新的对象时,不需要直接使用构造函数,而是通过工厂类来生成对象。这种模式在
- feign调用走不走网关全局拦截_feign在服务间传递header
小葙
场景:用户登陆后,再次访问网页,将用户信息loginToken放在request的header中,首先经过网关,然后到达A服务,然后A服务调用B服务时如何把loginToken传递给B服务1.修改hytrix配置,配置hytrix的strategy为SEMAPHORE。Hystrix提供两种执行隔离策略(ExecutionIsolationStrategy):SEMAPHORE、THREADSEM
- DragonFireFury
lanyue456
Alongtimeago,inapowerfulcountry,therewasakingwholovedmoneyverymuch.Hewantedatreasurewithalotofgemsinthemountainsbuthewasveryafraidofthetyrannosaurusthatguardedthetreasure.Sohecameupwithastrategy,hecal
- 【早安心语】
壹典心理咨询
【2020-5-10】早安春夏秋冬Youmustknowthatthebeautyofapersonisnottheface,butallthepastexperiences.Eleganceisnotatraining,butakindofexperience.Indifferentisnotadisguise,butaaccumulation.PeoplewillneverOld,oldiso
- springboot策略解决低耦合 函数计算调用问题
烟雨国度
springboot状态模式后端
当然,我理解您现在可能感到有些混乱。让我为您创建一个详细的程序执行流程图,以帮助您更好地理解整个过程。策略选择和计算前端请求处理CalculationStrategyFactory初始化应用启动扫描组件注入策略列表遍历策略列表获取类名转为小写策略实例HTTPPOST解析请求体获取toolname根据toolname查找返回策略实例返回计算结果调用CalculationStrategyFactory
- 解决 Resolved versions for app (26.1.0) and test app (27.1.1) differ的办法
tgcity
在对应的build.gradle文件中添加configurations.all{resolutionStrategy.force'com.android.support:support-annotations:26.1.0'}
- Navicat BI Viewer Crack
SEO-狼术
netDelphiCrack开发语言
NavicatBIViewerCrackKeyFeaturesofNavicatBIViewer:System-WideDarkMode:Allowsforamorecomfortableviewingexperiencebyapplyingdarkmodeacrosstheapplication.NavigationPane:Accessandmanagelocalandcloud-stored
- EasyExcel--自定义表头(标题)样式策略
南晓枫
前言:在项目开发中,我们有时候会遇到自定义表头样式的需求。EasyExcel官方文档中关于表头样式的说明有两种(以设置表头颜色为例):方式1:通过使用注解来设置颜色(优点:使用非常方便,缺点:对于复杂表头就无能为力了,例如无法单独设置父表头和子表头的颜色)方式2:通过使用HorizontalCellStyleStrategy策略的方式来设置表头颜色(优点:通过此策略可以对表头设置更多的样式,缺点:
- 【重走编程路】设计模式概述(八) -- 策略模式、模板方法模式
咖啡+=方糖
重走编程路设计模式策略模式模板方法模式
文章目录前言13.策略模式(Strategy)定义解决方案应用场景优缺点14.模板方法模式(TemplateMethod)问题解决方案应用场景优缺点前言行为型模式关注对象之间的交互以及如何分配职责,提供了一种定义对象之间的行为和职责的最佳方式。本章介绍创建型模式中的策略模式和模板方法模式。13.策略模式(Strategy)定义策略模式定义了一系列算法,并将每一种算法封装起来,使它们可以相互替换。策
- 《认知行为疗法入门》回避策略 自弃策略
心理咨询师卜彬
贝克认为,个体为了遮掩其负性核心信念,会发展出一套心理策略,并且通过这套策略使自己看起来(不是别人看来)是正面的形象。这套心理策略被称为补偿策略(CompensatoryStrategy)。对多数个体而言,比较常见的负性核心信念是“无能的”和“不可爱的”两类。常见的补偿策略有以下七个类别:●努力策略;●回避策略;●顺从策略;●归因策略;●警惕策略;●自弃策略;●自恋策略。回避策略是最常见的补偿策略
- 设计模式--策略模式
Liu_Junwei
设计模式设计模式策略模式java
策略模式(StrategyPattern)是一种行为型设计模式,用于定义一系列算法,并将每一个算法封装起来,使它们可以相互替换。策略模式让算法的变化独立于使用算法的客户。主要角色策略(Strategy)接口:定义了一个公共接口,所有具体策略类都需要实现这个接口。具体策略(ConcreteStrategy):实现了策略接口的具体算法。上下文(Context):持有一个策略对象的引用,用于调用策略对象
- 行为模式6.备忘录模式------文本的撤销和保存
臣妾写不来啊
23种设计模式备忘录模式
行为型模式模板方法模式(TemplateMethodPattern)命令模式(CommandPattern)迭代器模式(IteratorPattern)观察者模式(ObserverPattern)中介者模式(MediatorPattern)备忘录模式(MementoPattern)解释器模式(InterpreterPattern)状态模式(StatePattern)策略模式(StrategyPat
- 设计模式-工厂模式和策略模式的区别
workflower
设计方法策略模式设计模式架构课程设计设计规范
工厂模式和策略模式都是设计模式中的重要组件,它们用于解决不同类型的软件设计问题。以下是它们之间的区别:目的不同:工厂模式(FactoryPattern)的主要目的是创建对象。它提供了一种创建对象的接口,使得子类可以决定实例化哪一个类。工厂模式的重点在于如何创建和管理对象。策略模式(StrategyPattern)旨在定义一系列算法,将每个算法封装起来,并使它们可以互换。策略模式使得算法可以在不影响
- Unity游戏中常用的设计模式——策略模式
LittleBridLibrary
Unity3D设计模式unity
策略模式策略模式:它定义了算法家族,分别封装起来,让它们之间可以互相替换,策略模式让算法的变化,不会影响到使用算法的客户。//抽象算法类策略类publicabstractclassStrategy{//算法方法publicabstractvoidAlgorithmInterface();}//具体算法ApublicclassConcreteStrategyA:Strategy{//算法A实现pub
- 【Unity3D与23种设计模式】策略模式(Strategy)
林尧彬
设计模式游戏
GoF中定义:“定义一组算法,并封装每个算法,让它们之间可以彼此交换使用。策略模式让这些算法在客户端使用它们时能更加独立。”游戏开发过程中不同的角色会有不同的属性计算方法初级解决方法便是:ifelse,不够再来几个ifelse高级点儿的就用switchcase配合enum对于小型项目或者快速开发验证用的项目而言,这么做是没问题的但是开发规模或产品化项目时,最好还是选择策略模式在策略模式中,算法中的
- Unity中的策略模式
菜园赤子
设计模式
策略模式主要用于游戏中的数值计算。为不同角色的相同方法提供统一的接口。方便管理。usingUnityEngine;publicclassTest:MonoBehaviour{privatevoidStart(){StrategyContextstrategyContext=newStrategyContext(newConcreteStrategyA());strategyContext.Do()
- 算法 单链的创建与删除
换个号韩国红果果
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较早的版本都自带,