- NVDIMM 知识点
zhixingheyi_tian
云计算Linux
Anamespacecanbeprovisioned(配置)tooperateinoneof4modes,fsdax,devdax,sector,andraw.Herearetheexpectedusagemodelsforthesemodes:fsdax:Filesystem-DAXmodeisthedefaultmodeofanamespacewhenspecifyingndctlcreate
- Linux 存储 Stack详解
jianchwa
linux
(未完待续,持续更新中)目录序言0存储设备0.1机械盘0.2SSD0.3NVDIMM1VFS1.0基础组件1.0.1iov_iter1.0.2iomap1.1inode1.1.1inode的生命周期1.2Dentry1.2.1dentry的功能1.2.2dentry操作1.2.3rootdentry1.2.4d_splice_alias1.2.5lookup1.2.6symbollink1.3mo
- 使用qemu创建ubuntu-base文件系统,并安装PM相关内核模块
名扬569
工具使用环境搭建nvdimm内核模块qemurootfs
目录一、配置镜像二、使用qemu模拟nvdimm(安装PM相关内核模块)运行记录遇到的一些问题1、ext4文件系统损坏问题:系统启动时,遇到ext4的报错信息解决办法:2、内核模块未成功加载3、qemu报错4、主机终端无法正常打开流程简述:(镜像基本的文件系统配置)1、下载ubuntu-base的镜像2、挂载镜像,配置镜像的网络,并安装各类软件(PM模块配置)3、编译内核模块,并拷贝到镜像中4、启
- 缓存助力存储加速–OCF与SPDK介绍及用法
weixin_37097605
作者简介:惠春阳Intel软件工程师,主要从事spdk,isa-l开发和存储软件性能优化的工作。缓存助力存储加速随着用户对存储速度的要求越来越高,市面上出现了很多高速,超高速的存储设备,比如借助Intel®Optane技术实现的NVDIMM,NVMeSSD等。然而,受限于成本因素,这类高速设备目前并没有大量普及,数据中心依然被SATASSD甚至HDD占据。SPDK在19.01的release中,引
- SCM&NVDIMM学习笔记
kawlyh
存储基础知识学习
参考文章:https://blog.csdn.net/BtB5e6Nsu1g511Eg5XEg/article/details/93984203http://www.openpcba.com/web/contents/get?id=4359&tid=15http://www.360doc.com/showweb.aspx?id=910957413https://www.stmcu.org.cn/a
- nvdimm
marshalzxy
nvdimm(non-volatiledimm)是persistentmemory的一种。persistentmemory就是特殊的一种内存,它采用一般的内存插口(dimm),但是具备断电数据保存功能。它可以采用一般的cpu访问内存的方式load/store,其访问延时是dram级别的;但是它又具备flash式的断电保存功能。至2018年初,市面nvdimm主要是nvdimm-n,它制作是采用dr
- nvdimm
marshalzxy
nvdimm(non-volatiledimm)是persistentmemory的一种。persistentmemory就是特殊的一种内存,它采用一般的内存插口(dimm),但是具备断电数据保存功能。它可以采用一般的cpu访问内存的方式load/store,其访问延时是dram级别的;但是它又具备flash式的断电保存功能。至2018年初,市面nvdimm主要是nvdimm-n,它制作是采用dr
- 超融合基础架构HCI新特性
百思不解
Cloud
重复数据删除和压缩:重复数据擦除支持REFS格式(原来仅支持NTFS),通过重擦和压缩,SDS可以获得高达10倍的空间使用,WindowsAdminCenter一键式启用,多线程处理体系结构最大程度降低对性能影响,每个卷最大支持64TB,每个文件最大支持1TB。对持久内存的原生支持:原生支持持久内存,如Intel傲腾内存和NVDIMM-N,可以使用持久内存作为缓存来加速整个超融合集群,或者使用持久
- 挂载内存文件系统pmfs
SuperNS
文章目录编译内核内存分区挂载编译内核在内核编译的过程中,主要需要做的工作是在makemenuconfig过程中,需要选择一些必要的选项。可以参照官网https://nvdimm.wiki.kernel.org/#dokuwiki__top里面有如何编译、分区、挂载的教程如图所有内容。我是编译的4.4.30的内核,其中有几个选项找不到可以忽略,选项前方括号置为*或M即为选中,具体可以参见menuco
- VMware vSphere 6.7配置最大更改
z荒野求生
VMware
VMwarevSphere6.7配置最大更改VMwarevSphere6.7提供了更高的可扩展性。您可以在我的ESX和vCenter配置最大值页面上查看与所有先前版本的比较。VMwarevSphere6.7中的更改包括:虚拟机最大值vSphere6.7vSphere6.5vSphere6.0NVDIMM控制器1N/AN/A非易失性存储器1TBN/AN/A每个虚拟SCSI适配器的虚拟SCSI目标64
- Linux中的dax特性
jongwu3
linux虚拟化
在Linux中由于块设备一般属于低速设备,访问成本很高,为了减少访问块设备的次数内核一般会将访问磁盘的内容缓存起来,等下次访问时直接从内存中获得结果,这大大提高了系统的性能。所以说缓存是个好东西。但是随着技术进步,一些类似于内存的块设备出现了,主要的有Intel的nvdimm设备,它是一种既可以当磁盘又可以当内存使用的存储设备,它的名字是非易失性内存,速度可以比肩内存,而又不会掉电丢数据。如果这种
- Linux内核中实现保留内存的方法
yhc1991
arm开发linux内核积累
Linux中保留内存(Reservedmemory)是指把系统中的一部分内存保留起来,内核不会为它建立页表,一般的应用程序无法访问到这段内存。在板卡调试、内存测试和设备DAM调试的过程中,可以运用这种办法,先验证系统在只有低端内存的情况下能否顺利启动;此外,服务器和存储系统的环境下,也可以用这种方法从大量系统内存中保留出一部分,留给特殊用途使用或者模拟诸如NVDIMM等设备。因此,有必要对Rese
- Linux Kernel中AEP的现状和发展
Linux阅码场
阿里石洋内核月谈YesterdayAEP简介AEP是Intel推出的一种新型的非易失OptaneMemory设备,又被称作ApachePass,所以一般习惯称作AEP。在这之前也有类似的设备称作NVDIMM或PMEM,目前Linux创建的AEP设备节点也是叫做pmem(如/dev/pmem0),所以本文中NVDIMM或PMEM都指AEP。但是本文不是为了科普AEP,如果想了解AEP的一些基本知识,
- NVDIMM原理与应用之四:基于pstore 和 ramoops保存Kernel panic日志
weixin_34272308
基于pstore和ramoops实现在非易失性内存中保存panic日志具体步骤如下0.确定地址范围需求提前知道用来保存panic日志的非易失性内存的起始地址和长度。比如笔者用到的那部分内存的起始地址是0x11ff000000,长度是16M。2.修改内核保证内核配置选项中选上了ramoops驱动支持:生成驱动加载过程中,如果发现对独立的非易失性存储加载驱动失败,检查是否需要修改内核驱动,特别是fs/
- 【NVM文件系统】基于日志结构的文件系统NOVA(NVMFS)的部署(内核编译+挂载)
Captain_zw
SDPM
NOVA介绍NOVA是一个基于日志结构的文件系统,但它不是为整个文件系统维护一个全局日志,而是为每个文件(inode)维护独立的日志。NOVA将日志分成4KB页面,它们在内存中不需要连续。日志只包含元数据。NOVA的目标是为字节寻址的非易失性存储器(例如,NVDIMM和即将发布的3DXpointDIMM)提供高性能,功能齐全的生产就绪文件系统。它结合了许多其他文件系统的设计元素,提供高性能、一致性
- NVDIMM-P 和 NVIDMM-N ABC
存储之厨
AEP高速总线及设备
这篇博客主要记录最近了解的一些主要NVIDMM厂家及其产品。分类NVIDMM-N:memorymappedDRAM,提供字符访问接口,在三种产品中性能最好,容量最小NVDIMM-F:memorymappedFlush,只提供块设备接口。NandFlush直接链接到Memorycontrollerchannel。NVIDMM-N:memroymappedFlush,提供块设备和字符设备访问接口。特性
- 超融合基础架构HCI新特性
百思不解
Cloud
重复数据删除和压缩:重复数据擦除支持REFS格式(原来仅支持NTFS),通过重擦和压缩,SDS可以获得高达10倍的空间使用,WindowsAdminCenter一键式启用,多线程处理体系结构最大程度降低对性能影响,每个卷最大支持64TB,每个文件最大支持1TB。对持久内存的原生支持:原生支持持久内存,如Intel傲腾内存和NVDIMM-N,可以使用持久内存作为缓存来加速整个超融合集群,或者使用持久
- 完成Persistent Memory的模拟
一只呱呱呱啊
过程主要参考:https://nvdimm.wiki.kernel.org/how_to_choose_the_correct_memmap_kernel_parameter_for_pmem_on_your_systemhttps://software.intel.com/zh-cn/articles/how-to-emulate-persistent-memory-on-an-intel-ar
- nvdimm 驱动的分析
存储之厨
nvdimmkerneldriverDriver
nvdimm驱动的分析1.驱动的简介nvdimm在内核中的驱动,是基于一个典型的字符类型的设备驱动模型去实现的。因此,同样需要实现设备驱动的几个典型操作:open/release/mmap/ioctl。在open阶段通过efi或者e820table探测到nvdimm的起始物理地址和长度,通过set_mtrr()设置nvdimm对应程序空间的cache属性,通过io_remmap()把物理地址映射到
- NVDIMM在闪存存储中的应用探讨
wuzhongjie
SSDNVDIMM闪存存储存储技术
SSD作为新型存储介质对外暴露成一种通用块设备,传统应用似乎无需任何改变就可以在SSD上运行。在实际应用过程中,传统业务的确可以在SSD上直接运行,但问题是SSD并没有被充分利用,优势没有被充分发挥;更糟糕的是业务的IO特性会导致SSD出现新的问题。例如,在有些应用现场,用户发现SSD的使用寿命被很快耗尽,写放大系统变得很大,使用寿命与预期不同。厂商的写放大系统是在特定的IOPattern下测算出
- Linux内核中实现保留内存的方法
存储之厨
linuxkernelreserved
Linux中保留内存(Reservedmemory)是指把系统中的一部分内存保留起来,内核不会为它建立页表,一般的应用程序无法访问到这段内存。在板卡调试、内存测试和设备DAM调试的过程中,可以运用这种办法,先验证系统在只有低端内存的情况下能否顺利启动;此外,服务器和存储系统的环境下,也可以用这种方法从大量系统内存中保留出一部分,留给特殊用途使用或者模拟诸如NVDIMM等设备。因此,有必要对Rese
- NVDIMM ABC
存储之厨
cpuNVDIMMNVMe
NVDIMM概述1、简介顾名思义,NVDIMM是Non-VolatileDIMM(非易失性内存)的简称。作为系统掉电后仍然保证数据不丢失的重要硬件,NVDIMM和NVRAM的功能类似,都是在系统掉电时仍然能够保证一部分内存里的数据不会丢失,并且当系统上电后数据能够自动恢复到内存当中。和NVRAM不同的是,NVRAM要么是把数据写回到PCIE接口的独立卡上,要么是依赖于独立的后备电池给DRAM在系统
- 非易失内存技术NVDIMM
wuzhongjie
FlashSSDnandNVDIMM
从技术的角度来看,NANDFlash闪存介质虽然存在擦写次数寿命的问题,但是,配合软件算法、系统级的数据保护技术,NANDFlash的寿命问题变得不再是一个棘手的问题,而NANDFlash更多的优势成为该项技术向前推进的重要动力。采用NANDFlash构建的SSD正快速的替代传统磁盘,已经大面积的在互联网领域得到应用,并且不断向对数据可靠性有要求的企业级市场渗透。 SSD和传统磁盘相比有几个非常独
- 非易失内存技术NVDIMM
wuzhongjie
FlashSSDnandNVDIMM
从技术的角度来看,NANDFlash闪存介质虽然存在擦写次数寿命的问题,但是,配合软件算法、系统级的数据保护技术,NANDFlash的寿命问题变得不再是一个棘手的问题,而NANDFlash更多的优势成为该项技术向前推进的重要动力。采用NANDFlash构建的SSD正快速的替代传统磁盘,已经大面积的在互联网领域得到应用,并且不断向对数据可靠性有要求的企业级市场渗透。 SSD和传统磁盘相比有几个非常独
- 非易失内存技术NVDIMM
wuzhongjie
SSDNVDIMMNANDFlashSSD技术
从技术的角度来看,NANDFlash闪存介质虽然存在擦写次数寿命的问题,但是,配合软件算法、系统级的数据保护技术,NANDFlash的寿命问题变得不再是一个棘手的问题,而NANDFlash更多的优势成为该项技术向前推进的重要动力。采用NANDFlash构建的SSD正快速的替代传统磁盘,已经大面积的在互联网领域得到应用,并且不断向对数据可靠性有要求的企业级市场***。SSD和传统磁盘相比有几个非常独
- Java常用排序算法/程序员必须掌握的8大排序算法
cugfy
java
分类:
1)插入排序(直接插入排序、希尔排序)
2)交换排序(冒泡排序、快速排序)
3)选择排序(直接选择排序、堆排序)
4)归并排序
5)分配排序(基数排序)
所需辅助空间最多:归并排序
所需辅助空间最少:堆排序
平均速度最快:快速排序
不稳定:快速排序,希尔排序,堆排序。
先来看看8种排序之间的关系:
1.直接插入排序
(1
- 【Spark102】Spark存储模块BlockManager剖析
bit1129
manager
Spark围绕着BlockManager构建了存储模块,包括RDD,Shuffle,Broadcast的存储都使用了BlockManager。而BlockManager在实现上是一个针对每个应用的Master/Executor结构,即Driver上BlockManager充当了Master角色,而各个Slave上(具体到应用范围,就是Executor)的BlockManager充当了Slave角色
- linux 查看端口被占用情况详解
daizj
linux端口占用netstatlsof
经常在启动一个程序会碰到端口被占用,这里讲一下怎么查看端口是否被占用,及哪个程序占用,怎么Kill掉已占用端口的程序
1、lsof -i:port
port为端口号
[root@slave /data/spark-1.4.0-bin-cdh4]# lsof -i:8080
COMMAND PID USER FD TY
- Hosts文件使用
周凡杨
hostslocahost
一切都要从localhost说起,经常在tomcat容器起动后,访问页面时输入http://localhost:8088/index.jsp,大家都知道localhost代表本机地址,如果本机IP是10.10.134.21,那就相当于http://10.10.134.21:8088/index.jsp,有时候也会看到http: 127.0.0.1:
- java excel工具
g21121
Java excel
直接上代码,一看就懂,利用的是jxl:
import java.io.File;
import java.io.IOException;
import jxl.Cell;
import jxl.Sheet;
import jxl.Workbook;
import jxl.read.biff.BiffException;
import jxl.write.Label;
import
- web报表工具finereport常用函数的用法总结(数组函数)
老A不折腾
finereportweb报表函数总结
ADD2ARRAY
ADDARRAY(array,insertArray, start):在数组第start个位置插入insertArray中的所有元素,再返回该数组。
示例:
ADDARRAY([3,4, 1, 5, 7], [23, 43, 22], 3)返回[3, 4, 23, 43, 22, 1, 5, 7].
ADDARRAY([3,4, 1, 5, 7], "测试&q
- 游戏服务器网络带宽负载计算
墙头上一根草
服务器
家庭所安装的4M,8M宽带。其中M是指,Mbits/S
其中要提前说明的是:
8bits = 1Byte
即8位等于1字节。我们硬盘大小50G。意思是50*1024M字节,约为 50000多字节。但是网宽是以“位”为单位的,所以,8Mbits就是1M字节。是容积体积的单位。
8Mbits/s后面的S是秒。8Mbits/s意思是 每秒8M位,即每秒1M字节。
我是在计算我们网络流量时想到的
- 我的spring学习笔记2-IoC(反向控制 依赖注入)
aijuans
Spring 3 系列
IoC(反向控制 依赖注入)这是Spring提出来了,这也是Spring一大特色。这里我不用多说,我们看Spring教程就可以了解。当然我们不用Spring也可以用IoC,下面我将介绍不用Spring的IoC。
IoC不是框架,她是java的技术,如今大多数轻量级的容器都会用到IoC技术。这里我就用一个例子来说明:
如:程序中有 Mysql.calss 、Oracle.class 、SqlSe
- 高性能mysql 之 选择存储引擎(一)
annan211
mysqlInnoDBMySQL引擎存储引擎
1 没有特殊情况,应尽可能使用InnoDB存储引擎。 原因:InnoDB 和 MYIsAM 是mysql 最常用、使用最普遍的存储引擎。其中InnoDB是最重要、最广泛的存储引擎。她 被设计用来处理大量的短期事务。短期事务大部分情况下是正常提交的,很少有回滚的情况。InnoDB的性能和自动崩溃 恢复特性使得她在非事务型存储的需求中也非常流行,除非有非常
- UDP网络编程
百合不是茶
UDP编程局域网组播
UDP是基于无连接的,不可靠的传输 与TCP/IP相反
UDP实现私聊,发送方式客户端,接受方式服务器
package netUDP_sc;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.Ine
- JQuery对象的val()方法执行结果分析
bijian1013
JavaScriptjsjquery
JavaScript中,如果id对应的标签不存在(同理JAVA中,如果对象不存在),则调用它的方法会报错或抛异常。在实际开发中,发现JQuery在id对应的标签不存在时,调其val()方法不会报错,结果是undefined。
- http请求测试实例(采用json-lib解析)
bijian1013
jsonhttp
由于fastjson只支持JDK1.5版本,因些对于JDK1.4的项目,可以采用json-lib来解析JSON数据。如下是http请求的另外一种写法,仅供参考。
package com;
import java.util.HashMap;
import java.util.Map;
import
- 【RPC框架Hessian四】Hessian与Spring集成
bit1129
hessian
在【RPC框架Hessian二】Hessian 对象序列化和反序列化一文中介绍了基于Hessian的RPC服务的实现步骤,在那里使用Hessian提供的API完成基于Hessian的RPC服务开发和客户端调用,本文使用Spring对Hessian的集成来实现Hessian的RPC调用。
定义模型、接口和服务器端代码
|---Model
&nb
- 【Mahout三】基于Mahout CBayes算法的20newsgroup流程分析
bit1129
Mahout
1.Mahout环境搭建
1.下载Mahout
http://mirror.bit.edu.cn/apache/mahout/0.10.0/mahout-distribution-0.10.0.tar.gz
2.解压Mahout
3. 配置环境变量
vim /etc/profile
export HADOOP_HOME=/home
- nginx负载tomcat遇非80时的转发问题
ronin47
nginx负载后端容器是tomcat(其它容器如WAS,JBOSS暂没发现这个问题)非80端口,遇到跳转异常问题。解决的思路是:$host:port
详细如下:
该问题是最先发现的,由于之前对nginx不是特别的熟悉所以该问题是个入门级别的:
? 1 2 3 4 5
- java-17-在一个字符串中找到第一个只出现一次的字符
bylijinnan
java
public class FirstShowOnlyOnceElement {
/**Q17.在一个字符串中找到第一个只出现一次的字符。如输入abaccdeff,则输出b
* 1.int[] count:count[i]表示i对应字符出现的次数
* 2.将26个英文字母映射:a-z <--> 0-25
* 3.假设全部字母都是小写
*/
pu
- mongoDB 复制集
开窍的石头
mongodb
mongo的复制集就像mysql的主从数据库,当你往其中的主复制集(primary)写数据的时候,副复制集(secondary)会自动同步主复制集(Primary)的数据,当主复制集挂掉以后其中的一个副复制集会自动成为主复制集。提供服务器的可用性。和防止当机问题
mo
- [宇宙与天文]宇宙时代的经济学
comsci
经济
宇宙尺度的交通工具一般都体型巨大,造价高昂。。。。。
在宇宙中进行航行,近程采用反作用力类型的发动机,需要消耗少量矿石燃料,中远程航行要采用量子或者聚变反应堆发动机,进行超空间跳跃,要消耗大量高纯度水晶体能源
以目前地球上国家的经济发展水平来讲,
- Git忽略文件
Cwind
git
有很多文件不必使用git管理。例如Eclipse或其他IDE生成的项目文件,编译生成的各种目标或临时文件等。使用git status时,会在Untracked files里面看到这些文件列表,在一次需要添加的文件比较多时(使用git add . / git add -u),会把这些所有的未跟踪文件添加进索引。
==== ==== ==== 一些牢骚
- MySQL连接数据库的必须配置
dashuaifu
mysql连接数据库配置
MySQL连接数据库的必须配置
1.driverClass:com.mysql.jdbc.Driver
2.jdbcUrl:jdbc:mysql://localhost:3306/dbname
3.user:username
4.password:password
其中1是驱动名;2是url,这里的‘dbna
- 一生要养成的60个习惯
dcj3sjt126com
习惯
一生要养成的60个习惯
第1篇 让你更受大家欢迎的习惯
1 守时,不准时赴约,让别人等,会失去很多机会。
如何做到:
①该起床时就起床,
②养成任何事情都提前15分钟的习惯。
③带本可以随时阅读的书,如果早了就拿出来读读。
④有条理,生活没条理最容易耽误时间。
⑤提前计划:将重要和不重要的事情岔开。
⑥今天就准备好明天要穿的衣服。
⑦按时睡觉,这会让按时起床更容易。
2 注重
- [介绍]Yii 是什么
dcj3sjt126com
PHPyii2
Yii 是一个高性能,基于组件的 PHP 框架,用于快速开发现代 Web 应用程序。名字 Yii (读作 易)在中文里有“极致简单与不断演变”两重含义,也可看作 Yes It Is! 的缩写。
Yii 最适合做什么?
Yii 是一个通用的 Web 编程框架,即可以用于开发各种用 PHP 构建的 Web 应用。因为基于组件的框架结构和设计精巧的缓存支持,它特别适合开发大型应
- Linux SSH常用总结
eksliang
linux sshSSHD
转载请出自出处:http://eksliang.iteye.com/blog/2186931 一、连接到远程主机
格式:
ssh name@remoteserver
例如:
ssh
[email protected]
二、连接到远程主机指定的端口
格式:
ssh name@remoteserver -p 22
例如:
ssh i
- 快速上传头像到服务端工具类FaceUtil
gundumw100
android
快速迭代用
import java.io.DataOutputStream;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOExceptio
- jQuery入门之怎么使用
ini
JavaScripthtmljqueryWebcss
jQuery的强大我何问起(个人主页:hovertree.com)就不用多说了,那么怎么使用jQuery呢?
首先,下载jquery。下载地址:http://hovertree.com/hvtart/bjae/b8627323101a4994.htm,一个是压缩版本,一个是未压缩版本,如果在开发测试阶段,可以使用未压缩版本,实际应用一般使用压缩版本(min)。然后就在页面上引用。
- 带filter的hbase查询优化
kane_xie
查询优化hbaseRandomRowFilter
问题描述
hbase scan数据缓慢,server端出现LeaseException。hbase写入缓慢。
问题原因
直接原因是: hbase client端每次和regionserver交互的时候,都会在服务器端生成一个Lease,Lease的有效期由参数hbase.regionserver.lease.period确定。如果hbase scan需
- java设计模式-单例模式
men4661273
java单例枚举反射IOC
单例模式1,饿汉模式
//饿汉式单例类.在类初始化时,已经自行实例化
public class Singleton1 {
//私有的默认构造函数
private Singleton1() {}
//已经自行实例化
private static final Singleton1 singl
- mongodb 查询某一天所有信息的3种方法,根据日期查询
qiaolevip
每天进步一点点学习永无止境mongodb纵观千象
// mongodb的查询真让人难以琢磨,就查询单天信息,都需要花费一番功夫才行。
// 第一种方式:
coll.aggregate([
{$project:{sendDate: {$substr: ['$sendTime', 0, 10]}, sendTime: 1, content:1}},
{$match:{sendDate: '2015-
- 二维数组转换成JSON
tangqi609567707
java二维数组json
原文出处:http://blog.csdn.net/springsen/article/details/7833596
public class Demo {
public static void main(String[] args) { String[][] blogL
- erlang supervisor
wudixiaotie
erlang
定义supervisor时,如果是监控celuesimple_one_for_one则删除children的时候就用supervisor:terminate_child (SupModuleName, ChildPid),如果shutdown策略选择的是brutal_kill,那么supervisor会调用exit(ChildPid, kill),这样的话如果Child的behavior是gen_