2024-07-12
한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina
आधिकारिक दस्तावेजीकरणम् : १.https://min.io/docs/minio/linux/operations/install-deploy-manage/deploy-minio-बहु-नोड-बहु-ड्राइव.html
एतत् समाधानं बहु-नोड् बहु-चालक (MNMD) अथवा "वितरित" विन्यासे नियोजितस्य MinIO इत्यस्य उपयोगं करोति । MNMD परिनियोजनानि उद्यम-श्रेणीप्रदर्शनं, उपलब्धतां, मापनीयतां च प्रदास्यन्ति तथा च सर्वेषां उत्पादनकार्यभारानाम् अनुशंसितं टोपोलॉजी अस्ति ।
MNMD परिनियोजनानि मेटानसङ्केतनविन्यासानां समर्थनं कुर्वन्ति ये परिनियोजने नोड्स् अथवा ड्राइव्स् इत्यस्य आर्धपर्यन्तं हानिम् सहितुं शक्नुवन्ति, यदा पठनसञ्चालनानां सेवां निरन्तरं कुर्वन्ति
क्लस्टर परिनियोजनस्य आवश्यकताः
नोड् योजना तथा डिस्क योजना निम्नलिखितरूपेण भवति प्रत्येकं नोड् चत्वारि डिस्कं सज्जीकरोति ।
नोड नाम | नोड IP | लघु डिस्क | माउण्ट बिन्दु | प्रचालन प्रणाली |
---|---|---|---|---|
minio1.उदाहरण.com | 192.168.72.51 | / देव / एसडीबी / देव / एसडीसी / देव / एसडीडी / देव / एसडीई | / वर / लिब / मिनिओ / डेटा1 / वर / लिब / मिनिओ / डेटा 2 / वर / लिब / मिनिओ / डेटा3 / वर / लिब / मिनिओ / डेटा4 | उबंतु२२.०४ |
minio2.उदाहरण.com | 192.168.72.52 | / देव / एसडीबी / देव / एसडीसी / देव / एसडीडी / देव / एसडीई | / वर / लिब / मिनिओ / डेटा1 / वर / लिब / मिनिओ / डेटा 2 / वर / लिब / मिनिओ / डेटा3 / वर / लिब / मिनिओ / डेटा4 | उबंतु२२.०४ |
minio3.उदाहरण.com | 192.168.72.53 | / देव / एसडीबी / देव / एसडीसी / देव / एसडीडी / देव / एसडीई | / वर / लिब / मिनिओ / डेटा1 / वर / लिब / मिनिओ / डेटा 2 / वर / लिब / मिनिओ / डेटा3 / वर / लिब / मिनिओ / डेटा4 | उबंतु२२.०४ |
minio4.उदाहरण.com | 192.168.72.54 | / देव / एसडीबी / देव / एसडीसी / देव / एसडीडी / देव / एसडीई | / वर / लिब / मिनिओ / डेटा1 / वर / लिब / मिनिओ / डेटा 2 / वर / लिब / मिनिओ / डेटा3 / वर / लिब / मिनिओ / डेटा4 | उबंतु२२.०४ |
lb1.उदाहरण.com | 192.168.72.55 | - | - | उबंतु२२.०४ |
lb2.उदाहरण.com | 192.168.72.56 | - | - | उबंतु२२.०४ |
वि.आइ.पी | 192.168.72.100 | - | - | - |
विवरणम्: VIP-सङ्केतः समाधानं करोतिminio.example.com
डोमेननाम एकीकृतप्रवेशद्वाररूपेण कार्यं करोति ।
http://minio.example.com
http://minio.example.com/minio/ui
क्लस्टर-वास्तुकला यथा अस्ति ।
सर्वे लघुनोड्स् क्रमशः होस्ट्-नामभिः सह विन्यस्ताः भवन्ति ।
hostnamectl set-hostname minio1.example.com
hostnamectl set-hostname minio2.example.com
hostnamectl set-hostname minio3.example.com
hostnamectl set-hostname minio4.example.com
सर्वे लघुनोड्स् पृथक् पृथक् होस्ट्स् रिजोल्यूशन इत्यनेन विन्यस्ताः भवन्ति ।
cat >/etc/hosts<<EOF
192.168.72.51 minio1.example.com
192.168.72.52 minio2.example.com
192.168.72.53 minio3.example.com
192.168.72.54 minio4.example.com
EOF
सर्वे लघुनोड् विन्याससमयाः समन्वयिताः भवन्ति ।
लघु बहु-नोड् प्रणाली स्थिरं अन्तर-नोड् संचालनं अन्तरक्रियां च निर्वाहयितुम् समयं तिथिं च समन्वयितं स्थापयितव्यम् ।
apt install -y chrony
systemctl enable --now chrony
timedatectl set-timezone Asia/Shanghai
प्रत्येकं नोड् ४ डिस्कं माउण्ट् करोति, येषु sda सिस्टम् डिस्कः अस्ति:
root@minio1:~# lsblk -d -n -o NAME | grep '^sd'
sda
sdb
sdc
sdd
sde
प्रत्येकं नोड् मध्ये चत्वारि ड्राइव्स् माउण्ट् कर्तुं चत्वारि निर्देशिकाः रचयन्तु ।
sudo mkdir -p /var/lib/minio/data1
sudo mkdir -p /var/lib/minio/data2
sudo mkdir -p /var/lib/minio/data3
sudo mkdir -p /var/lib/minio/data4
प्रत्येकं नोड् पृथक् पृथक्, डिस्कं XFS सञ्चिकातन्त्रे स्वरूपयन्तु:
sudo mkfs.xfs /dev/sdb -L DISK1
sudo mkfs.xfs /dev/sdc -L DISK2
sudo mkfs.xfs /dev/sdd -L DISK3
sudo mkfs.xfs /dev/sde -L DISK4
स्वचालितं माउण्टिङ्ग् विन्यस्यताम्
cat >>/etc/fstab<<EOF
LABEL=DISK1 /var/lib/minio/data1 xfs defaults,noatime 0 2
LABEL=DISK2 /var/lib/minio/data2 xfs defaults,noatime 0 2
LABEL=DISK3 /var/lib/minio/data3 xfs defaults,noatime 0 2
LABEL=DISK4 /var/lib/minio/data4 xfs defaults,noatime 0 2
EOF
mount all in /etc/fstab
सञ्चिकातन्त्रं सञ्चिकायां परिभाषितं किन्तु अद्यापि माउण्ट् न कृतम्
sudo mount -av
सञ्चिकातन्त्रं सम्यक् माउण्ट् कृतम् इति पुष्टिं कुर्वन्तु
root@minio1:~# df -hT
......
/dev/sdb xfs 100G 746M 100G 1% /var/lib/minio/data1
/dev/sdc xfs 100G 746M 100G 1% /var/lib/minio/data2
/dev/sdd xfs 100G 746M 100G 1% /var/lib/minio/data3
/dev/sde xfs 100G 746M 100G 1% /var/lib/minio/data4
प्रत्येकस्मिन् नोड् मध्ये पृथक् पृथक् deb संकुलस्य उपयोगेन MinIO संस्थापयन्तु
wget https://dl.min.io/server/minio/release/linux-amd64/archive/minio_20240704142545.0.0_amd64.deb -O minio.deb
sudo dpkg -i minio.deb
उपयुञ्जताम् groupadd
तथाuseradd
उपयोक्तृणां समूहानां च निर्माणार्थं आदेशाः
groupadd -r minio-user
useradd -M -r -g minio-user minio-user
chown -R minio-user:minio-user /var/lib/minio
अस्ति /etc/default/minio
वातावरणसञ्चिकाः रचयन्तु। MinIO सेवा एतां सञ्चिकां MinIO इति रूपेण उपयुङ्क्ते तथा च...minio.service
सञ्चिकायाः उपयोगितानां सर्वेषां वातावरणचरानाम् स्रोतः ।
cat >/etc/default/minio<<EOF
MINIO_VOLUMES="http://minio{1...4}.example.com:9000/var/lib/minio/data{1...4}/minio"
MINIO_OPTS="--console-address :9001"
MINIO_ROOT_USER=minioadmin
MINIO_ROOT_PASSWORD=Minio@123456
MINIO_BROWSER_REDIRECT_URL="http://minio.example.com/minio/ui"
EOF
MinIO सेवां आरभ्य परिनियोजने प्रत्येकस्मिन् नोड् इत्यत्र निम्नलिखितम् आदेशं निर्गच्छतु ।
sudo systemctl restart minio.service
सेवा ऑनलाइन अस्ति इति निम्नलिखित आदेशस्य उपयोगेन सम्यक् चालयति इति पुष्टिं कुर्वन्तु:
sudo systemctl status minio.service
journalctl -f -u minio.service
ब्राउजर् उद्घाट्य पोर्ट् अभिगन्तु :9001
MinIO कन्सोल् प्रवेशपृष्ठं उद्घाटयितुं कोऽपि MinIO होस्ट्नाम ।उदाहरणतया
http://minio1.example.com:9001
प्रयोगं कुर्वन्तु minio_root_user
तथाminio_root_password
प्रवेशं कुर्वन्तु।
परिचय-प्रवेश-प्रबन्धनम्, मेट्रिक-लॉग्-निरीक्षणम्, अथवा सर्वर-विन्यासम् इत्यादीनां सामान्यप्रबन्धनकार्यं कर्तुं भवान् MinIO-कन्सोल्-इत्यस्य उपयोगं कर्तुं शक्नोति । प्रत्येकं MinIO सर्वरे स्वकीयं एम्बेडेड् MinIO कन्सोल् भवति ।
आधिकारिक दस्तावेजीकरणम् : १.https://min.io/docs/minio/linux/integrations/setup-nginx-proxy-with-minio.html इति
उपयुञ्जताम्nginx
तथाkeepalived
भारसन्तुलनं प्राप्तुं 2 सर्वरं भारसंतुलननोड्रूपेण सज्जीकरोतु ।
क्रमशः lb नोड् इत्यत्र होस्ट् नाम विन्यस्यताम् ।
hostnamectl set-hostname lb1.example.com
hostnamectl set-hostname lb2.example.com
क्रमशः lb नोड् इत्यत्र होस्ट्स् रिजोल्यूशनं विन्यस्यताम् ।
cat >/etc/hosts<<EOF
192.168.72.55 lb1.example.com
192.168.72.56 lb2.example.com
192.168.72.51 minio1.example.com
192.168.72.52 minio2.example.com
192.168.72.53 minio3.example.com
192.168.72.54 minio4.example.com
EOF
nginx तथा keepalived 2 नोड्स इत्यत्र संस्थापयन्तु:
apt install -y nginx keepalived
nginx विन्याससञ्चिकां रचयन्तु, सर्वर-सङ्केतं परिवर्तयन्तु तथा च listen पोर्ट् अनुकूलितं कुर्वन्तु, परिवर्तनेषु ध्यानं ददतुserver_name
पैरामीटर् : १.
cat > /etc/nginx/conf.d/minio-lb.conf <<'EOF'
upstream minio_s3 {
least_conn;
server minio1.example.com:9000;
server minio2.example.com:9000;
server minio3.example.com:9000;
server minio4.example.com:9000;
}
upstream minio_console {
least_conn;
server minio1.example.com:9001;
server minio2.example.com:9001;
server minio3.example.com:9001;
server minio4.example.com:9001;
}
server {
listen 80;
listen [::]:80;
server_name minio.example.com;
# Allow special characters in headers
ignore_invalid_headers off;
# Allow any size file to be uploaded.
# Set to a value such as 1000m; to restrict file size to a specific value
client_max_body_size 0;
# Disable buffering
proxy_buffering off;
proxy_request_buffering off;
location / {
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_connect_timeout 300;
# Default is HTTP/1, keepalive is only enabled in HTTP/1.1
proxy_http_version 1.1;
proxy_set_header Connection "";
chunked_transfer_encoding off;
proxy_pass https://minio_s3; # This uses the upstream directive definition to load balance
}
location /minio/ui/ {
rewrite ^/minio/ui/(.*) /$1 break;
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
proxy_set_header X-NginX-Proxy true;
# This is necessary to pass the correct IP to be hashed
real_ip_header X-Real-IP;
proxy_connect_timeout 300;
# To support websockets in MinIO versions released after January 2023
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
# Some environments may encounter CORS errors (Kubernetes + Nginx Ingress)
# Uncomment the following line to set the Origin request to an empty string
# proxy_set_header Origin '';
chunked_transfer_encoding off;
proxy_pass https://minio_console; # This uses the upstream directive definition to load balance
}
}
EOF
nginx सेवा आरभत
systemctl restart nginx
keepalived configuration file रचयित्वा वास्तविकवातावरणानुसारं परिवर्तयन्तुinterface
तथाvirtual_ipaddress
पैरामीटर्स्, द्वयोः नोड्योः समानं विन्यासः भवति:
cat > /etc/keepalived/keepalived.conf <<EOF
! Configuration File for keepalived
global_defs {
router_id minio
vrrp_version 2
vrrp_garp_master_delay 1
script_user root
enable_script_security
}
vrrp_script chk_nginx {
script "/usr/bin/killall -0 nginx"
timeout 3
interval 3 # check every 1 second
fall 2 # require 2 failures for KO
rise 2 # require 2 successes for OK
}
vrrp_instance lb-minio {
state BACKUP
interface ens33
virtual_router_id 51
priority 100
advert_int 1
nopreempt
authentication {
auth_type PASS
auth_pass 1111
}
virtual_ipaddress {
192.168.72.100
}
track_script {
chk_nginx
}
}
EOF
keepalvied सेवा आरभत
systemctl restart keepalived
उत्पन्नं VIP-सङ्केतं पश्यन्तु
root@lb1:~# ip a
1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
inet 127.0.0.1/8 scope host lo
valid_lft forever preferred_lft forever
inet6 ::1/128 scope host
valid_lft forever preferred_lft forever
2: ens33: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc mq state UP group default qlen 1000
link/ether 00:50:56:9a:92:75 brd ff:ff:ff:ff:ff:ff
altname enp2s1
inet 192.168.72.55/24 brd 192.168.72.255 scope global ens33
valid_lft forever preferred_lft forever
inet 192.168.72.100/32 scope global ens33
valid_lft forever preferred_lft forever
inet6 fe80::250:56ff:fe9a:9275/64 scope link
valid_lft forever preferred_lft forever
यस्मिन् यन्त्रे minio अभिगन्तुं आवश्यकं तस्मिन् hosts resolution विन्यस्यताम्
echo "192.168.72.100 minio.example.com" >>/etc/hosts
ब्राउज़र अभिगम लघु कन्सोल
http://minio.example.com/minio/ui/
मेट्रिक्स सूचनां पश्यन्तु:
कस्मिन् अपि यन्त्रे minio client संस्थापयन्तु
wget https://dl.min.io/client/mc/release/linux-amd64/mc
chmod +x mc
mv mc /usr/local/bin/
लघु क्लायन्ट् विन्यस्तं कुर्वन्तु
mc alias set myminio http://minio.example.com minioadmin Minio@123456
एपिआइ-अन्तरफलकस्य माध्यमेन क्लस्टर-स्थितिं पश्यन्तु
root@ubuntu:~# mc admin info myminio
● minio1.example.com:9000
Uptime: 25 minutes
Version: 2024-07-04T14:25:45Z
Network: 4/4 OK
Drives: 4/4 OK
Pool: 1
● minio2.example.com:9000
Uptime: 25 minutes
Version: 2024-07-04T14:25:45Z
Network: 4/4 OK
Drives: 4/4 OK
Pool: 1
● minio3.example.com:9000
Uptime: 25 minutes
Version: 2024-07-04T14:25:45Z
Network: 4/4 OK
Drives: 4/4 OK
Pool: 1
● minio4.example.com:9000
Uptime: 25 minutes
Version: 2024-07-04T14:25:45Z
Network: 4/4 OK
Drives: 4/4 OK
Pool: 1
Pools:
1st, Erasure sets: 1, Drives per erasure set: 16
16 drives online, 0 drives offline
root@ubuntu:~#
refer to : १.https://elma365.com/en/help/minio-cluster.html इति ग्रन्थः