分布式存储的三种类型

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了分布式存储的三种类型相关的知识,希望对你有一定的参考价值。

参考技术A 有关分布式存储的三个基本问题

文件系统vs对象存储——选型和趋势

块存储、文件存储、对象存储这三者的本质差别是什么

分布式存储的应用场景相对于其存储接口,现在流行分为三种:

对象存储: 也就是通常意义的键值存储,其接口就是简单的GET、PUT、DEL和其他扩展,如七牛、又拍、Swift、S3

块存储: 这种接口通常以QEMU Driver或者Kernel Module的方式存在,这种接口需要实现Linux的Block Device的接口或者QEMU提供的Block Driver接口,如Sheepdog,AWS的EBS,青云的云硬盘和阿里云的盘古系统,还有Ceph的RBD(RBD是Ceph面向块存储的接口)

文件存储: 通常意义是支持POSIX接口,它跟传统的文件系统如Ext4是一个类型的,但区别在于分布式存储提供了并行化的能力,如Ceph的CephFS(CephFS是Ceph面向文件存储的接口),但是有时候又会把GFS,HDFS这种非POSIX接口的类文件存储接口归入此类。

生成二维码的三种方式

一:二维码的概念
二维条码(2-dimemsional bar code)是用某种特定的几何图形按一定规律在平面(二维方向上)分布的黑白相间的图形记录数据符号信息的图形

二: 二维码的分类
通常分为三种类型:
1.0 线性堆叠式二维码
编码原理:建立在一维条码基础之上,按需要堆积成两行或者多行
2.0 矩阵式二维码
在一个矩阵空间通过黑白像素在矩阵中的不同分布进行编码,用点表示二进制的1,空白表示二进制的0
3.0 邮政码
通过不同长度的条进行编码,主要用于邮政编码,如POSTNET、BPO4-STATE

三: 二维码的优缺点
1.0 高密度编码,信息容量大
2.0 编码范围广
3.0 容错能力强
4.0 译码可靠性高
5.0 可引入加密措施
6.0 成本低,易制作,持久耐用

缺点:二维码成为手机病毒,钓鱼网站传播的新渠道、信息泄露

四:QR Code
1.0 目前流行的三大国际标准
PDF417 : 不支持中文
DM : 专利未公开,需支付专利费用
QR Code : 专利公开,支持中文
2.0 两种生成方式
01 : 借助第三方的jar包,如zxing和qrcodejar
02 : javascript,如jQuery.qrcode.js

