- arm系统移植
61u3
#6-armlinuxubuntuarm
目录1.流程2.概念2.1设备树2.2根文件系统2.3文件说明3.交叉编译链3.1作用3.2在linux下配置4.tftp4.1作用4.2安装过程5.nfs5.1作用5.2安装过程6.配置开发板7.linux下的uboot镜像烧写到SD卡中7.1生成uboot二进制文件,二进制文件就是裸机程序。7.2合成最终的uboot7.3通过dd命令把u-boot-iTOP-4412.bin烧写到SD卡中8.
- UBOOT学习笔记(六):UBOOT启动--CPU架构及板级初始化阶段
ZH_2025
uboot&linux启动篇linuxarm
3.1、_mainENTRY(_main)#ifdefined(CONFIG_TPL_BUILD)&&defined(CONFIG_TPL_NEEDS_SEPARATE_STACK)ldrr0,=(CONFIG_TPL_STACK)/*TPL(三级引导)使用独立栈*/#elifdefined(CONFIG_SPL_BUILD)&&defined(CONFIG_SPL_STACK)ldrr0,=(C
- RK3566系统移植 | 基于rk-linux-sdk移植uboot(2017.09)
Mculover666
linux
文章目录一、测试已有的配置二、移植到fireflyROC-RK3566开发板1.新建单板2.新建设备树3.编译4.测试一、测试已有的配置查看rksdk中提供的uboot中对于rk3566的配置:rk3566.config内容如下:CONFIG_BASE_DEFCONFIG="rk3568_defconfig"CONFIG_LOADER_INI="RK3566MINIALL.ini"因为rk3566
- vxWorks7.0下基于zynq的boot启动程序
hongbozhu_1981
最近工作有点忙,好久没有更新内容,前段时间抽空做了vxWorks7.0下的基于zynq的boot程序,在此做个总结。vxworks7.0支持三种不同的boot程序:第一种uboot,第二种vxworks6.9.x以上的bootloader,第三种bootapp,关于uboot的创建方法在前面的博文中已经提到过,bootloader6.9的话,因为我不在使用6.9的版本,所以在此也就不做介绍,今天我
- Buildroot 根文件系统构建
hqb_newfarmer
linux运维服务器
目录1.buildroot下载2.配置buildroot1、配置Targetoptions编辑2、配置Toolchain3、配置Systemconfiguration4、配置Filesystemimages5、禁止编译Linux内核和uboot6、配置Targetpackages3.编译buildroot4.buildroot第三方软件和库的配置1、使能alsa-lib编辑2、使能alsa-uti
- 【linux开发-驱动】-U-Boot相关
笃行致远~
l嵌入式inux开发linux单片机驱动开发
一、什么是U-Boot1、Linux系统要启动需要通过bootloader程序引导,也就说芯片上电以后先运行一段bootloader程序。2、uboot是一个裸机程序,就是一个bootloader,作用就是用于启用linux或其他系统。uboot最主要的工作就是初始化DDR。在实际开发中,我们一般不会直接用uboot官方的U-Boot源码的,一般使用开发板半导体厂商提供的更全面。区别:种类描述ub
- Linux系统移植⑨:uboot启动流程详解-bootz启动Linux过程
Linux系统移植⑨:uboot启动流程详解-bootz启动Linux过程bootz是U-Boot中用于启动Linux内核的命令,专为处理zImage(压缩内核映像)设计。启动Linux的完整过程:1.加载内核与相关文件U-Boot先将以下文件加载到内存指定地址:zImage:压缩的Linux内核映像(位于内存地址KERNEL_ADDR)。设备树二进制文件(DTB):硬件描述文件(位于FDT_AD
- uboot:源码分析-启动第一阶段-lowlevel_init
li星野
嵌入式linux嵌入式硬件
lowlevel_init找到lowlevel_init函数真正的地方,是在uboot/board/samsumg/x210/lowlevel_init.S中。检查复位状态(1)复杂CPU允许多种复位情况。譬如直接冷上电、热启动、睡眠(低功耗)状态下的唤醒等,这些情况都属于复位。所以我们在复位代码中要去检测复位状态,来判断到底是哪种情况。(2)判断哪种复位的意义在于:冷上电时DDR是需要初始化才能
- x210:uboot和系统移植扩展--uboot启动第一阶段
毛裤先生_2
嵌入式linuxuboot
从u-boot.lds中ENTRY所指定处可以看出,整个uboot程序的起始就是_start处。不简单的头文件包含(1)#include。config.h是在include目录下的,这个文件不是源码中本身存在的文件,而是配置过程中自动生成的文件(参考uboot配置和编译过程详解章节,该文件中的内容为#include)。可见start.S中包含的第一个头文件就是:include/configs/x2
- ARM嵌入式系统启动和分区管理
kebi2009
linux系统架构
1常规启动流程1.1背景介绍uboot只是一个启动引导向,最终的目的是启动linux系统。那么即使不使用uboot也可以用其他的引导向,但是目前主流都是使用的uboot,所以这里对uboot的执行函数流程进行了整理,方便大家好阅读uboot的工程源码,在了解uboot之前,需要了解一下芯片启动处理逻辑。看到这个笔记的小伙伴们,应该都知道,系统的启动方式有很多种,比如SD、mmc、norflash、
- UBoot移植与YAFFS文件系统制作实践指南
影评周公子
本文还有配套的精品资源,点击获取简介:在嵌入式系统开发中,UBoot作为启动引导程序,负责设备初始化和加载操作系统内核。YAFFS文件系统专为NAND闪存设计,提供坏块处理和错误纠正功能。本文深入分析了UBoot的启动引导过程,并详细介绍了如何移植UBoot以及制作YAFFS文件系统,以确保嵌入式设备的稳定性和数据的可靠存储。1.UBoot初始化过程分析在嵌入式系统的世界里,UBoot作为一款通用
- mtd 分区表计算方式
隐身模式
mcu
详细的MTD设备分析见opensourcehttps://www.opensourceforu.com/2012/01/working-with-mtd-devices/下面主要介绍如何计算分区大小mtd分区表计算方式dev分区大小erasesizename换算Mmtd00010000000020000vnvm1Mmtd10050000000020000uboot5Mmtd200800000000
- 基于Pico PC RK3588S平台搭建Ubuntu20.04.6根文件系统
biubiu杨
RK3588ubuntulinux
文章目录前言很多厂商没有吧文件系统的构建方法开源出来,只是提供了一个rootfs.img的固件包,这不利于我们做二次开发,本文章实现一个自己构建的文件系统,并移植到RK的平台上使用。搭建好用于开发的Ubuntu虚拟机环境,熟练使用一些常用工具如烧录系统的工具RKDevTool、远程连接工具MobaXterm等等。当然,本章只针对根文件系统,uboot、boot的镜像文件和驱动文件需要提前准备好,编
- 嵌入式3. U-Boot
weixin_39757802
嵌入式嵌入式硬件
【uboot本质】(1)uboot的本质就是一个裸机程序,和我们裸机全集中写的那些裸机程序xx.bin并没有本质区别。如果非说要有区别,那就是:我们写的大部分小于16KB,而uboot大于16KB(一般uboot在180k-400k之间)(2)uboot本身是一个开源项目,由若干个.c文件和.h文件组成,配置编译之后会生成一个uboot.bin,这就是uboot这个裸机程序的镜像文件。然后这个镜像
- imx6ull u-boot启动流程分析
risc_luck
ubootubootimxnxp
一、程序入口程序的链接由链接脚本决定的,所以可以通过u-boot.lds来找到uboot的入口。从上图可以看出入口为_start,该标签在vector.S中(\arch\arm\lib\vectors.S).macroARM_VECTORSbresetldrpc,_undefined_instructionldrpc,_software_interruptldrpc,_prefetch_abort
- 【RK3399】【Uboot】 流程分析之常用宏定义说明
岁月如诗,光阴荏苒
嵌入式学习
1、内核等固件加载地址:ENV_MEM_LAYOUT_SETTINGS,定义如下./include/configs/rk3399_common.h58#defineENV_MEM_LAYOUT_SETTINGS\59"scriptaddr=0x00500000\0"\60"pxefile_addr_r=0x00600000\0"\61"fdt_addr_r=0x08300000\0"\62"ker
- eeprom和编程器固件 k2_用编程器免拆夹子刷斐讯K2 K2P解决难搞固件 刷BREED 无损原EEPROM...
luckinboy
eeprom和编程器固件k2
文章中放的几个地址都是思路来源,感谢各路大神原帖子的思路,因为我刷机时候没有拍照,只好借用各位大佬的图来说明步骤,我做一下整理会放出本篇刷机流程,很简单!K222.6.532.231软件版本已经无解,UBOOT等可以软刷的方式都被堵死,编程器夹子已经成了最后的比较方便的刷机办法。(这特么已经是硬刷了,还能咋着?)首先要准备的工具:1.编程器推荐MinproI2.免拆SOP8夹子3.编程器店家提供的
- 固件升级OTA、DFU非常好的一篇文章
color_leo
mcu
nRFConnectSDK(NCS)/Zephyr固件升级详解–重点讲述MCUboot和蓝牙空中升级一切荣耀属于原作者
- MUSE Pi Pro 开箱啦!8核RISC-V,UEFI有点意思~
LitchiCheng
rsic-vrisc-v机器人
视频讲解:MUSEPiPro开箱啦!8核RISC-V,UEFI有点意思~首先感谢进迭时空的测试开发板,前面发给我SpecBrief时就有了一点期待,想看下这个板子有哪些有意思的东西。RISC-V,8核,UEFI,2TOPS算力,这些内容在之前玩过的RISC-V中也是不多的,刚好搞过Jetson的edk2的uefi固件,对于嵌入式设备来说,有uefi的还是少数,大部分都是uboot或更前的bl31等
- 在Ubuntu 22.04下开发板无法通过nfs挂载rootfs的问题
小翔的博客
嵌入式Linuxubuntulinuxarm开发
一、问题现象在设置好uboot环境变量bootargs后,通过nfs挂载linux根文件系统,但是经过多次检查和尝试仍无法挂载(编译内核时已开启nfs服务,并且网络参数设置无误),开发板linux输出信息如下:服务器端Ubuntu版本如下:二、问题分析在Ubuntu中查看nfs支持的版本:sudocat/proc/fs/nfsd/versions发现当前版本的ubuntu不支持nfsv2版本三、解
- Linux Kernel入门到精通系列讲解(RV-U-boot 篇) 4.2 RISC-V从零移植自己的Uboot
嵌入式内核源码
Linuxkernel从入门到精通linuxrisc-v嵌入式uboot
1.概述上一章节我们已经成功从OpenSBI跳转到Uboot,并且已经把默认的qemu-riscv64_smode_defconfig移植成功了,本章节我们将会重新规划memory分区,方便后续创建更多的设备,并且从零开始移植一个属于NarutoPi的uboot。2.重建分区表2.1当前QEMU已创建Memory地址大小内存区域描述0x0000_00002KbROM0x0000_80002KbSR
- Android设备的序列号与ro.serialno
程序员(无名)
androidRockchip
Android设备的序列号是通过获取Property“ro.serialno”的值取得的。“ro.serialno”的值一般来源于内核启动参数中的"ro.boot.serialno"。在rk3368Android6.0中,uboot读取idblock的IDBLOCK_SN偏移地址获取序列号----->保存到env变量“fbt_sn#”----->保存到env变量“androidboot.seria
- 嵌入式学习日志(一)——全志H3之开发环境准备
Three_Sheep
嵌入式linuxuboot嵌入式
小目标:让自己编译的uboot跑起来参考:wiki.friendlyarm.com/wiki/index.php/NanoPi_NEO首先熟悉一下板子NanoPiNEO和开发流程。维基主要参考《使用全志原厂BSP》这一节。概要步骤:1.获得BSP源码包:gitclonehttps://github.com/friendlyarm/h3_lichee.gitlichee2.下载交叉编译器gcc-li
- 6818 蜂鸣器驱动
扣篮发型不乱
armlinux驱动开发arm开发
需要先编译uboot和kernel编译驱动前,需要先编译uboot和kernel在我的环境中,已经有一个mk文件,先编译uboot,再编译kernel./mk-u编译uboot./mk-k编译内核驱动相关的命令:modinfobeepDriver.ko查看驱动信息rmmodgec6818_beep卸载驱动insmodbeep.ko安装驱动源文件编译驱动的Makefile需要指定kernel的源码位
- CMCC RAX3000M使用Tftpd刷写OpenWrt固件的救砖方法
TeleostNaCl
经验分享智能路由器
有时候,我们在玩运行OpenWrt的CMCCRAX3000M,因为一些操作不当,导致无法进入路由器系统,无法正常刷机。此时,如果我们已经刷写了uboot,则可以在uboot模式下通过Tftpd刷写新的OpenWrt固件,实现救砖效果。本文将以原版OpenWrt为例,详细介绍CMCCRAX3000M通过Tftpd刷写OpenWrt固件的救砖方法。救砖的固件可以自行编译生成,也可以从官方的OpenWr
- qemu(4) -- qemu-system-arm使用
xflm
qemulinux
1.前言参考网上的资料,使用qemu中的vexpress_a9板子,跑一下Linux环境。2.源码工作目录的结构如下。$treeuboot_linux_busybox/-L1uboot_linux_busybox/#工作目录├──build#编译输出目录├──busybox-1.37.0#busybox源码目录├──linux-5.15.180#linux源码目录├──script#辅助脚本目录:
- rk3568安全启动功能实践
Amelio_Ming
安全linux
本文主要讲述笔者在rk3568芯片上开发安全启动功能实践的流程。其中主要参考瑞芯微官方文档《Rockchip_Developer_Guide_Secure_Boot_for_UBoot_Next_Dev_CN.pdf》。文档中描述逻辑不是很清晰而且和当前瑞芯微的sdk中安全启动的流程匹配度不高。本文就不再对瑞芯微官方文档的内容进行赘述,读者可以先查看官方文件后再阅读本文章。所谓的安全验证引导流程分
- cmcc rax3000me刷入ImmortalWrt24.10快照版本心路历程
冲动的BUG
路由器刷机ImmortalWrtrax3000me
写在开头:本人路由器型号是rax3000me,带usb口,内存ddr3版本。在本人购买rax3000me之前,完全没有刷路由器经验,相信你也可以的。本篇记录跟着网上教程成功刷上ImmortalWrt23.05.x版本后,结果查到最新ImmortalWrt已经来到24.10版本,于是想刷入24.10版本,由于本人没查攻略,直接使用mtd命令写入官方uboot导致路由器灯常亮蓝色,无法进入web界面,
- 一、linux系统启动过程操作记录
离凌寒
linuxlinux
一、linux系统启动过程经历:上电–>uboot–>加载内核–>挂载根文件系统–>执行应用程序uboot等效bootloader,启动过程进行了跳转到固定的位置执行相应的代码初始化硬件设备,如:cpu初始化,看门狗,时钟,内存,存储设备等。加载内核代码到内存中。跳转到内核代码起始位置执行。uboot下常见指令printenv查看环境参数如串口,网络,boot配置参数等setbootdelayx设
- 20250427在ubuntu16.04.7系统上编译NanoPi NEO开发板的FriendlyCore系统解决问题mkimage not found
南棱笑笑生
杂质杂质
20250427在ubuntu16.04.7系统上编译NanoPiNEO开发板的FriendlyCore系统解决问题mkimagenotfound2025/4/279:19缘起:使用NanoPiNEO开发板,编译FriendlyCore系统,编译内核的时候报错。./build.shuboot-buildubootonlyCCdrivers/leds/trigger/ledtrig-default-
- SQL的各种连接查询
xieke90
UNION ALLUNION外连接内连接JOIN
一、内连接
概念:内连接就是使用比较运算符根据每个表共有的列的值匹配两个表中的行。
内连接(join 或者inner join )
SQL语法:
select * fron
- java编程思想--复用类
百合不是茶
java继承代理组合final类
复用类看着标题都不知道是什么,再加上java编程思想翻译的比价难懂,所以知道现在才看这本软件界的奇书
一:组合语法:就是将对象的引用放到新类中即可
代码:
package com.wj.reuse;
/**
*
* @author Administrator 组
- [开源与生态系统]国产CPU的生态系统
comsci
cpu
计算机要从娃娃抓起...而孩子最喜欢玩游戏....
要让国产CPU在国内市场形成自己的生态系统和产业链,国家和企业就不能够忘记游戏这个非常关键的环节....
投入一些资金和资源,人力和政策,让游
- JVM内存区域划分Eden Space、Survivor Space、Tenured Gen,Perm Gen解释
商人shang
jvm内存
jvm区域总体分两类,heap区和非heap区。heap区又分:Eden Space(伊甸园)、Survivor Space(幸存者区)、Tenured Gen(老年代-养老区)。 非heap区又分:Code Cache(代码缓存区)、Perm Gen(永久代)、Jvm Stack(java虚拟机栈)、Local Method Statck(本地方法栈)。
HotSpot虚拟机GC算法采用分代收
- 页面上调用 QQ
oloz
qq
<A href="tencent://message/?uin=707321921&Site=有事Q我&Menu=yes">
<img style="border:0px;" src=http://wpa.qq.com/pa?p=1:707321921:1></a>
- 一些问题
文强chu
问题
1.eclipse 导出 doc 出现“The Javadoc command does not exist.” javadoc command 选择 jdk/bin/javadoc.exe 2.tomcate 配置 web 项目 .....
SQL:3.mysql * 必须得放前面 否则 select&nbs
- 生活没有安全感
小桔子
生活孤独安全感
圈子好小,身边朋友没几个,交心的更是少之又少。在深圳,除了男朋友,没几个亲密的人。不知不觉男朋友成了唯一的依靠,毫不夸张的说,业余生活的全部。现在感情好,也很幸福的。但是说不准难免人心会变嘛,不发生什么大家都乐融融,发生什么很难处理。我想说如果不幸被分手(无论原因如何),生活难免变化很大,在深圳,我没交心的朋友。明
- php 基础语法
aichenglong
php 基本语法
1 .1 php变量必须以$开头
<?php
$a=” b”;
echo
?>
1 .2 php基本数据库类型 Integer float/double Boolean string
1 .3 复合数据类型 数组array和对象 object
1 .4 特殊数据类型 null 资源类型(resource) $co
- mybatis tools 配置详解
AILIKES
mybatis
MyBatis Generator中文文档
MyBatis Generator中文文档地址:
http://generator.sturgeon.mopaas.com/
该中文文档由于尽可能和原文内容一致,所以有些地方如果不熟悉,看中文版的文档的也会有一定的障碍,所以本章根据该中文文档以及实际应用,使用通俗的语言来讲解详细的配置。
本文使用Markdown进行编辑,但是博客显示效
- 继承与多态的探讨
百合不是茶
JAVA面向对象 继承 对象
继承 extends 多态
继承是面向对象最经常使用的特征之一:继承语法是通过继承发、基类的域和方法 //继承就是从现有的类中生成一个新的类,这个新类拥有现有类的所有extends是使用继承的关键字:
在A类中定义属性和方法;
class A{
//定义属性
int age;
//定义方法
public void go
- JS的undefined与null的实例
bijian1013
JavaScriptJavaScript
<form name="theform" id="theform">
</form>
<script language="javascript">
var a
alert(typeof(b)); //这里提示undefined
if(theform.datas
- TDD实践(一)
bijian1013
java敏捷TDD
一.TDD概述
TDD:测试驱动开发,它的基本思想就是在开发功能代码之前,先编写测试代码。也就是说在明确要开发某个功能后,首先思考如何对这个功能进行测试,并完成测试代码的编写,然后编写相关的代码满足这些测试用例。然后循环进行添加其他功能,直到完全部功能的开发。
- [Maven学习笔记十]Maven Profile与资源文件过滤器
bit1129
maven
什么是Maven Profile
Maven Profile的含义是针对编译打包环境和编译打包目的配置定制,可以在不同的环境上选择相应的配置,例如DB信息,可以根据是为开发环境编译打包,还是为生产环境编译打包,动态的选择正确的DB配置信息
Profile的激活机制
1.Profile可以手工激活,比如在Intellij Idea的Maven Project视图中可以选择一个P
- 【Hive八】Hive用户自定义生成表函数(UDTF)
bit1129
hive
1. 什么是UDTF
UDTF,是User Defined Table-Generating Functions,一眼看上去,貌似是用户自定义生成表函数,这个生成表不应该理解为生成了一个HQL Table, 貌似更应该理解为生成了类似关系表的二维行数据集
2. 如何实现UDTF
继承org.apache.hadoop.hive.ql.udf.generic
- tfs restful api 加auth 2.0认计
ronin47
目前思考如何给tfs的ngx-tfs api增加安全性。有如下两点:
一是基于客户端的ip设置。这个比较容易实现。
二是基于OAuth2.0认证,这个需要lua,实现起来相对于一来说,有些难度。
现在重点介绍第二种方法实现思路。
前言:我们使用Nginx的Lua中间件建立了OAuth2认证和授权层。如果你也有此打算,阅读下面的文档,实现自动化并获得收益。SeatGe
- jdk环境变量配置
byalias
javajdk
进行java开发,首先要安装jdk,安装了jdk后还要进行环境变量配置:
1、下载jdk(http://java.sun.com/javase/downloads/index.jsp),我下载的版本是:jdk-7u79-windows-x64.exe
2、安装jdk-7u79-windows-x64.exe
3、配置环境变量:右击"计算机"-->&quo
- 《代码大全》表驱动法-Table Driven Approach-2
bylijinnan
java
package com.ljn.base;
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.Collections;
import java.uti
- SQL 数值四舍五入 小数点后保留2位
chicony
四舍五入
1.round() 函数是四舍五入用,第一个参数是我们要被操作的数据,第二个参数是设置我们四舍五入之后小数点后显示几位。
2.numeric 函数的2个参数,第一个表示数据长度,第二个参数表示小数点后位数。
例如:
select cast(round(12.5,2) as numeric(5,2))  
- c++运算符重载
CrazyMizzz
C++
一、加+,减-,乘*,除/ 的运算符重载
Rational operator*(const Rational &x) const{
return Rational(x.a * this->a);
}
在这里只写乘法的,加减除的写法类似
二、<<输出,>>输入的运算符重载
&nb
- hive DDL语法汇总
daizj
hive修改列DDL修改表
hive DDL语法汇总
1、对表重命名
hive> ALTER TABLE table_name RENAME TO new_table_name;
2、修改表备注
hive> ALTER TABLE table_name SET TBLPROPERTIES ('comment' = new_comm
- jbox使用说明
dcj3sjt126com
Web
参考网址:http://www.kudystudio.com/jbox/jbox-demo.html jBox v2.3 beta [
点击下载]
技术交流QQGroup:172543951 100521167
[2011-11-11] jBox v2.3 正式版
- [调整&修复] IE6下有iframe或页面有active、applet控件
- UISegmentedControl 开发笔记
dcj3sjt126com
// typedef NS_ENUM(NSInteger, UISegmentedControlStyle) {
// UISegmentedControlStylePlain, // large plain
&
- Slick生成表映射文件
ekian
scala
Scala添加SLICK进行数据库操作,需在sbt文件上添加slick-codegen包
"com.typesafe.slick" %% "slick-codegen" % slickVersion
因为我是连接SQL Server数据库,还需添加slick-extensions,jtds包
"com.typesa
- ES-TEST
gengzg
test
package com.MarkNum;
import java.io.IOException;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;
import javax.servlet.ServletException;
import javax.servlet.annotation
- 为何外键不再推荐使用
hugh.wang
mysqlDB
表的关联,是一种逻辑关系,并不需要进行物理上的“硬关联”,而且你所期望的关联,其实只是其数据上存在一定的联系而已,而这种联系实际上是在设计之初就定义好的固有逻辑。
在业务代码中实现的时候,只要按照设计之初的这种固有关联逻辑来处理数据即可,并不需要在数据库层面进行“硬关联”,因为在数据库层面通过使用外键的方式进行“硬关联”,会带来很多额外的资源消耗来进行一致性和完整性校验,即使很多时候我们并不
- 领域驱动设计
julyflame
VODAO设计模式DTOpo
概念:
VO(View Object):视图对象,用于展示层,它的作用是把某个指定页面(或组件)的所有数据封装起来。
DTO(Data Transfer Object):数据传输对象,这个概念来源于J2EE的设计模式,原来的目的是为了EJB的分布式应用提供粗粒度的数据实体,以减少分布式调用的次数,从而提高分布式调用的性能和降低网络负载,但在这里,我泛指用于展示层与服务层之间的数据传输对
- 单例设计模式
hm4123660
javaSingleton单例设计模式懒汉式饿汉式
单例模式是一种常用的软件设计模式。在它的核心结构中只包含一个被称为单例类的特殊类。通过单例模式可以保证系统中一个类只有一个实例而且该实例易于外界访问,从而方便对实例个数的控制并节约系统源。如果希望在系统中某个类的对象只能存在一个,单例模式是最好的解决方案。
&nb
- logback
zhb8015
loglogback
一、logback的介绍
Logback是由log4j创始人设计的又一个开源日志组件。logback当前分成三个模块:logback-core,logback- classic和logback-access。logback-core是其它两个模块的基础模块。logback-classic是log4j的一个 改良版本。此外logback-class
- 整合Kafka到Spark Streaming——代码示例和挑战
Stark_Summer
sparkstormzookeeperPARALLELISMprocessing
作者Michael G. Noll是瑞士的一位工程师和研究员,效力于Verisign,是Verisign实验室的大规模数据分析基础设施(基础Hadoop)的技术主管。本文,Michael详细的演示了如何将Kafka整合到Spark Streaming中。 期间, Michael还提到了将Kafka整合到 Spark Streaming中的一些现状,非常值得阅读,虽然有一些信息在Spark 1.2版
- spring-master-slave-commondao
王新春
DAOspringdataSourceslavemaster
互联网的web项目,都有个特点:请求的并发量高,其中请求最耗时的db操作,又是系统优化的重中之重。
为此,往往搭建 db的 一主多从库的 数据库架构。作为web的DAO层,要保证针对主库进行写操作,对多个从库进行读操作。当然在一些请求中,为了避免主从复制的延迟导致的数据不一致性,部分的读操作也要到主库上。(这种需求一般通过业务垂直分开,比如下单业务的代码所部署的机器,读去应该也要从主库读取数