- Java 反射基础
文章目录反射:框架设计的灵魂一、获取Class对象的方式1、Class.forName("全类名")2、类名.class3、对象.getClass()注意:二、class对象功能1、获取成员变量们2、获取构造方法们3、获取成员方法们4、获取全类名三、Field:成员变量1、设置值2、获取值3、忽略访问权限修饰符的安全检查四、Constructor:构造方法1、创建对象:2、忽略访问权限修饰符的安全
- python namedtuple转为dict
链池
python开发语言
python相关学习资料:搭建私人助理大模型需要什么环境?006_指法标准_键盘正位_你好世界_hello_world_单引号_双引号一张图生成指定动作的动态视频,MagicAnimate本地部署Pythonnamedtuple转为dict的方法作为一名经验丰富的开发者,我很高兴能够帮助刚入行的小白们解决编程问题。今天,我们将一起学习如何将Python中的namedtuple转换为dict。这个过
- Python namedtuple 详解:作用与使用方法
文章目录一、什么是namedtuple主要特点:二、namedtuple的作用1.替代普通元组,提高代码可读性2.替代简单类,减少样板代码3.作为轻量级数据结构三、基本使用方法1.创建namedtuple类型2.创建实例3.访问字段4.不可变性测试四、高级特性与方法1._asdict()-转换为有序字典2._replace()-创建新实例并替换字段3._fields-查看字段名4._make()-
- MySQL8数据库高级特性
KellenKellenHao
oracle数据库sql
创建测试表 createdatabasejxcharactersetutf8; usejx; my>descusers; +----------+-------------+------+-----+---------+----------------+ |Field |Type |Null|Key|Default|Extra | +----------+-------------+--
- Django双下划线查询
八九燕来
djangosqlite数据库
在Django中,双下划线(__)查询是一种强大的语法,用于在ORM(对象关系映射)中跨关联模型进行字段查询,或使用内置查询表达式(如过滤、聚合等)。以下是其核心用法和示例:1.跨关联模型查询通过双下划线可以引用关联模型(ForeignKey、ManyToManyField、OneToOneField)的字段。示例模型:classAuthor(models.Model):name=models.C
- Kotlin 协程四 —— Flow 和 Channel 的应用
金戈鐡馬
Androidkotlinandroid协程FlowChannel
一、Flow与Channel的相互转换1.1Flow转换为Channel1.1.1ChannelFlow@InternalCoroutinesApipublicabstractclassChannelFlow(//upstreamcontext@JvmFieldpublicvalcontext:CoroutineContext,//buffercapacitybetweenupstreamandd
- 3.5 const限定修饰符
尘世闲鱼
C++PrimerC++学习开发语言C++
节以魔法数字为引介绍了C++中的const限定修饰符的使用,主要分为两个部分:1、const修饰的变量;2、const修饰的指针const修饰的变量魔法数字(MagicNumber)是指在代码中直接使用的没有明确含义的常量数字,它们通常没有解释或说明,因此对代码的可读性、可维护性和可扩展性造成负面影响。例如,下列代码中的“3.14159”即为魔法数字。doublecalculateArea(dou
- Elasticsearch 查询统计 A 字段全部为空的 B 字段(qbit)
前言本文对Elasticsearch7.17适用问题是有两个字符串字段app_id和owner,怎么查询app_id全部为空字符串的owner有哪些?查询DSL语句{"size":0,"aggs":{"owners":{"terms":{"field":"owner",//取决于owner字段的基数"size":10000},"aggs":{"non_empty_app_id_docs":{"fi
- C#-Type&Assembly
霸王奉先
C#c#开发语言TypeAssembly程序集反射类反射
一.TypeDLL文件在被加载至内存时每一个类都有一个Type,根据Type可获取类的方法,字段等信息.<1.获取所有字段#获取string类对应TypeTypetype=typeof(string);#获取私有字段,公有字段,静态字段FieldInfo[]allFields=type.GetFields(BindingFlags.Public|BindingFlags.NonPublic)<2.
- python魔法方法长文详解
千翻娃儿
python原生基础python
python魔法方法详解1.什么是魔法方法魔法方式(Magicmethods)是python的内置函数,一般以双下划线开头和结尾,比如__add__,__new__等。每个魔法方法都有对应的一个内置函数或者运算符。当我们个对象使用这些方法时,相当于对这个对象的这类方法进行重写(如运算符重载)。魔法方法的存在是对类或函数进行了提炼,供python解释器直接调用。当使用len(obj)时,实际上调用的
- crdb_ado_res_nl.dll ContextManager.dll CATGmoOperators.dll crdb_fielddef_res_es.dll CATInt3DMap.
a***0738
microsoftwindowsvisualstudio
在使用电脑系统时经常会出现丢失找不到某些文件的情况,由于很多常用软件都是采用MicrosoftVisualStudio编写的,所以这类软件的运行需要依赖微软VisualC++运行库,比如像QQ、迅雷、Adobe软件等等,如果没有安装VC++运行库或者安装的版本不完整,就可能会导致这些软件启动时报错,提示缺少库文件。如果我们遇到关于文件在系统使用过程中提示缺少找不到的情况,如果文件是属于运行库文件的
- Redission实现的分布式锁的可重入性
俏布斯
redisredis
Redisson分布式锁在Redis中存储可重入状态所使用的Hash结构,并通过示例说明。核心数据结构Key:锁的名称。例如:"myLock"。数据类型:Hash(RedisHSET/HGET/HINCRBY操作的对象)。HashField(字段名):客户端唯一标识符。格式通常为:UUID:threadId。UUID:生成Redisson客户端实例时创建的一个全局唯一ID(一个JVM进程一个)。t
- OneCode FormField 基础表单字段 功能说明
低代码老李
低代码软件行业领域设计低代码人工智能javaspring
一、基础表单组件组件名称功能说明CustomFormComponent基础表单布局组件,负责表单数据的加载、绑定、校验和提交,支持自定义布局和事件处理CustomMFormComponent主从表单组件,支持主子表数据结构,实现主表与子表数据的联动加载、保存和校验TableFormComponent表格表单组件,基于数据库表元数据动态生成表单,支持字段权限控制和动态列显示FormLayoutMod
- 深入解析C语言位域
第九先生
C/C++系列c语言开发语言
一、位域是什么?为何需要它?位域(BitField)是C语言中一种特殊的结构体成员,允许开发者以比特(bit)为单位精确分配内存空间,而非传统的字节或字。其核心价值在于:节省内存:例如布尔标志(0/1)仅需1比特,而非1字节(8比特),在嵌入式系统或海量数据场景下可显著降低内存占用硬件交互:直接映射硬件寄存器的特定位(如使能位、状态码),替代繁琐的位掩码操作协议解析:精准匹配网络/文件协议的紧凑字
- 《重构》笔记摘录 - 9.处理继承关系
使二颗心免于哀伤
《重构》笔记摘录重构笔记
文章目录1函数上移(PullUpMethod)2字段上移(PullUpField)3构造函数本体上移(PullUpConstructorBody)4函数下移(PushDownMethod)5字段下移(PushDownField)6以子类取代类型码(ReplaceTypeCodewithSubclasses)7移除子类(RemoveSubclass)8提炼超类(ExtractSuperclass)9
- el-form的重置表单(resetFields())不生效解决方法
zhuà!
javascriptvue.js前端vueelementui
产生问题的原因总结ref的定义与使用时,因为写错,单词不一致el-form-item标签中绑定的prop与form对象中的变量不一致在dialog或drawer组件中嵌套使用form时,先点击编辑后,直接给组件中的form赋值,导致form在第一次加载生成的时候,“初始值”直接就成了,当前编辑的form值,如果第一次是点击的添加功能,则“初始值”为空,一切正常解决方法检查ref以及prop单词是否
- MySQL使用C语言连接
shilinnull
MySQLmysql
文章目录版本查看以及编译mysql接口介绍初始化链接数据库下发mysql命令mysql_query获取执行结果mysql_store_result获取结果行数mysql_num_rows获取结果列数mysql_num_fields获取列名mysql_fetch_fields获取结果内容mysql_fetch_row关闭mysql链接mysql_closeC语言操作mysql查看连接数代码样例官网下
- java arthas redefine实现热替换某个类
master-dragon
#java类加载和gcjavaarthas
简单的看下arthasredefine类的效果,需要注意redefine的class不能修改、添加、删除类的field和method,包括方法参数、方法名称及返回值。redefine后的原来的类不能恢复,redefine有可能失败(比如增加了新的field),参考jdk本身的文档。redefine命令和jad/watch/trace/monitor/tt等命令会冲突。执行完redefine之后,如
- odoo17 警示: selection attribute will be ignored as the field is related
信息化未来
数据库
在Odoo17中,当使用related字段时,直接在fields.Selection中指定选择列表会被忽略(因为选择项会从关联字段继承)。wtd_fuwlx=fields.Selection('服务类型',related='wtd_id.fuwlx',store=True)遇到了一个警告,提示在Odoo17中,由于字段是关联字段(relatedfield),所以selection属性将被忽略。在O
- 用自定义注解解决excel动态表头导出的问题
Java知识技术分享
java技术exceljavaintellij-idea数据库
导入的excel有固定表头+动态表头如何解决自定义注解:importjava.lang.annotation.*;/***自定义注解,用于动态生成excel表头*/@Target(ElementType.FIELD)@Retention(RetentionPolicy.RUNTIME)public@interfaceFieldLabel{//字段中文Stringlabel();//字段顺序into
- 自定义注解的使用
Java知识技术分享
java技术javaspring后端
自定义注解/***自定义注解*/@Target(ElementType.FIELD)@Retention(RetentionPolicy.RUNTIME)public@interfaceFieldLabel{//字段中文Stringlabel();//字段顺序intorder()default0;//分组标识Stringgroup()default"default";}解析自定义注解://1、获取
- MyBatis-Plus 实战:优雅处理 JSON 字段映射(以 JSONArray 为例)
William Dawson
mybatisjson
MyBatis-Plus实战:优雅处理JSON字段映射(以JSONArray为例)作者:WilliamDawson|更新日期:2025-04-21标签:MyBatis-Plus、JSON、TypeHandler、@TableField、@TableName、FastJSON在使用MyBatis-Plus进行业务开发时,我们时常需要把数据库中的JSON字段(比如字符串形式的数组)自动映射成Java
- 精准定义 RediSearch 索引 Schema
Hello.Reader
数据库缓存技术人工智能djangopython后端
一、Schema基础概念索引(Index):对Redis中的Hash或JSON文档进行反向索引,以支持全文、标签、数值、地理、向量等多种查询模式。Schema:定义索引结构,包括哪些字段(fields/attributes)、字段类型、是否可排序、权重(relevanceweight)、过滤条件等。在执行FT.CREATE时,必须指定:数据类型:ONHASH或ONJSONKey前缀(可选):PRE
- django form组件
fightingwy
pythondjango
djangoform组件:校验数据:校验数据,是后端的Form类对象通过render先渲染到前端,然后浏览器用户输入数据提交到后端,后端根据类中的字段设置的属性来判断数据是否合法。校验数据的步骤:第一步需要一个form类,其实就是表单类啦,我们不设置就是text:classMyForm(forms.Form):name=forms.CharField(max_length=8,min_length
- C# 操作mongodb 多次查询快还是使用管道查询速度快
Accpdaiyekun
mongodbc#mongodblua
最近特殊原因,需要查询表数据,分别两张表,结构大概如下:publicpartialclassItemRelationPO:DbExtField{//////道具ID唯一///[BsonId][BsonElement("ItemOid")]publiculongItemOid{get;set;}//////父节点///publiculongParent{get;set;}//////所有者ID///
- Python中的语法糖介绍
硅星纯牛码
pythonpython
Python中的语法糖介绍1.魔法方法(magicmethods)基础魔法方法属性相关的魔法方法2.装饰器(decorators)内置装饰器@property:让方法变为虚拟属性@classmenthod:定义类方法@staticmethod:定义静态方法functools中的装饰器functoolswraps:保留元数据functoolslru_cache:缓存计算结果3.推导式(compreh
- mongodb 基本概念
重生之我是一名程序员
mongodb
mongodb基本概念基于mongo:4.4.2databasedatabase数据库tablecollection数据库表/集合rowdocument数据记录行/文档columnfield数据字段/域indexindex索引tablejoins表连接,MongoDB不支持primarykeyprimarykey主键,MongoDB自动将_id字段设置为主键MongoDB数据类型数据类型描述Str
- shopex48mysql索引优化
showker
mysql
altertablesdb_pluginsaddindexidx_type_identifier(plugin_type,plugin_ident);CREATEINDEXidx_disabled_varnameONsdb_magicvars(disabled,var_name);CREATEINDEXidx_goods_type_spec_typeidONsdb_goods_type_spec(
- Django REST framework - 序列器关系
djangopython
简介数据结构而非算法是编程的核心。—RobPike关系字段用于表示模型间的关系。它们可以应用于ForeignKey、ManyToManyField和OneToOneField关系,以及反向关系和自定义关系(如GenericForeignKey)。注意:关系字段在relations.py中声明,但按照惯例,应从serializers模块导入,使用fromrest_frameworkimportser
- Python@dataclass装饰器实践
首尔的初雪是眼泪
pythonpythonwindows
目录1.基本使用1.1示例:基本的数据类1.2__init__自动生成2.字段的默认值2.1带有默认值的字段2.2field()函数3.不可变数据类(frozen=True)4.比较与排序4.1支持排序的dataclass5.继承与dataclass5.1继承dataclass6.总结在Python中,@dataclass是一个非常有用的装饰器,它能够自动为类生成一些常见的方法,例如__init_
- 算法 单链的创建与删除
换个号韩国红果果
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较早的版本都自带,