五 :实例讲解
1.0: zxing (http://github.com/zxing/)
1.1 : 进入该链接下载源码,新建java项目,导入core、javase包中的com文件,export为jar文件
1.2: public class CreatQRCode {

public static void main(String[] args) {

int width = 300;
int height = 300;
String formart = "png";
String content = "www.gongzifusu.com";

//定义二维码的参数
HashMap hints = new HashMap<>();
hints.put(EncodeHintType.CHARACTER_SET,"utf-8"); //编码格式
hints.put(EncodeHintType.ERROR_CORRECTION,ErrorCorrectionLevel.M); //容错等级
hints.put(EncodeHintType.MARGIN,2); //边距

//生成二维码
try {

BitMatrix bitMatrix = new MultiFormatWriter().encode(content, BarcodeFormat.QR_CODE, width, height);
Path file = new File("C:/Users/Administrator/Desktop/QRCode/img.png").toPath();
MatrixToImageWriter.writeToPath(bitMatrix, formart, file);

} catch (Exception e) {

e.printStackTrace();

}

}

}
1.3: 解析二维码
public static void main(String[] args) {

try {
MultiFormatReader multiFormatReader = new MultiFormatReader();
File file = new File("C:/Users/Administrator/Desktop/QRCode/img.png");
BufferedImage bufferedImage = ImageIO.read(file);
BinaryBitmap binaryBitmap = new BinaryBitmap(new HybridBinarizer(new BufferedImageLuminanceSource(bufferedImage)));

//定义二维码的参数
HashMap hints = new HashMap<>();
hints.put(EncodeHintType.CHARACTER_SET,"utf-8"); //编码格式

Result result = multiFormatReader.decode(binaryBitmap,hints);
System.out.println("解析结果: "+result.toString());
System.out.println("二维码格式: "+result.getBarcodeFormat());
System.out.println("二维码文本内容: "+result.getText());
} catch (Exception e) {
e.printStackTrace();
}
}

2.0 QRCode方式生成二维码(http://www.swetake.com/qrcode/index-e.html)/(https://osdn.jp/projects/qrcode/)
2.1 :下载相关源码文件,创建java项目,导入jar包,
2.2 : 生成二维码
public class CreateQRCodeByQC {

public static void main(String[] args) throws Exception{

Qrcode x = new Qrcode();
x.setQrcodeEncodeMode(‘M‘); //纠错等级
x.setQrcodeEncodeMode(‘B‘); //N代表数字,A代表a_Z,B代表其他符号
x.setQrcodeVersion(7); //版本
String qrDate = "天降大任于斯人也,必先苦其心志,劳其筋骨,饿其体肤,空乏其身,增益其所不能,所以动心忍性...";

int width = 67 + 12 * (x.getQrcodeVersion()-1);
int height = 67 + 12 * (x.getQrcodeVersion()-1);
BufferedImage bufferedImage = new BufferedImage(width, height, BufferedImage.TYPE_INT_BGR);

Graphics2D gs = bufferedImage.createGraphics();

gs.setBackground(Color.WHITE);
gs.setColor(Color.BLACK);
gs.clearRect(0, 0, width, height);

int pixoff = 2 ; //偏移量

byte[] d = qrDate.getBytes("gb2312");
if (d.length>0 && d.length <120) {
boolean [][]s = x.calQrcode(d);
for (int i = 0; i < s.length; i++) {
for (int j = 0; j < s.length; j++) {
if (s[j][i]) {
gs.fillRect(j*3+pixoff,i*3 +pixoff,3,3);
}
}
}
}

gs.dispose();
bufferedImage.flush();

ImageIO.write(bufferedImage,"png", new File("C:/Users/Administrator/Desktop/QRCode/qrcode.png"));

}

}
2.3 解析二维码
public class ReadQRCodeByQR {

public static void main(String[] args) throws Exception{

File file = new File("C:/Users/Administrator/Desktop/QRCode/qrcode.png");

BufferedImage bufferedImage = ImageIO.read(file);
QRCodeDecoder qrCodeDecoder = new QRCodeDecoder();
String result = new String(qrCodeDecoder.decode(new MyQRCodeImage(bufferedImage)),"gb2312");

System.out.println(result);

}

}

public class MyQRCodeImage implements QRCodeImage{

BufferedImage bufferedImage;


public MyQRCodeImage(BufferedImage bufferedImage) {
super();
this.bufferedImage = bufferedImage;
}

@Override
public int getHeight() {

// TODO Auto-generated method stub
return bufferedImage.getHeight();
}

@Override
public int getPixel(int arg0, int arg1) {

// TODO Auto-generated method stub
return bufferedImage.getRGB(arg0, arg1);
}

@Override
public int getWidth() {

// TODO Auto-generated method stub
return bufferedImage.getWidth();
}

}

3.0 jQuery-qrcode(https://github.com/jeromeetienne/jquery-qrcode)
3.1 新建web项目,导入jquery.min.js、jquery.qrcode.min.js
3.2 <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>页面生成二维码</title>
<script type="text/javascript" src="<%=request.getContextPath()%>/js/jquery.min.js"></script>
<script type="text/javascript" src="<%=request.getContextPath()%>/js/jquery.qrcode.min.js"></script>
</head>
<body>
生成二维码如下:<br>
<div id="qrcode"></div>

<script type="text/javascript">
jQuery(‘#qrcode‘).qrcode("www.STK.com");
</script>
</body>
</html>

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

以上是关于分布式存储的三种类型的主要内容,如果未能解决你的问题,请参考以下文章

SSO三种情况的实现方式

随笔-SQL的三种存储引擎即三种类型的表

云计算的三种服务类型

关于MySQL中的三种日期类型

HDFS简介:不用HDFS我们如何存储大规模数据

Git基础