Baca dan tulis pemisahan nginx
1. Topologi eksperimen
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; } } }
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: [确定]
5
Nota, hanya dayakannya di bawah
6. Mulakan semula httpd
[root@web1 ~]# vim /etc/httpd/conf/httpd.conf
7 Ujian
[root@web1 ~]# service httpd restart 停止 httpd: [确定] 正在启动 httpd: [确定]
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>
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>
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'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>
Mari kita uji sekali lagi,
[root@web1 ~]# setfacl -m u:apache:rwx /var/www/html/
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>
[root@web1 ~]# cd /var/www/html/ [root@web1 html]# ll
Atas ialah kandungan terperinci Bagaimana untuk mengkonfigurasi pemisahan baca-tulis nginx. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!