- RK系列(RK3568) GPIO按键驱动 和Android key新值添加
hmbbPdx_
RK驱动开发Rk开发(RK3568)android驱动开发linux
平台:Android12SOC:RK3568kernel:Linux-4.19首先按键驱动那块不用我们自己写,内核本身有支持可以查看kernel-4.19-driver/input/keyboard/gpio_keys.c我们先描述好设备树添加GPIO4-A0的按键gpio-keys{compatible="gpio-keys";#address-cells=;#size-cells=;autor
- Linux 设备树详解:从概念到实战
Jay_515
Linux学习嵌入式linux设备树
关键词:设备树(DeviceTree)、DTS、DTC、DTB、嵌入式Linux驱动开发为什么需要设备树?在旧版Linux内核中,硬件信息(如内存映射、外设地址、中断号等)直接硬编码在内核源码中。这导致:内核臃肿,需为不同硬件编译不同版本硬件变动需重新编译内核代码冗余严重(一个board-*.c文件对应一块开发板)设备树(DeviceTree)的引入彻底解决了这一问题!它通过描述硬件拓扑结构的文本
- 【笔记】构建Linux 0.1.1(BeagleBone Black)
外星间谍
嵌入式Linux构建LinuxBeagleBoneBlack
注意这里的文章自动换行了。与0.1相比,我重新编译了,整理了下。既然可以连HDMI显示器,那我研究下Wayland。以后再研究网络。===============================================================================说明我构建的目标平台为BeagleBoneBlack,'http://beagleboard.org/'。交叉
- leetcode37 + java
酸乳酸乳
leetcodejava
数独回溯使用三个数组记录状态行列九宫格classSolution{publicboolean[][]v1=newboolean[9][10];publicboolean[][]v2=newboolean[9][10];publicboolean[][]v3=newboolean[9][10];publicvoidsolveSudoku(char[][]board){for(inti=0;i<9;i
- docker-compose部署rocketmq和rocketmq-dashboard以及消息队列的概念讲解
qq_53099538
dockerrocketmq容器
引言在现代软件架构,尤其是微服务架构中,组件之间的解耦和异步通信变得尤为重要。消息队列作为实现这一目标的关键技术,不仅提升了系统的可扩展性和健壮性,还简化了复杂场景下的消息传递。本文旨在深入探讨消息队列的基本概念、工作原理及其实现机制,帮助读者更好地理解和应用这一重要技术。一、基于docker-compose部署rocketmq以及rocketmq-dashboard步骤1:准备工作目录首先,你需
- (k8s) Dashboard+国产kuboard(好用)+简单命令
小刘同学....
kubernetesdockerlinux
可视化部署Dashboard昨天做一主两从飞高可用,出现浏览器那一行,是为啥thisisunsafekubectlget获取资源podnodesvc-A所有名称空间-n指定名称空间-w动态显示kubectledit资源podnodesvc官方的,毛坯房国产在哪找的资源?访问看service可以管理多个k8s集群命令补全一下学习命令状态kubectlgetpod#默认名称空间中的所有pod-A所有名
- Sentinel实现原理
2401_85327573
sentinel网络服务器
Sentinel是阿里巴巴开源的分布式系统流量控制组件,主要用于服务保护,涵盖流量控制、熔断降级、系统负载保护等功能。以下是Sentinel的实现原理,使用中文简要说明:1.总体架构Sentinel采用轻量级设计,分为核心库(Java实现)和Dashboard控制台两部分:-核心库:嵌入到应用中,负责流量控制、熔断、降级等逻辑。-Dashboard:提供可视化界面,用于配置规则、监控流量和运行状态
- Go Modules
至此流年莫相忘
Golanggolang开发语言后端
什么是GoModules?Gomodules是Go语言的依赖解决方案,发布于Go1.11,成长于Go1.12,丰富于Go1.13,正式于Go1.14推荐在生产上使用。Gomoudles目前集成在Go的工具链中,只要安装了Go,自然而然也就可以使用Gomoudles了,而Gomodules的出现也解决了在Go1.11前的几个常见争议问题:Go语言长久以来的依赖管理问题。“淘汰”现有的GOPATH的使
- Android studio java websocket 编译报错:Supertypes of the following classes cannot be resolved.
SmallWalnutBG
AndroidStudioAndroidJava
Androidstudio编译报错:Supertypesofthefollowingclassescannotberesolved.PleasemakesureyouhavetherequireddependenceAndroidstudio版本:具体操作:1、新增一个module,将Java-WebSocket导入moudle(implementation"org.java-websocket:
- Vue 复制页面内容
Aotman_
vue.jsjavascript前端es6
方法1:使用document.execCommand('copy')在用户触发的事件中这种方法适用于用户触发的事件(如点击按钮),因为这是execCommand('copy')的唯一允许场景。复制到剪贴板exportdefault{methods:{copyToClipboard(){consttext='要复制的内容';//你想复制的文本constel=document.createElemen
- OpenRisc-54-play with OpenRISC based atlys board
Rill
OpenRiscopenrisc
1.OpenRISC1200softprocessorIntroductionTheOpenRISC1200(OR1200)isasynthesizableCPUcoremaintainedbydevelopersatOpenCores.org.TheOR1200designisanopensourceimplementationoftheOpenRISC1000RISCarchitecture.
- OpenStack-Dashboard界面简单修改
陌殇殇殇
openstack
OpenStackDashboard界面替换图片一、dashboard界面Logo的路径及文件dashboard的Logo存放(在Controller节点)的路径:/usr/share/openstack-dashboard/openstack_dashboard/static/dashboard/img/涉及需要修改的文件(3个):favicon.ico//浏览器窗口的小图标logo.svg//
- Unable to start embedded Tomcat
MyFreeIT
JDKtomcatmybatisjava
通常是由于xml文件配置错误导致1.mapper指向错误2.字段类型错误TINYINT是数据库类型或者String是Java类型
- Chisel芯片开发入门系列 -- 1. Chisel Introduction
ChipCamp
Chisel芯片开发入门系列scala青少年编程fpga开发dsp开发arm开发
ChiselIntroductionChisel(ConstructingHardwareInaScalaEmbeddedLanguage)isahardwareconstructionlanguageembeddedinthehigh-levelprogramminglanguageScala.Chiselisalibraryofspecialclassdefinitions,predefine
- OpenStack入门体验
惊起白鸽450
openstack
目录什么是云计算云计算的服务模型OpenStack概述OpenStack一键部署使用packstack一键离线部署OpenStack通过Dashboard体验OpenStack功能创建云主机什么是云计算云计算是一种通过网络(通常是互联网)提供计算资源和服务的模式,它可以让用户按需获取服务器、存储、数据库、软件等资源,而无需自己搭建和维护物理基础设施。以下是关于云计算的详细介绍一、核心概念云计算的本
- Nacos Server
workflower
java服务器linux
NacosServer环境和域名掌门的应用环境分为4套,DEV|FAT|UAT|PROD分别对应开发、测试、准生产环境、生产环境,因此NacosServer也分为4套独立环境。除了DEV环境是单机部署外,其他是集群方式部署。对外均以域名方式访问,包括SDK方式连接NacosServer和访问NacosServerDashboard控制台页面。NacosServer环境隔离和调用隔离NacosSer
- Android Settings开发总结
风和先行
Androidandroid
目录1.界面构成1.1主界面2.事件响应2.1界面切换2.2监听SettingProvider字段变化3.搜索栏4.常用调试技巧5.其它子模块5.1应用与通知Open,卸载等的控制与显示6.默认值更新1.界面构成主界面使用的layout是:settings_main_dashboard,子界面使用的layout是:settings_main_prefs。主界面使用DashboardSummary(
- 数独游戏代码
钰清雅
游戏
importrandomimporttkinterastkfromtkinterimportmessagebox,ttk#新增ttk导入defprint_board(board):#保留原有逻辑用于调试"""打印当前数独棋盘"""foriinrange(9):ifi%3==0andi!=0:print("-----------")forjinrange(9):ifj%3==0andj!=0:pri
- 【开源推荐】嵌入式软件开发学习路线全景图:从裸机到 RTOS,再到嵌入式 Linux(附涵超全电子书资源以及面经资料)
Natsume1710
开源学习linux
本文将系统介绍一个适合初学者&进阶者的嵌入式开发学习开源项目,涵盖C语言、驱动开发、RTOS、嵌入式Linux、物联网通信等核心内容,特别适合电赛、毕设、面试准备和入行工程师使用。一、为什么推荐这个项目?嵌入式学习门槛高、知识零散,这是大多数学习者面临的第一大难题。GitHub项目0voice/EmbeddedSoftwareLearn是由国内技术社区整理并维护的开源仓库,它将整个嵌入式学习路径从
- 关闭python解释器_Windows Python解释器在Ctrl C上退出
weixin_39537977
关闭python解释器
在Windows8及更高版本上运行3.6之前的Python版本的shell提示符处,CtrlC处理已中断.对于input和raw_input,它也会被破坏,你将获得一个EOFError而不是KeyboardInterrupt.您可以通过安装和启用win_unicode_console或升级到3.6来解决此问题问题是Python从控制台读取的旧代码依赖于ReadFile,当CtrlC中断读取时,将最
- 关闭python解释器的方式_Python CTRL + C退出解释器?
weixin_39614546
关闭python解释器的方式
Python2.73WhyisitonmylaptopwhenIhitCTRL+C,IcanexittheinterpreterandonmydesktophittingCTRL+CwillmaketheinterpretershootbackatmeaKeyboardInterruptmessage.HowcanIgetridofthisKeyboardInterruptandgobacktoe
- RK3588 平台 Kylin 系统备份方法
雨之小
linuxubuntukylin大数据
在日常开发与调试工作中,对系统进行备份是一项重要的任务。以下是在RK3588平台上对Kylin系统进行备份的方法,通过一系列指令实现系统的高效备份,便于后续恢复或查阅。一、创建备份目录并同步数据首先,在pc的ubuntu虚拟机上创建一个用于存放备份数据的目录“Board”:mkdirBoard接着,使用rsync命令将kylin系统(IP地址为192.168.0.99)上的数据同步到本地的“Boa
- c++数据结构 有效的数独、矩阵置零
艾艾的博客
c++数据结构矩阵
36.有效的数独-力扣(LeetCode)(leetcode-cn.com)classSolution{public:boolisValidSudoku(vector>&board){introw[9][9];intline[9][9];intbox[9][9];for(inti=0;i1||line[index][j]>1||box[index][(i/3)*3+j/3]>1){returnfa
- arcpy数据分析自动化(2)
pianmian1
python
数据处理在提取数据后,我们需要对字段进行标准化处理,例如统一土地利用类型的命名。#定义字段映射字典field_mapping={"Residential":"居住用地","Commercial":"商业用地","Industrial":"工业用地","Agricultural":"农业用地"}#获取输出地理数据库中的所有要素类arcpy.env.workspace=output_gdbfeatur
- 解决react-native软键盘弹出挡住输入框的问题
曲小强
reactNative采坑之路软键盘弹出挡住输入框react-native
这是效果:代码:importReact,{Component}from'react';import{View,Text,Button,StyleSheet,TextInput,ScrollView,KeyboardAvoidingView,Dimensions}from'react-native';import{StackActions,NavigationActions,withNavigati
- react-native键盘遮挡输入框
huaiyanchen
react-native
1、使用组件KeyboardAvoidingView使用注意:在render内使用,需要设置高度keyboardVerticalOffset:有时候应用离屏幕顶部还有一些距离(比如状态栏等等),利用此属性来补偿修正这段距离。2.与ScrollView使用ScrollView标签不要设置高度render(){return(...this._extraUniqueKey(item,index)}ren
- eSIM智能卡开发与规范概述:从架构到RSP技术
李大锤同学
本文还有配套的精品资源,点击获取简介:eSIM(EmbeddedSIM)是一种集成于设备硬件的SIM卡技术,通过GSMA制定的规范支持全球互操作性和标准化。本压缩包包含了eSIM架构、RSP技术规范及相关更新版本的详细文档。开发者通过学习这些文档可以深入了解eSIM的工作原理、用户身份信息的安全存储管理、运营商配置的远程下载激活,以及确保设备全球互操作性的关键技术。这对于开发eSIM智能卡、制造支
- OpenStack入门
YUNYINGXIA
openstack
目录一、云计算概述(一)云计算的定义(二)云计算的服务模型(三)OpenStack概述二、OpenStack一键部署(一)环境要求(二)在线安装前准备工作(三)在线部署OpenStack(四)离线安装前准备工作(五)离线部署OpenStack三、通过Dashboard体验OpenStack功能(一)登录Dashboard(二)Dashboard界面功能四、创建云主机(一)创建网络(二)创建路由(三
- uboot:源码分析-启动第一阶段-lowlevel_init
li星野
嵌入式linux嵌入式硬件
lowlevel_init找到lowlevel_init函数真正的地方,是在uboot/board/samsumg/x210/lowlevel_init.S中。检查复位状态(1)复杂CPU允许多种复位情况。譬如直接冷上电、热启动、睡眠(低功耗)状态下的唤醒等,这些情况都属于复位。所以我们在复位代码中要去检测复位状态,来判断到底是哪种情况。(2)判断哪种复位的意义在于:冷上电时DDR是需要初始化才能
- stm32 micropython usb wifi_【micropython】用python来进行USB-HID
weixin_39564386
stm32micropythonusbwifi
转载请注明:@小五义http://www.cnblogs.com/xiaowuyiQQ群:64770604本文以TPYBoardv101开发板为例讲解了利用micropython进行BadUSB的usb-HID设备测试的主要方法,使用mt7681模块进行了一个简单的实验,实现了手机摇控键盘输入的测试。0x01引言Micropython即运行在微控制器上的Python,只要你懂python3.x,就
- 算法 单链的创建与删除
换个号韩国红果果
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较早的版本都自带,