- reduce 到底是什么?Java8 Stream 的终极聚合工具详解
程序员
reduce()是JavaStreamAPI提供的一个终端操作方法,用于将流中的元素组合起来生成一个单一的值。这一方法非常强大,可以实现累积、聚合、拼接等功能,适用于各种数据处理场景。1.reduce()方法的作用reduce()是一个通用的归约操作,它通过一个关联函数,逐个处理流中的每个元素,将其累积为一个值。方法签名如下:无初始值的reduceOptionalreduce(BinaryOper
- ASP.NET Core - 依赖注入(四)
啊晚
ASP.NETCORE系列总结asp.net后端
ASP.NETCore-依赖注入(四)4.ASP.NETCore默认服务5.依赖注入配置变形4.ASP.NETCore默认服务之前讲了中间件,实际上一个中间件要正常进行工作,通常需要许多的服务配合进行,而中间件中的服务自然也是通过Ioc容器进行注册和注入的。前面也讲到,按照约定中间件的封装一般会提供一个User{Middleware}的扩展方法给用户使用,而服务注册中也有一个类似的约定,一般会有一
- ASP.NET Core - 配置系统之配置读取
啊晚
ASP.NETCORE系列总结microsoft.netcoreasp.net
ASP.NETCore-配置系统之配置读取1.配置读取一个应用要运行起来,往往需要读取很多的预设好的配置信息,根据约定好的信息或方式执行一定的行为。配置的本质就是软件运行的参数,在一个软件实现中需要的参数非常多,如果我们以HardCode(硬编码)的方式写在应用代码中,这样配置就会很乱,而且后续也不容易修改。乱而多,而且不容易修改,这就需要一个统一管理的地方,最常见的方式就是配置文件,这个也是开发
- DDR 带宽的计算与监控
算法自动驾驶
DDR带宽(DoubleDataRateBandwidth)是指DDR内存在一秒内可以传输的数据量,通常以GB/s(Gigabytespersecond)为单位。它是衡量内存系统性能的重要指标,直接影响系统的数据吞吐能力。1.如何计算DDR带宽计算DDR理论带宽的公式为:DDR主频*位宽=理论带宽其中,位宽(bitwidth)指的是内存总线的位宽,例如64位、128位、16bit、32bit等,b
- MySQL数据库表的设计
weixin_34289744
数据库python
2019独角兽企业重金招聘Python工程师标准>>>表的约束主键约束createtablestudent(idintprimarykey,namevarchar(40));createtablestudent(idintprimarykeyauto_increment,namevarchar(20));唯一约束createtablestudent(idintprimarykeyauto_incr
- java race condition_Java多线程Race Condition vs. Data Race
邢仁
javaracecondition
http://blog.regehr.org/archives/490Araceconditionisaflawthatoccurswhenthetimingororderingofeventsaffectsaprogram’scorrectness.Generallyspeaking,somekindofexternaltimingororderingnon-determinismisneede
- python转换视频格式为mp4
宁君
Pythonpython
1.第一种方法电脑下载安装ffmpeg方法见mac电脑安装ffmpeg两种方法然后代码如下frommoviepy.editorimportVideoFileClipimportosimportffmpegdefconvert_video_to_mp4(input_video_path,output_video_path):'''速度慢,CPU狂飙:paraminput_video_path::pa
- 【FAQ】HarmonyOS SDK 闭源开放能力 —Map Kit(4)
1.问题描述:添加了很多的marker点,每个marker点都设置了customInfoWindow,但是每次只能显示一个customInfoWindow吗?解决方案:Marker的InfoWindow每次只能显示一个。2.问题描述:在地图选型中,1.使用华为MapKit,和使用高德、腾讯等SDK上,有什么优缺点比较吗?2.MapKit是否需要商业授权?价格如何?3.两种方案,最后App包大小是否
- 《CPython Internals》阅读笔记:p151-p151
python
《CPythonInternals》学习第9天,p151-p1510总结,总计1页。一、技术总结无。二、英语总结(生词:1)1.marshal(1)marshalingMarshallingormarshaling(USspelling)istheprocessoftransformingthememoryrepresentationofanobjectintoadataformsuitablef
- 卓越效能,极简运维,体验云上的Serverless架构,领取转轮日历!
数据库mysql
技术解决方案【CloudUp挑战赛】」上线了!业务的持续稳定可服务,决定着企业对客户的服务质量,是企业发展的基础。应用部署的高可用架构和弹性能力对于业务的稳定与发展起着至关重要的作用,但企业同时需要考虑资源维护成本和费用成本。本方案采用云上的Serverless架构,整合了专有网络VPC、应用型负载均衡ALB、Serverless应用引擎以及PolarDBMySQL版Serverless数据库服务
- Python单例模式中的问题
后端python
一、装饰器形式的单例模式首先先给出Python中装饰器的单例模式:python代码解读复制代码importthreadingdefsingleton(cls):_instances={}_lock=threading.Lock()defget_instance(*args,**kwargs):ifclsnotin_instances:with_lock:ifclsnotin_instances:_
- 《CPython Internals》阅读笔记:p118-p150
python
《CPythonInternals》学习第8天,p118-p150总结,总计33页。一、技术总结补充一些本人整理的关于Context-FreeGrammar(CFG)的知识。1.symbol(符号)Amathematicalsymbolisafigureoracombinationoffiguresthatisusedtorepresentamathematicalobject(符号是一个数字或数
- MYSQL数据库表的设计
qq_45849275
java
一、https://blog.csdn.net/jasonhui512/article/details/53134054页面原型需求分析表结构的设计数据库设计案例elasticSearchpostgresqlmongodbRedisneo4jfastDFSmemcachemavengitsvnluencemybatismybatisplusspringspringMVCspringbootspri
- 【LeetCode】路径总和 III
Seal^_^
编程专栏#LeetCodeleetcode算法二叉树数据结构C语言
【LeetCode】路径总和IIITheBegin点点关注,收藏不迷路给定一个二叉树的根节点root,和一个整数targetSum,求该二叉树里节点值之和等于targetSum的路径的数目。路径不需要从根节点开始,也不需要在叶子节点结束,但是路径方向必须是向下的(只能从父节点到子节点)。示例1:输入:root=[10,5,-3,3,2,null,11,3,-2,null,1],targetSum=
- springBoot整合mongdb
一决威严-雪雪
2024java开发整理springboot后端java
1.添加依赖首先,在你的pom.xml文件中添加MongoDB的依赖: org.springframework.boot spring-boot-starter-data-mongodb2.配置MongoDB连接在application.properties或application.yml文件中配置MongoDB的连接信息:spring:data:mongodb:uri:mongodb:/
- 《CPython Internals》阅读笔记:p96-p96
python
《CPythonInternals》学习第6天,p96-p96总结,总计1页。一、技术总结1.parser-tokenizerp92,Creatingaconcretesyntaxtreeusingaparser-tokenizer,orlexer.p96,CPythonhasaparser-tokenizermodule,writteninC.当做这在92页提到parser-tokenizer的
- ARM和x86区别
qq_34385566
作者:波心荡链接:https://www.zhihu.com/question/20148756/answer/103220283来源:知乎著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。多方位对比ARM和x86CPU两大架构现在发展如何?附全文随便逮住一个人问他知不知道CPU,我想他的答案一定会是肯定的,但是如果你再问他知道ARM和X86架构么?这两者的区别又是什么?绝大多数
- Python列表方法
L_lemo004
Pythonpython
目录添加元素Pythonappend()方法添加元素Pythonextend()方法添加元素Pythoninsert()方法插入元素删除元素del:根据索引值删除元素pop():根据索引值删除元素remove():根据元素值进行删除clear():删除列表所有元素修改元素修改单个元素修改一组元素查找元素index()方法count()方法添加元素实际开发中,经常需要对Python列表进行更新,包括
- 【Docker-2】在 Debian 上安装 Docker 引擎
小白--AI
docker容器dockerdebianeureka
在Debian上安装Docker引擎要开始在Debian上使用Docker引擎,请确保满足先决条件,然后按照安装步骤操作。先决条件操作系统要求要安装DockerEngine,您需要以下Debian之一的64位版本版本:DebianBookworm12(稳定版)DebianBullseye11(旧稳定版)Debian的Docker引擎兼容x86_64(或amd64)、armhf、arm64、和PPC
- 主体分割技术,提升图像信息提取能力
在智能设备普及和AI技术进步的推动下,用户对线上互动的质量、个性化以及沉浸式体验的追求日益增强。例如,对于热衷于图片编辑或视频制作的用户来说,他们需要一种快速而简便的方法来将特定主体从背景中分离出来。HarmonyOSSDK基础视觉服务(CoreVisionKit)提供主体分割能力,可以检测出图片中区别于背景的前景物体或区域(即"显著主体"),并将其从背景中分离出来,适用于需要识别和提取图像主要信
- HarmonyOS Next Developer Beta2 7月尝鲜版版本说明
harmonyos
课程简介本课程是【HarmonyOSTechTalk】的第27课。本次交流涵盖多方面重要内容。首先是版本说明的更新,包括历史版本归一化与开发者界面变更分类,依影响程度区分不同应用变更类型。接着聚焦HarmonyOSNEXTDeveloperBeta2-7月尝鲜版,其版本配套、新增及变更特性值得关注。而CodeGenie插件更是亮点,在代码生成与补全、智能知识问答、万能卡片代码生成等场景大显身手。开
- C/C++三方库编译构建
harmonyos
课程简介本课程是【HarmonyOSTechTalk】的第19课。本次交流聚焦于C/C++三方库在HarmonyOS开发中的应用。首先是适配HarmonyOS工具链,这是将开源三方库融入鸿蒙生态的关键步骤,确保其兼容性与稳定性。DevEcoStudio则是构建的得力助手,可用于打造自定义三方库,满足特定开发需求。在Native工程里使用这些三方库,能拓展功能、提升效率。通过本次课程学习,开发者能够
- IDEA 中编写 MyBatis 的 XML 文件,parameterType 无法跳转到类 Cannot find declaration to go to.
_Max_Ma
MyBatisintellij-ideamybatisxml
出现上图的问题,resultMap标签中的type和parmeterType中的类报红且无法跳转到对应的类中,此问题可能有几个原因:1.没有配置别名2.没有写全路径解决方法:alias配置别名(具体可以看其他文章的配置)写全类路径
- Spring Cache自定义过期时间
背景要求:对数据做统计分析,时间截止到当天零点根据要求,每天查询的数据范围都是截止前一天结束,第二天需要查询新数据。那么缓存只保留一天。使用caffeine简单举个例子,主要依赖有:org.springframework.bootspring-boot-starter-web2.7.18org.springframework.bootspring-boot-starter-cache2.7.18c
- pandas
大哥喝阔落
pandas
pandasPandas内置数据结构我们知道,构建和处理二维、多维数组是一项繁琐的任务。Pandas为解决这一问题,在ndarray数组(NumPy中的数组)的基础上构建出了两种不同的数据结构,分别是Series(一维数据结构)DataFrame(二维数据结构):Series是带标签的一维数组,这里的标签可以理解为索引,但这个索引并不局限于整数,它也可以是字符类型,比如a、b、c等;DataFra
- Pycharm快捷键
大哥喝阔落
pycharmidepython
PyCharm常见快捷键汇总常用快捷键快捷键功能Ctrl+Q快速查看文档(快速某个函数功能)Ctrl+F1显示错误描述或警告信息Ctrl+/行注释(可选中多行)Ctrl+Alt+L代码格式化Ctrl+Alt+O自动导入Ctrl+Alt+I自动缩进Tab/Shift+Tab缩进、不缩进当前行(可选中多行)Ctrl+C/Ctrl+Insert复制当前行或选定的代码块到剪贴板Ctrl+D复制选定的区域C
- PyEcharts 基本图表之词云图
开不开心少年
头哥题目python开发语言
第1关:WordCloud:词云图任务描述本关任务:利用所学知识,按要求自行绘制一个词云图。相关知识为了完成本关任务,你需要掌握:1.Python的基本语法,2.PyEcharts词云图的相关内容。编程要求根据以上介绍,在右侧编辑器补充代码,使用给定数据绘制一个词云图,要求:系列名称设置为空,数据项为data,单词字体大小范围设置为20到100,词云图轮廓设置为全局变量中的SymbolType.D
- 免费通配符SSL证书获取流程
https
以JoySSL为例,获取免费通配符SSL证书的流程如下一、注册并申请证书1.访问服务商官网:打开JoySSL的官方网站,找到免费证书申请页面,2.注册账号:在注册过程中,填写相关信息,并输入特定的注册码(230916)以获取免费申请名额。免费通配符SSL证书:https://www.joyssl.com/certificate/select/joyssl-dv-wildcard-free-1.ht
- SQL: 求连续登录天数,间隔1天也算作连续
问题需求:计算每个用户最大的连续登录天数,可以间隔一天。解释:如果一个用户在第1,3,5,6,9天登录游戏,则视为连续6天登录CREATETABLElog(idVARCHAR(1),timedate);insertintologvalues('A','2024-12-20');insertintologvalues('A','2024-12-24');insertintologvalues('A'
- 基于SHM的IPC库的性能和功能比较
c++ipc
使用SHM来传输tlmpayload测试前言我花了几天打算自己写一个zero-copy的版本,使用boost里现成的managed_shared_memory和interprocess_semphore,container/vector等库,但压力测试一直有问题,有的传100多笔数据就出错,有的500多笔数据出错,都是boost低层的rbtree之类的内存布局出错,调不下去,所以放弃自己写,而寻找
- 算法 单链的创建与删除
换个号韩国红果果
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较早的版本都自带,