s3fs ceph-s3 /mnt/ceph -o sigv2 -o use_path_request_style -o passwd_file=/etc/passwd-s3fs -o url=http://s3.biliops.com
/var/log/radosgw/radosgw-node-6.log
http-403:7fe690eba7c0 0 ceph version 9.2.0 (bb2ecea240f3a1d525bcb35670cb07bd1f0ca299), process radosgw, pid 2332333 7fe690eba7c0 0 framework: civetweb 7fe690eba7c0 0 framework conf key: port, val: 2333 7fe690eba7c0 0 starting handler: civetweb 7fe60adfb700 1 civetweb: 0x7fe5f80008c0: 192.168.168.168 - - [14/Jan/2016:23:22:33 +0800] "HEAD /ceph-s3/name HTTP/1.0" 404 0 - - 7fe609df9700 1 civetweb: 0x7fe5ec0008c0: 192.168.168.168 - - [14/Jan/2016:23:22:33 +0800] "HEAD /ceph-s3/name/ HTTP/1.0" 404 0 - - 7fe60a5fa700 1 civetweb: 0x7fe5f00008c0: 192.168.168.168 - - [14/Jan/2016:23:22:33 +0800] "HEAD /ceph-s3/name_$folder$ HTTP/1.0" 403 0 - -
civetweb
提供的服務前加了一層Nginx。civetweb
節點。/etc/ceph/ceph.conf
:[client.rgw.node-6] host = node-6 keyring = /var/lib/ceph/radosgw/ceph-rgw.node-6/keyring rgw socket path = /tmp/radosgw-node-6.sock log file = /var/log/radosgw/radosgw-node-6.log rgw data = /var/lib/ceph/radosgw/ceph-rgw.node-6 rgw print continue = false rgw frontends = civetweb port=2333
civetweb
卻能正常使用s3fs ceph-s3 /mnt/ceph -o sigv2 -o use_path_request_style -o passwd_file=/etc/passwd-s3fs -o url=http://node-6.biliops.com:2333
tcpflow
抓包,對比 Nginx 代理先後請求內容的區別,發現:HEAD /ceph-s3/name_%24folder%24
;HEAD /ceph-s3/name_$folder$
。/etc/nginx/sites-enabled/01-proxypass.biliops.com
,關鍵部分:server { listen 80 backlog=65535; server_name proxypass.biliops.com; location / { proxy_ignore_client_abort on; proxy_set_header Host echo.biliops.com; proxy_redirect off; proxy_http_version 1.1; proxy_set_header Connection "keep-alive"; proxy_pass $schema://127.0.0.1:80/; } } server { listen 80; server_name echo.biliops.com; location / { add_header request $request; } }
s3fs
的請求 curl -I proxypass.biliops.com/name_%24folder%24
;proxy_pass http://127.0.0.1:80/;
時,訪問結果是:request: HEAD /name_$folder$ HTTP/1.1node
proxy_pass http://127.0.0.1:80$1;
時,訪問結果是:request: HEAD /name_%24folder%24 HTTP/1.1nginx
/
和 $1
的區別明白後,按需使用便可。uri
,則使用$1
來轉發。/
全全代理。