vdbench的作用_基于SSD的iSCSI target的建立和Vdbench测试「建议收藏」

vdbench的作用_基于SSD的iSCSI target的建立和Vdbench测试「建议收藏」在SAN存储系统中,LIO是把存储设备直接转化为可用存储资源的高效工具,它实现了基于文件/块设备/ramdisk甚至回环设备创建存储设备的iscsitarget接口和CLI。通过iSCSIinitiator访问iSCSItarget的典型应用场景和联接如下图所示意:上图非常直观地显示了基于ram、/dev/下的设备以及文件,创建iSCSItarget的数据流。如果更深入地再往下看,可以看到它和…

大家好,又见面了,我是你们的朋友全栈君。

在SAN存储系统中,LIO是把存储设备直接转化为可用存储资源的高效工具,它实现了基于文件/块设备/ramdisk甚至回环设备创建存储设备的iscsi

target接口和CLI。 通过iSCSI

initiator访问iSCSI

target 的典型应用场景和联接如下图所示意:

vdbench的作用_基于SSD的iSCSI target的建立和Vdbench测试「建议收藏」

上图非常直观地显示了基于ram、/dev/下的设备以及文件,创建iSCSI

target的数据流。如果更深入地再往下看,可以看到它和底层文件系统、卷管理的接口如下所示:

vdbench的作用_基于SSD的iSCSI target的建立和Vdbench测试「建议收藏」

厘清了iSCSI的应用模式和软件层次后,就不难理解如何创建iscsi

target 设备了,并且也会理解为何

在数据传输之前,需要iscsi

initiator 和iscsi

target 设备建立起连接了。

下面通过具体的命令,举例说明在linux操作系统里面如何创建iscsi

target、建立iscsi链接和使用iscsi资源。首先需要在存储资源所挂载的机器上用targetcli创建target:

[root@localhost]#

targetcli /backstores/block create my_ssd

/dev/disk/by-id/wwn-0x55cd2e404b7b8ced-part5

\Created

block storage object my_ssd using

/dev/disk/by-id/wwn-0x55cd2e404b7b8ced-part5.

[root@localhost]#

targetcli /iscsi create

Created

target iqn.2003-01.org.linux-iscsi.localhost.x8664:sn.beb1fd396120.

Created

TPG 1.

Global

pref auto_add_default_portal=true

Created

default portal listening on all IPs (0.0.0.0), port 3260.

[root@localhost]#

targetcli

/iscsi/iqn.2003-01.org.linux-iscsi.localhost.x8664:sn.beb1fd396120/tpg1/luns

create /backstores/block/my_ssd

Created

LUN 0.

You

have new mail in /var/spool/mail/root

[root@localhost]#

targetcli

/iscsi/iqn.2003-01.org.linux-iscsi.localhost.x8664:sn.beb1fd396120/tpg1

set attribute authentication=0 demo_mode_write_protect=0

generate_node_acls=1

Parameter

authentication is now ‘0’.

Parameter

demo_mode_write_protect is now ‘0’.

Parameter

generate_node_acls is now ‘1’.

[root@localhost]#

targetcli saveconfig myssd.config

Configuration

saved to myssd.config

上面命令还把当前配置保存到文件myssd.config当中去,机器重启后,还可以从这个文件

恢复到当前设置,这样就可以避免需要重新输入上面的命令:

[root@localhost]#

targetcli clearconfig confirm=True

All

configuration cleared

如果上面没有制定文件名,默认会保存到/etc/target/saveconfig.json文件当中去。

[root@localhost]#

targetcli restoreconfig myssd.config

接着需要在initiator端连接到target端,先探测有没有iscsi能被找到,如果找到自动连接上去:

[root@localhost

PlxSdk]# iscsiadm -m discovery -t st -p 10.10.2.33 -l

Logging

in to [iface: default, target:

iqn.2003-01.org.linux-iscsi.localhost.x8664:sn.beb1fd396120, portal:

10.10.2.33,3260] (multiple)

Login

to [iface: default, target:

iqn.2003-01.org.linux-iscsi.localhost.x8664:sn.beb1fd396120, portal:

10.10.2.33,3260] successful.

这时能从/dev设备下看到多出一个设备:

lrwxrwxrwx.

1 root root    9 Jun 20 20:19

ip-10.10.2.33:3260-iscsi-iqn.2003-01.org.linux-iscsi.localhost.x8664:sn.beb1fd396120-lun-0

-> ../../sdr

这就证明iscsi

target已经映射到了initiator

/dev/sdr这个设备上,在initiator端对/dev/sdr进行读写访问,就相当于往远端的10.10.2.33机器上的/dev/disk/by-id/wwn-0x55cd2e404b7b8ced-part5进行读写。

