FreeBSD iSCSI
Sisukord
Sissejuhatus
iSCSI tehnoloogia võimaldab üle TCP/IP võrgu ühendada klientarvutile külge plokk-seadme vastavat teenust pakkuvast serverist, kusjuures on kombeks kasutada selliseid nimetusi kliendi ja serveri kohta
- initiator - iSCSI klient
- target - iSCSI server
Target ja initiator arvutid võivad kasutada erinevaid operatsioonisüsteeme ning asuda ka erinevatel riistvaralistel platvormidel. Kuna andmevahetuse maht võib kujuneda suureks, siis võib olla mõistlik lisaks kasutusele võtta ainult iSCSI jaoks eraldatud võrgusegment.
FreeBSD8 versiooniga tuleb kaasa sisseehitatud iSCSI initiator ja iscontrol käsurea utiliit. Kahjuks puudub hetkel iSCSI target.
Selleks, et kasutada iSCSI targetit on olemas kaks rakendus portsudes. Esiteks "iscsi-target" (/usr/ports/net/iscsi-target), mis on vahem ja NetBSD pealt porditud lahendus. Teiseks "istgt" (/usr/ports/net/istgt/), mis kaasaegse, uuem ja originaalselt kirjutatud FreeBSD jaoks ning seda kasutab ka FreeNAS lahendus. Üldiselt soovitatakse tungivalt kasutada võimaluse korral "istgt" tarkvara.
istgt paigaldamine
istgt asub portsude kaustas /usr/ports/net/istgt/
# cp auth.conf.sample auth.conf # cp istgt.conf.sample istgt.conf # cp istgtcontrol.conf.sample istgtcontrol.conf
Istgt.conf (/usr/local/etc/istgt/istgt.conf) on üsna pikk ja paljude võimalustega fail seega tooks välja vaid kõige lihtsamad muudatused mis vajalikud, et jagamine tööle hakkals. Selleks vaikeseadistustesse võiks teha järgnevad muudatused:
Lülitada [UnitControl] autentimine esialgu välja
AuthMethod Auto #AuthMethod CHAP Mutual #AuthGroup AuthGroup10000
Lisada [PortalGroup1] alla enda seadme IP aadressi ja pordi millel tarkvara kuulab
Portal DA1 193.40.0.189:3260
[InitiatorGroup1] lubaks võrgu mis pääseb ligi
InitiatorName "ALL" Netmask 193.40.0.0/24
Ning seadistada seejärels [LogicalUnit1] juures enda block seadme mida jagatakse võrku ning selle suuruse
LUN0 Storage /dev/zvol/srv/iscsi1 Auto
Käivitame serveri
# /usr/local/etc/rc.d/istgt start Starting istgt. istgt version 0.3 (20100707) LU1 HDD UNIT LU1: LUN0 file=/dev/zvol/srv/iscsi1, size=1099511627776 LU1: LUN0 2147483648 blocks, 512 bytes/block LU1: LUN0 1024.0GB storage for iqn.2007-09.jp.ne.peach.istgt:disk1 LU1: LUN0 command queuing disabled
http://wiki.virtastic.com/display/howto/FreeBSD+7.2+with+ZFS+as+an+iSCSI+target
http://people.freebsd.org/~rse/iscsi/iscsi.txt
Iscsi-targeti paigaldamine
# cd /usr/ports/net/iscsi-target/ # make install ===> Installing rc.d startup script(s) ===> Compressing manual pages for iscsi-target-20080207_2 ===> Registering installation for iscsi-target-20080207_2 ===> SECURITY REPORT: This port has installed the following files which may act as network servers and may therefore pose a remote security risk to the system. /usr/local/bin/iscsi-target This port has installed the following startup scripts which may cause these network services to be started at boot time. /usr/local/etc/rc.d/iscsi_target If there are vulnerabilities in these programs there may be a security risk to the system. FreeBSD makes no guarantee about the security of ports included in the Ports Collection. Please type 'make deinstall' to deinstall the port if this is a concern. For more information, and contact details about the security status of this software, see the following webpage: http://www.netbsd.org/
Seejärel jagame välja füüsilise ketta. See on meil küljes seadmena /dev/ad0 suurusega 70GB
Võrk kuhu jagamine on 192.168.0.0/24
/usr/local/etc/iscsi/targets
# NAME DEVICE START LENGTH extent0 /dev/ad0 0 70GB # NAME ACCESS STORAGE NETMASK target0 rw extent0 192.168.0.0/24
et reboodil automaatselt server starditaks Avame /etc/rc.conf ja lisame rea
iscsi_target_enable="YES"
Ja stardime serveri
# /usr/local/etc/rc.d/iscsi_target start Starting iscsi_target. Reading configuration from `/usr/local/etc/iscsi/targets' target0:rw:193.40.0.0/24 extent0:/dev/ad0:0:75161927680 DISK: 1 logical unit (146800640 blocks, 512 bytes/block), type iscsi fs DISK: LUN 0: 71680 MB disk storage for "target0" TARGET: TargetName is iqn.1994-04.org.netbsd.iscsi-target
Meile oluline info on siin nimieks olev qn.1994-04.org.netbsd.iscsi-target seda läheb kliendi juures meil hiljem vaja
Kliendi seadustus FreeBSD10 versioonis
Esiteks peab olema starditud iscsi deemon. Selleks tuleb rc.confi kirjutada
iscsid_enable="YES"
Käsitsi saame deemoni startida käsuga
# service iscsid start
Ühendamiseks
# iscsictl -A -p 10.10.10.10 -t iqn.2012-06.com.example:target0
Kontrollimiseks
# iscsictl Target name Target portal State iqn.2012-06.com.example:target0 10.10.10.10 Connected: da0
Automaatseks külgevõtmiseks tuleb tekitada fail /etc/iscsi.conf järgneva sisuga:
t0 { TargetAddress = 10.10.10.10 initiatorname = iqn.1996-07.ee.test:server1 TargetName = iqn.2012-06.com.example:target0 }
Kui InitiatorName ei ole seadistatud kasutatakse vaikimisi kujul iqn.2005-01.il.ac.huji.cs:<hostname>.
Samuti on vajalik failiõigused paika seadistada.
# chmod 750 /etc/iscsi.conf
Selleks, et konfis defineeritud target ühendada
# iscsictl -An t0
Kõigi konfiguratsioonis defineeritud targetite ühendamiseks
# iscsictl -Aa
Selleks, et startimisel kõik kettad ühendataks tuleb rc.confi lisada
iscsictl_enable="YES" iscsictl_flags="-Aa"
I had put # REQUIRE: mountcritlocal iscsictl in /etc/rc.d/zfs , trying to make zfs start after iscsi, since the zfs
Kliendi seadistus FreeBSD9 ja vanemates versioonides
Laadime seejärel iscsi mooduli mis FreeBSD7'mest alates vaikuimisi juba kaasas
# kldload iscsi_initiator
Boodilt startimiseks
# echo 'iscsi_initiator_load="YES"' >>/boot/loader.conf
Vaatame mis jaotised saadaval on
# iscontrol -v -d targetaddress=10.4.4.1 initiatorname=iqn.2004-04.org.freebsd:initiator-server1
- Targetaddress - iSCSI serveri aadress
- initatorname - kliendi unikaalne nimi (võib kirjutada ka täisnime nt: iqn.2004-04.org.freebsd:initiator-server1).
Kui see pole määratud tekitab bsd automaatselt iqn.2005-01.il.ac.huji.cs:<hostname>
Käsureal jaotise külgevõtmine ühe reaga
# iscontrol -p /run/iscsi-suvakas.pid InitiatorName=iqn.2004-04.org.freebsd:initiator-server1 TargetName=iqn.1994-04.org.netbsd.iscsi-target:target0 TargetAddress=10.4.4.2
dmesgi/message logi peaks ilmuma read
da1 at iscsi0 bus 0 target 0 lun 0 da1: <NetBSD NetBSD iSCSI 0> Fixed Direct Access SCSI-3 device
Boodil iscsi automaatne külgevõtmine. Esimesena on vajalik teha seadistusfail kust ja mida on võimalik külge haakida
/etc/iscsi.conf
target0 { targetaddress = 193.40.0.194 initiatorname = iqn.2004-04.org.freebsd:initiator-server1 targetname = iqn.1994-04.org.netbsd.iscsi-target:target0 }
Selleks ,et automaatselt moodul laaditaks lisame /boot/loader.conf faili rea
iscsi_initiator_load="YES"
Ning haagime seejärel ketta külge
# iscontrol -n target0 # iscontrol[1464]: running iscontrol[1464]: (pass1:iscsi0:0:0:0): tagged openings now 0 iscontrol[1464]: cam_open_btl: no passthrough device found at 1:0:1 iscontrol[1464]: cam_open_btl: no passthrough device found at 1:0:2 iscontrol[1464]: cam_open_btl: no passthrough device found at 1:0:3 iscontrol: supervise starting main loop
Selleks, et boodijärgselt ka kohe õieg viilakas külge haagitaks tekitame järgneva "iscsi" nimelise skripti /usr/local/etc/rc.d alla
#!/bin/sh
# PROVIDE: iscsi
# REQUIRE: NETWORKING
# BEFORE: amd LOGIN
# KEYWORD: shutdown
. /etc/rc.subr
name="iscsi"
rcvar=`set_rcvar`
command="/sbin/iscontrol"
stop_cmd=":"
start_postcmd="zfs_mount"
zfs_mount() {
if checkyesno zfs_enable ; then
sleep 5 # give time for iscsi to setup
zfs mount -a # mount newly available file systems
fi
}
load_rc_config $name
run_rc_command "$1"
Rc.confi kirjutame
iscsi_enable="YES" iscsi_flags="-n target0"
Skript võetud sellelt urlilt http://www.sysadmin-cookbook.net/iscsi/
Teenuste startimisest täpsemalt juttu manuaalis http://www.freebsd.org/doc/handbook/configtuning-starting-services.html
Kasutamine ja katsetamine
Värskelt masinasse ilmunud block devicele uus failisüsteem
# newfs /dev/da1 /dev/da1: 71680.0MB (146800640 sectors) block size 16384, fragment size 2048 using 391 cylinder groups of 183.77MB, 11761 blks, 23552 inodes. super-block backups (for fsck -b #) at: 160, 376512, 752864, 1129216, 1505568, 1881920, 2258272, 2634624, 3010976, 3387328, 3763680, 4140032, 4516384, 4892736, 5269088, 5645440, 6021792, 6398144, 6774496, 7150848, 7527200, 7903552, 8279904, 8656256, 9032608, 9408960, 9785312, 10161664, 10538016, 10914368, 11290720, 11667072, 12043424, 12419776, 12796128, 13172480, 13548832, 13925184, 14301536, 14677888, 15054240, 15430592, 15806944, 16183296, 16559648, 16936000, 17312352, 17688704, 18065056 ...
Seejärel ühendame selle külge /home/net alla
# mount /dev/da1 /home/net/ # df Filesystem 1K-blocks Used Avail Capacity Mounted on ... /dev/da1 71085512 4 65398668 0% /usr/home/net
Ja testime 1.1gigabaidise failiga kirjutuskiirust 100Mb võrgus
# dd if=/dev/zero of=zero-file bs=1024 count=1048576 1048576+0 records in 1048576+0 records out 1073741824 bytes transferred in 117.719325 secs (9121203 bytes/sec)
Jõudlus
FreeBSD süsteemis iSCSI jõudluse suurendamiseks
Vaatame mis vaikeseadistuseks
:~# camcontrol tags /dev/da2 (pass8:iscsi0:0:0:1): device openings: 1
Muudame
:~# camcontrol tags /dev/da2 -N 256 (pass8:iscsi0:0:0:1): tagged openings now 256 (pass8:iscsi0:0:0:1): device openings: 256
Kontrollime kas muutus
:~# camcontrol tags /dev/da2 (pass8:iscsi0:0:0:1): device openings: 256
ZFS volume jagamine
Tegemist siis LVMi analoogiaga FreeBSD jaoks. Toimub sarnasent nagu tavalise kettagagi. Tekitame näiteks terabaidi suuruse zfs volume
# zfs create -V 1024g tank/iscsi
Vaatame zfs loendit
# zfs list NAME USED AVAIL REFER MOUNTPOINT tank 1.00T 1.56T 28.8K /tank tank/iscsi 1T 2.56T 25.6K -
Fail tekib ise /dev/zvol/ kausta
Antud juhul on selleks
/dev/zvol/tank/iscsi
Mille võib jagada kas istg või iscsi-target abil välja jagada kasutades eelnevaid juhendeid. Hetkel kahjuks ZFSi enda iSCSI jagamise käsk ei toimi kuna FreeBSD ei sisalda iSCSI targetit vaikimisi.
Multipath FreeBSD peal
cat /boot/loader.conf geom_multipath_load="YES"
Esimesest allikast ketas külge
da2 at iscsi0 bus 0 scbus7 target 0 lun 1 da2: <HP HSV360 0005> Fixed Direct Access SCSI-5 device da2: 33554432MB (68719476736 512 byte sectors: 255H 63S/T 4277589C)
Teisest allikast ketas külge
da3 at iscsi1 bus 0 scbus8 target 0 lun 1 da3: <HP HSV360 0005> Fixed Direct Access SCSI-5 device da3: 33554432MB (68719476736 512 byte sectors: 255H 63S/T 4277589C)
Kahe allika põhjal ühe blokkseadme loomine
# gmultipath create -A HPHSV360 /dev/da2 /dev/da3 GEOM_MULTIPATH: HPHSV360 created GEOM_MULTIPATH: da2 added to HPHSV360 GEOM_MULTIPATH: da3 added to HPHSV360
Zfsi külge haakimine
# zpool import -d /dev/multipath zp1 :~> zpool status pool: zp1 state: ONLINE scan: none requested config: NAME STATE READ WRITE CKSUM zp1 ONLINE 0 0 0 multipath/HPHSV360 ONLINE 0 0 0
http://www.freebsd.org/cgi/man.cgi?query=gmultipath&sektion=8&manpath=FreeBSD+9.1-RELEASE