- python sanic orm_sanic中使用tortoise-orm
Mr浪子相依
pythonsanicorm
#models.pyfromtortoise.modelsimportModelfromtortoiseimportfieldsclassUser(Model):id=fields.IntField(pk=True,,source_field="userID")name=fields.CharField(max_length=100)date_field=fields.DateTimeField(
- Django 创建好的模块怎么在后台显示
u010373106
pythonDjangodjango数据库sqlite
1、配置模型及其需要显示的数据刚才创建好的tests的增删改查,在后台是不显示的,所以需要进行配置,在刚才创建好的模块里找到admin.py文件,在里面进行如下配置fromdjango.contribimportadminfrom.importmodelsfrom.modelsimportTests#Registeryourmodelshere.classTestsAdmin(admin.Mode
- 连续发送多个数据(uart串口RS232协议/verilog详细代码+仿真)
勇敢牛牛(FPGA学习版)
fpga开发嵌入式硬件matlab智能硬件
写在前言以下内容详细源文件,已经上传个人主页资源,需要自取~目录写在前言需求分析UART简介整体架构流程小结需求分析使用串口(rs232协议)间隔1s连续发送16byte的数据。由于每次发送的数据只有8bit,16byte=128bit,所以要发送16帧。UART简介这里实验所使用的参数有:rs232通信协议+9600bps+quartus18.0+modelsim2020异步通信:UART是一种
- django实操:换用自建mysql用户表(一次失败的经历)
EelBarb
pythondjangomysqlpython
前言别想了,基础不扎实的话,还是老老实实用django自带的用户模块吧!这是一次耗时而且失败了的经历。因为是一次失败的经历,这里我给出一些残酷的经验。实操重写用户模型这是我唯一成功的案例,你需要建一个类似如下的django-orm模型mysql_models.pyfromdjango.dbimportmodelsfromdjango.contrib.auth.modelsimportAbstrac
- 7、Django Admin删除默认应用程序
背着吉他去流浪
DjangoAdmindjangopython后端
admin文件fromdjango.contrib.auth.modelsimportUser,Groupadmin.site.unregister(User)admin.site.unregister(Group)显示效果:前后
- 10、Django Admin修改标题
背着吉他去流浪
DjangoAdmindjango数据库sqlite
adminfromdjango.contribimportadminfrom.modelsimportCategory,Origin,Hero,Villain#添加以下代码admin.site.site_header="系统管理"admin.site.site_title="管理员界面"admin.site.index_title="欢迎来到这里!"#注册模型#admin.site.registe
- Django后端架构开发:后台管理与会话技术详解
Switch616
PythonWebdjango数据库python后端开发语言
Django后端架构开发:后台管理与会话技术详解后台管理:自定义模型类Django的后台管理系统提供了强大的模型管理功能,你可以通过自定义模型类来控制模型在后台管理界面的显示和操作。自定义模型类通过继承admin.ModelAdmin类实现,可以指定显示的字段、过滤条件、搜索框等功能。fromdjango.contribimportadminfrommyapp.modelsimportMyMode
- 快速实现用户认证:使用Python和Flask配合PyJWT生成与解密Token的教程及示例代码
陈钇谷
pythonflask开发语言
生成token与解密token和拦截器#学习交流访问#https://v.iiar.cnimportjwtimportdatetimefrommodelsimportXUserfromflaskimportrequest,jsonifyfromfunctoolsimportwrapsSECRET_KEY='XPay'#创建tokendefgenerate_token(user_id):try:pa
- Flask实战开发——问答平台(五)用户注册与登录
小陈从不熬夜
Flask从入门到实践flaskpython后端
一、注册信息校验1、使用表单验证(flask-wtf)pipinstallflask-wtf2、在蓝图buleprints文件下新建forms.py文件importwtformsfromwtforms.validatorsimportEmail,Length,EqualTo,InputRequiredfrommodelsimportUserModel,EmailCaptchaModelfromex
- VGG16滤镜可视化和类激活图
LIjin_1006
人工智能神经网络深度学习cnn
这个用keras2.2.4+tensorflow1.15.0importkeraskeras.__version__fromkeras.applicationsimportVGG16fromkerasimportbackendasKimportnumpyasnpfromkerasimportmodelsimportmatplotlib.pyplotaspltimporttensorflowastf
- django rest framework 学习笔记2
_pass_
django学习笔记
注意:该文章部分摘抄之百度,仅当做学习笔记供小白使用,若侵权请联系删除!显示关联表的数据,本示例会显示所有的关联的数据信息fromrest_frameworkimportserializersfrom.modelsimportStudentclassStudentModelSerializer(serializers.ModelSerializer):classMeta:model=Student
- flask 留言板(flask 39)
SkTj
image.pngviews.pyfromflaskimportflash,render_template,redirect,url_forfromappimportapp,
[email protected]('/',methods=['GET','POST'])defindex():messages=Messag
- Gin 中使用 base64Captcha 生成图形验证码
肥茹
gin
验证码库https://github.com/mojocn/base64Captcha中文文档Go进阶37:重构我的base64Captcha图形验证码项目|❤️在models文件夹中写一个验证码的文件,Captcha.gopackagemodelsimport("github.com/mojocn/base64Captcha""image/color")//设置自带的store存在服务器内存中v
- django通过指定用户手机号查询外键所关联的数据,倒序查询
王家视频教程图书馆
已解决django
django通过指定用户手机号查询外键所关联的数据在Django中,可以通过使用filter方法和双下划线语法来查询外键所关联的数据。以下是一种常见的方法:fromyour_app.modelsimportUser,ForeignKeyModel#假设User模型有一个名为phone的字段,ForeignKeyModel模型有一个外键关联到User模型#通过指定用户手机号查询外键所关联的数据use
- 在Modelsim中添加Vivado仿真库
jjzw1990
vivado
说明:本文是在参考《在Modelsim中添加Xilinx仿真库》的基础上,经过反复试验才取得成功的!在Modelsim安装目录下新建一个用于存放Vivado仿真库的文件夹,如本文新建了一个命名为vivado2015_02_lib的文件夹;打开Vivado,依次点击Tools->CompileSimulationLibraries…按下图所示,在Simulator中选择Modelsim,在Advan
- Django学习之旅(二)创建数据模型及数据迁移
气概
django学习python
Django也属于面先对象的编程方式,因此以对象的形式承载数据及与数据库进行传输。创建数据模型在blog应用的models.py中编写数据模型,数据模型都必须继承models.Model,模型的属性也以系统规定的类型进行定义,如models.CharField等。参照追梦人物老师的教程,我们定义了博客及其分类、标签三个数据模型,如下。fromdjango.contrib.auth.modelsim
- 基于深度学习的农业病虫害识别实战
一枚爱吃大蒜的程序员
深度学习机器学习实战深度学习人工智能
视频讲解:基于深度学习的农业病虫害识别实战_哔哩哔哩_bilibili数据展示:代码:fromkeras.preprocessing.imageimportImageDataGenerator,load_img,img_to_array,array_to_imgfromkeras.modelsimportSequentialfromkeras.layersimportConv2D,MaxPooli
- Diamond软件的使用(5)--建立Modelsim仿真环境
zidan1412
FPGAfpgafpga开发
文章目录参考来源联合仿真平台使用Modelsim仿真的原因LATTICE器件仿真模型文件设置初始化文件更改Modelsim工作路径建立新的仿真库编译LATTICE仿真模型文件编译特定的仿真库设置路径库路径Diamond关联Modelsim编写Testbench并仿真验证加载PCS库参考来源以下内容主要参考自两个来源如何在ModelsimSE中建立LATTICE仿真库PPT作者JasonChen@w
- 最近踩坑记录
zidan1412
FPGAfpga
新电脑Modelsim破解失败新组了一台电脑,结果modelsim破解失败,报错Unabletocheckoutaviewerlicense捣鼓了一个小时,最后发现是无线网卡物理地址与破解工具产生的license文件中物理地址不同。22.6.10win10安装vmware后启动ubuntu蓝屏报错必须安装vmware16.1,其他的15.5和16.0都不行参考链接:[已解决]ModelSim出现U
- 【FPGA开发】Modelsim和Vivado的使用
Include everything
FPGA开发fpga开发
本篇文章包含的内容一、FPGA工程文件结构二、Modelsim的使用三、Vivado的使用3.1建立工程3.2分析RTLANALYSIS3.2.1`.xdc`约束(Constraints)文件的产生3.3综合SYNTHESIS3.4执行IMPLEMENTATION3.5烧录程序3.6程序固化3.6.1SPI约束3.6.2`.bin`文件的产生3.6.3`.mcs`文件的产生3.6.4添加配置的存储
- modelsim软件仿真出现现蓝色波形,数字为zzzzzzz开头
大话硬件
modelsimFPGAerror仿真zzzzzz开头
使用modelsim软件仿真出现输出波形是zzzzzzz0或zzzzzzz1出现上述的原因是out数据类型不对,默认定义成了高阻态,出现上述原因,在quartus软件里面也有报错的提示根据报错提示,发现是OUT这个输出没有定义它的位数,在后面直接用了8bir的数据来表示OUT增加OUT的类型,8bit的信号,此时quartus不报错仿真此时正常
- modelsim仿真使用到vivado的IP,该如何使用!
兵棒
fpga开发
modelsim仿真时,如果使用到了vivado的IP就会报错,本次就告诉大家如何将vivado的IP添加到modelsim中直接仿真。一、生成ini文件以及IP打包打开vivado,点击上方的Tools-->CompileSimulationLibraries得到如下界面simulator:选择相应的仿真器,本次讲解的时modelsim,所以该选什么你们懂的。language:选择语言,自行判断
- 1.3 Verilog 环境搭建详解教程
二当家的素材网
Verilog教程fpga开发Verilog
学习Verilog做仿真时,可选择不同仿真环境。FPGA开发环境有Xilinx公司的ISE(目前已停止更新),VIVADO;因特尔公司的QuartusII;ASIC开发环境有Synopsys公司的VCS;很多人也在用IcarusVerilog和GTKwave的方法,更加的轻便。虽然ISE或者QuartusII都会自带仿真器,但功能还是有欠缺。所以,这里介绍下QuartusII+Modelsim联合
- Quartus-II入门(全加器)
狴鲲
嵌入式系统应用开发单片机
文章目录前言一、相关概念1.半加器2.全加器二、原理图输入实现全加器1.半加器实现2.半加器仿真3.全加器实现4.硬件下载三、总结参考链接前言在做这里的学习之前,需要先把ModelsimSE安装好,Quartus-II及其固件库等,这个实验本身并不复杂,但是在做的过程中会有很多小的地方报错,按步骤一步一步来,否则很容易出错。一、相关概念1.半加器半加器电路是指对两个输入数据位相加,输出一个结果位和
- University Program VWF仿真步骤__全加器
Terasic友晶科技
工具篇fpga开发仿真
本教程将以全加器为例,选择DE2-115开发板的CycloneIVEP4CE115F29C7FPGA,使用QuartusLitev18.1,循序渐进的介绍如何创建Quartus工程,并使用QuartusPrime软件的UniversityProgramVWF工具创建波形文件,对全加器的功能进行仿真。使用UniversityProgramVWF工具进行仿真,其实也是调用ModelSim软件仿真,只是
- 【FPGA & Verilog&Modelsim】 8bitBCD码60计数器
去追远风
FPGA学习记录fpga开发
可私信获取整个项目文件8bit即有8位二进制BCD码,全称Binary-CodedDecimal,简称BCD码或者二-十进制代码利用四位二进制(0000-1111)16个中选择10个作为十进制0-9;常见的BCD码是8421码本项目使用两组BCD码(每组4bit,共8bit,故称为8bitBCD)(高位0-5,低位0-9)组成0-59计数器闲话不多,上代码计数值qout达到60时,cout进位输出
- 【Django-ninja】django ninja中使用查询过滤器FilterSchema
babybin
djangopython后端
DjangoORM中过滤器filter的基本用法filter()是QuerySet对象的一个方法,用于从数据库中过滤数据。它接受一个或多个关键字参数,每个参数都表示一个查询条件,它们之间是AND关系。以下是filter()方法的基本用法示例:frommyapp.modelsimportMyModel#查询所有name字段值为'John'的记录results=MyModel.objects.filt
- Quartus II 13.1的安装与基础实践
饿丸
嵌入式嵌入式
安装参考资料:Quartus:https://blog.csdn.net/qq_43279579/article/details/115158140Modelsim:https://blog.csdn.net/qq_43279579/article/details/115176423审核不让通过,原因是版权问题,安装过程参考上面的博客,不再赘述遇到的问题不知怎么回事,个人安装的时候没有安装上dev
- 自学 FPGA 要注意什么?
宸极FPGA_IC
fpga开发fpga硬件工程嵌入式硬件
1.学习习惯问题FPGA学习要多练习,多仿真,signaltapII是很好的工具,可以看到每个信号的真实值,建议初学者一定要自己多动手,光看书是没用的。同时自制力也很重要,差的人容易半途而废。2.EDA工具问题熟悉几个常用的就可以的,开发环境QuartusII,或ISE就可以了,这两个基本是相通的,会了哪一个,另外的那个也就很Easy了。功能仿真建议使用Modelsim,如果你是做芯片的,就可以学
- Django-全局上下文写通用功能
南栀子。
Django
全局上下文写通用功能:比如导航栏优点:只用修改数据库即可。步骤:stu包下新建python文件my_context_processor.py#coding=utf-8fromstu.modelsimportMenudefgetMenuInfo(request):menus=Menu.objects.all().order_by('mid')
- 算法 单链的创建与删除
换个号韩国红果果
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较早的版本都自带,