当然,使用完了之后,可以用下面的命令断开连接:

[root@localhost

PlxSdk]# iscsiadm -m session -u

Logging

out of session [sid: 1, target:

iqn.2003-01.org.linux-iscsi.localhost.x8664:sn.b5928f6012db, portal:

10.10.2.33,3260]

Logging

out of session [sid: 2, target:

iqn.2003-01.org.linux-iscsi.localhost.x8664:sn.beb1fd396120, portal:

10.10.2.33,3260]

最后运行测试程序,下面以vdbench为例,开始测试:

[root@localhost

vdbench]# cat ssd_param && ./vdbench  -f ssd_param -k -o

ssd_vdbench.out

sd=sd2,lun=/dev/sdr,openflags=o_direct,size=500m,threads=24

wd=wd1,xfersize=4k,rdpct=0,seekpct=100

rd=rd1,wd=wd1,sd=*,iorate=max,elapsed=5,interval=1,warmup=5,threads=24

Vdbench

distribution: vdbench504

For

documentation, see ‘vdbench.pdf’.

20:25:40.991

Created output directory ‘/home/vdbench_qichao/ssd_vdbench.out’

20:25:41.021

input argument scanned: ‘-fssd_param’

20:25:41.021

input argument scanned: ‘-k’

20:25:41.021

input argument scanned: ‘-ossd_vdbench.out’

20:25:41.153

Starting slave: /home/vdbench/vdbench SlaveJvm -m localhost -n

localhost-10-160620-20.25.40.968 -l localhost-0 -p 5570

20:25:41.627

All slaves are now connected

20:25:43.001

Starting RD=rd1; I/O rate: Uncontrolled MAX; elapsed=5 warmup=5; For

loops: threads=24

20:25:54.068

Vdbench execution completed successfully. Output directory:

/home/vdbench/ssd_vdbench.out

参考文档和链接:

http://linux-iscsi.org/wiki/Targetcli

http://www.linux-iscsi.org/Doc/LIO%20Admin%20Manual.pdf

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/144492.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • inputstream类型的变量需要关闭吗_input type

    inputstream类型的变量需要关闭吗_input typeinputStream的作用是用来表示那些从不同数据源产生输入的类。这些数据源包括    1字节数组    2String对象   3文件   4管道,工作方式与实际管道相似,即一端输入,从另一端输出    5一个由其他种类的流组成的序列,以便我们可以将他们收集合并到一个流内   6其他数据源,如internet连接等 每一种数据源都有相

    2022年9月21日
    3
  • pkl文件是什么_python pkl文件

    pkl文件是什么_python pkl文件这里只介绍关于字典类型和列表类型的数据的存储,其他格式的请君自行探索。1、字典类型importpickle#首先导入这个库,没有安装的话,自行百度,很简单dict_data={“name”:[“张三”,”李四”]}withopen(“dict_data.pkl”,’wb’)asfo:#将数据写入pkl文件pickle.dump(dict_data,fo)with…

    2025年9月8日
    6
  • c语言程序设计打卡系统,C语言程序设计报告书学生考勤系统设计.doc[通俗易懂]

    c语言程序设计打卡系统,C语言程序设计报告书学生考勤系统设计.doc[通俗易懂]设计题目:学生考勤系统设计设计方案:该系统能考察学生的出勤情况,所以包括每个班学生的全部信息。每个学生是一条记录,包括姓名﹑性别﹑学号,对应于某天某门课程的出勤情况等。该系统可模拟考勤过程,记录考勤结果,并能在课程结束后按照设定的考勤评分标准自动给出每个学生的考勤分数。其中,学生可在本系统在线请假以及查看学期内的上课出勤信息。在线请假中,学生可以随时查看到请假的详细进展情况。同时,学生可以查看本期…

    2025年6月12日
    2
  • 存储过程使用数组参数

    存储过程使用数组参数

    2021年9月16日
    54
  • 用递归实现数组求和的函数_JAVA数组递归排序

    用递归实现数组求和的函数_JAVA数组递归排序题目:给定一个len长度的数组,用递归的方法求数组和C代码实现:#include#includeintgetSum(inta[],intlen){ if(len==0)//要考虑空数组的情况 { return0; } else { intn=len-1; if(n==0) { returna[n

    2022年10月2日
    2
  • Java 8 开发的 4 大顶级技巧,你都知道吗 ?

    点击上方“全栈程序员社区”,星标公众号 重磅干货,第一时间送达 来源:https://dzone.com/articles/java-8-top-tips 正文 我使用Java 8…

    2021年6月28日
    77

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号