Bagaimana untuk mengkonfigurasi pemisahan baca-tulis nginx

WBOY
Lepaskan: 2023-05-18 15:19:57
ke hadapan
1452 orang telah melayarinya

Baca dan tulis pemisahan nginx

1. Topologi eksperimen

Bagaimana untuk mengkonfigurasi pemisahan baca-tulis nginx

Analisis keperluan, bahagian hadapan selesai. oleh nginx Load balancing reverse proxy, dua pelayan httpd di belakang. Keseluruhan seni bina adalah untuk menyediakan perkhidmatan bbs (forum) Terdapat keperluan untuk mencapai pemisahan membaca dan menulis, iaitu fungsi memuat naik lampiran yang kami muat naik hanya boleh dimuat naik ke web1, dan kemudian rsync+inotify digunakan untuk menyegerakkan lampiran pada web1 Semua orang tahu rsync +inotify hanya boleh menyegerakkan daripada master ke slave, bukan penyegerakan dua arah. Oleh itu, web1 boleh melakukan operasi tulis, manakala web2 hanya boleh melakukan operasi baca, yang membawa keperluan untuk pengasingan membaca dan menulis. Mari kita bercakap tentang cara mencapai pemisahan membaca dan menulis.

Penerangan fungsi 2.webdav

webdav (pengarangan dan versi diedarkan berasaskan web) ialah protokol komunikasi berdasarkan protokol http 1.1. Ia memanjangkan http 1.1 dan menambah beberapa kaedah baharu sebagai tambahan kepada beberapa kaedah standard http seperti get, post, dan head, supaya aplikasi boleh terus membaca dan menulis ke pelayan web, dan menyokong menulis mengunci dan membuka kunci ), dan boleh juga menyokong kawalan versi fail. Dengan cara ini, kita boleh mengkonfigurasi fungsi pemisahan baca-tulis Mari kita konfigurasikannya secara terperinci.

3. Ubah suai fail konfigurasi

[root@nginx nginx]# vim /etc/nginx/nginx.conf
server {
    listen    80;
    server_name localhost;
    #charset koi8-r;
    #access_log logs/host.access.log main;
    location / {
        proxy_pass http://192.168.18.202;
        if ($request_method = "put"){
            proxy_pass http://192.168.18.201;
        }
    }
}
Salin selepas log masuk

4 Muat semula fail konfigurasi

[root@nginx ~]# service nginx reload
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
重新载入 nginx:                      [确定]
Salin selepas log masuk

5

Bagaimana untuk mengkonfigurasi pemisahan baca-tulis nginxNota, hanya dayakannya di bawah .


6. Mulakan semula httpd

[root@web1 ~]# vim /etc/httpd/conf/httpd.conf
Salin selepas log masuk

7 Ujian

[root@web1 ~]# service httpd restart
停止 httpd:                        [确定]
正在启动 httpd:                      [确定]
Salin selepas log masuk

Perhatian, tiada masalah untuk mengakses web1 dan web2.

[root@nginx ~]# curl http://192.168.18.201
<h1>web1.test.com</h1>
[root@nginx ~]# curl http://192.168.18.202
<h1>web2.test.com</h1>
Salin selepas log masuk

Perhatikan, apabila kita memuat naik fail ke web2, kerana web2 hanya mempunyai fungsi yang boleh dibaca oleh manusia, tiada fungsi pembukaan akaun webdav, jadi paparan adalah kaedah 405 tidak dibenarkan.

[root@nginx ~]# curl -t /etc/issue http://192.168.18.202
<!doctype html public "-//ietf//dtd html 2.0//en">
<html><head>
<title>405 method not allowed</title>
</head><body>
<h1>method not allowed</h1>
the requested method put is not allowed for the url /issue.
<hr>
<address>apache/2.2.15 (centos) server at 192.168.18.202 port 80</address>
</body></html>
Salin selepas log masuk

Perhatikan, kami telah mendayakan fungsi webdav dalam web1, tetapi direktori kami ialah direktori akar dan pengguna apache tidak dibenarkan memuat naik, jadi 403 dilarang dipaparkan. Seterusnya kami membenarkan apache untuk membenarkan muat naik.

[root@nginx ~]# curl -t /etc/issue http://192.168.18.201
<!doctype html public "-//ietf//dtd html 2.0//en">
<html><head>
<title>403 forbidden</title>
</head><body>
<h1>forbidden</h1>
you don&#39;t have permission to access /issue
on this server.
<hr>
<address>apache/2.2.15 (centos) server at 192.168.18.201 port 80</address>
</body></html>
Salin selepas log masuk

Mari kita uji sekali lagi,

[root@web1 ~]# setfacl -m u:apache:rwx /var/www/html/
Salin selepas log masuk

Perhatikan, anda dapat melihat bahawa kami berjaya memuat naik fail, menunjukkan bahawa fungsi pemisahan baca-tulis nginx dikonfigurasikan. Akhir sekali, mari kita lihat fail yang dimuat naik.

[root@nginx ~]# curl -t /etc/issue http://192.168.18.201
<!doctype html public "-//ietf//dtd html 2.0//en">
<html><head>
<title>201 created</title>
</head><body>
<h1>created</h1>
resource /issue has been created.
<hr />
<address>apache/2.2.15 (centos) server at 192.168.18.201 port 80</address>
</body></html>
Salin selepas log masuk

Jumlah dos 12

[root@web1 ~]# cd /var/www/html/
[root@web1 html]# ll
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimana untuk mengkonfigurasi pemisahan baca-tulis nginx. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:yisu.com
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan