OpenStack Antelope : Swift कॉन्फ़िगर करें (भंडारण नोड)2023/09/08 |
OpenStack ऑब्जेक्ट स्टोरेज (Swift) कॉन्फ़िगर करें।
यह उदाहरण निम्न प्रकार से पर्यावरण पर आधारित है।
------------+--------------------------+------------ | | eth0|10.0.0.30 eth0|10.0.0.50 +-----------+-----------+ +-----------+-----------+ | [ dlp.srv.world ] | | [ network.srv.world ] | | (Control Node) | | (Proxy Node) | | | | | | MariaDB RabbitMQ | | Swift Proxy | | Memcached Nginx | | Nginx | | Keystone httpd | | | +-----------------------+ +-----------------------+ ------------+--------------------------+--------------------------+----------- eth0|10.0.0.71 eth0|10.0.0.72 eth0|10.0.0.73 +-----------+-----------+ +-----------+-----------+ +-----------+-----------+ | [snode01.srv.world] | | [snode02.srv.world] | | [snode03.srv.world] | | (Storage Node#1) | | (Storage Node#2) | | (Storage Node#3) | | | | | | | | Swift-Account | | Swift-Account | | Swift-Account | | Swift-Container | | Swift-Container | | Swift-Container | | Swift-Object | | Swift-Object | | Swift-Object | +-----------------------+ +-----------------------+ +-----------------------+ |
इस अनुभाग पर स्टोरेज नोड कॉन्फ़िगर करें।
अधिकांशतः सभी स्टोरेज नोड्स पर समान सेटिंग्स सेट करना ठीक है, लेकिन केवल आईपी एड्रेस एक-दूसरे से भिन्न होते हैं। भंडारण विभाजन के लिए, नए विभाजन बनाने के लिए डिस्क पर पर्याप्त आकार के खाली क्षेत्र की आवश्यकता होती है। |
|
[1] | सभी संग्रहण नोड्स पर, सबसे पहले OpenStack Antelope रिपॉजिटरी को यहां कॉन्फ़िगर करें [3] और निम्नानुसार सभी स्टोरेज नोड पर Swift-Account, Swift-Container, Swift-Object और अन्य इंस्टॉल करें। |
root@snode01:~# apt -y install swift swift-account swift-container swift-object xfsprogs
|
[2] | डिस्क के खाली स्थान ([/dev/sdb1] इस उदाहरण पर) को XFS के साथ प्रारूपित करें और निम्नानुसार सभी स्टोरेज नोड पर [/srv/node/device] पर माउंट करें। |
root@snode01:~# mkfs.xfs /dev/sdb1 meta-data=/dev/sdb1 isize=512 agcount=4, agsize=5242816 blks = sectsz=512 attr=2, projid32bit=1 = crc=1 finobt=1, sparse=1, rmapbt=0 = reflink=1 bigtime=0 inobtcount=0 data = bsize=4096 blocks=20971264, imaxpct=25 = sunit=0 swidth=0 blks naming =version 2 bsize=4096 ascii-ci=0, ftype=1 log =internal log bsize=4096 blocks=10239, version=2 = sectsz=512 sunit=0 blks, lazy-count=1 realtime =none extsz=4096 blocks=0, rtextents=0 Discarding blocks...Done.
root@snode01:~#
mkdir -p /srv/node/device root@snode01:~# mount -o noatime,nodiratime /dev/sdb1 /srv/node/device root@snode01:~# chown -R swift. /srv/node
root@snode01:~#
blkid | grep sdb1 /dev/sdb1: UUID="3a8490e2-2c5f-42eb-b688-fe0c21ad3206" BLOCK_SIZE="512" TYPE="xfs" PARTUUID="bc0f8b5e-01" root@snode01:~# vi /etc/fstab # अंत में जोड़ें /dev/disk/by-uuid/3a8490e2-2c5f-42eb-b688-fe0c21ad3206 /srv/node/device xfs defaults,noatime,nodiratime 0 0 |
[3] | Swift प्रॉक्सी नोड से Swift रिंग फ़ाइलों को सभी स्टोरेज नोड्स में कॉपी करें। |
root@network:~# scp /etc/swift/*.gz 10.0.0.71:/etc/swift/ account.ring.gz 100% 3912 3.8KB/s 00:00 container.ring.gz 100% 3904 3.8KB/s 00:00 object.ring.gz 100% 3895 3.8KB/s 00:00 |
[4] | सभी स्टोरेज नोड्स पर Swift और Rsync कॉन्फ़िगर करें। |
root@snode01:~# chown swift. /etc/swift/*.gz
root@snode01:~#
vi /etc/swift/swift.conf # वह मान सेट करें जो प्रॉक्सी नोड पर सेट है [swift-hash] swift_hash_path_suffix = swift_shared_path swift_hash_path_prefix = swift_shared_path
root@snode01:~#
vi /etc/swift/account-server.conf # पंक्ति 2 : निम्नानुसार सेटिंग्स की पुष्टि करें bind_ip = 0.0.0.0 bind_port = 6002
root@snode01:~#
vi /etc/swift/container-server.conf # पंक्ति 2 : निम्नानुसार सेटिंग्स की पुष्टि करें bind_ip = 0.0.0.0 bind_port = 6001
root@snode01:~#
vi /etc/swift/object-server.conf # पंक्ति 2 : निम्नानुसार सेटिंग्स की पुष्टि करें bind_ip = 0.0.0.0 bind_port = 6000
root@snode01:~#
vi /etc/rsyncd.conf # नया निर्माण
pid file = /var/run/rsyncd.pid
log file = /var/log/rsyncd.log
uid = swift
gid = swift
# प्रत्येक संग्रहण नोड का आईपी पता निर्दिष्ट करें
address = 10.0.0.71
[account]
path = /srv/node
read only = false
write only = no
list = yes
incoming chmod = 0644
outgoing chmod = 0644
max connections = 25
lock file = /var/lock/account.lock
[container]
path = /srv/node
read only = false
write only = no
list = yes
incoming chmod = 0644
outgoing chmod = 0644
max connections = 25
lock file = /var/lock/container.lock
[object]
path = /srv/node
read only = false
write only = no
list = yes
incoming chmod = 0644
outgoing chmod = 0644
max connections = 25
lock file = /var/lock/object.lock
[swift_server]
path = /etc/swift
read only = true
write only = no
list = yes
incoming chmod = 0644
outgoing chmod = 0644
max connections = 5
lock file = /var/lock/swift_server.lock
root@snode01:~#
vi /etc/default/rsync # पंक्ति 14: परिवर्तन RSYNC_ENABLE= true
|
[5] | Swift सेवाएँ प्रारंभ करें। |
root@snode01:~# systemctl restart rsync swift-account-auditor \
root@snode01:~# swift-account-replicator \ swift-account \ swift-container-auditor \ swift-container-replicator \ swift-container-updater \ swift-container \ swift-object-auditor \ swift-object-replicator \ swift-object-updater \ swift-object systemctl enable rsync swift-account-auditor \
swift-account-replicator \ swift-account \ swift-container-auditor \ swift-container-replicator \ swift-container-updater \ swift-container \ swift-object-auditor \ swift-object-replicator \ swift-object-updater \ swift-object |
Sponsored Link |
|