在生產環境中使用時,務必先經過測試環境測試,測試通過后再上生產環境避免造成生產事故,若配置不當,可能引發性能、安全或邏輯等問題甚至造成生產事故?? 背景:存儲告急由于每個文件都提供了url地址鏈接,將文件遷移走肯定是不行的,如何擴容且不中斷服務?
隨著業務快速增長,我們的文件存儲服務器 /home/data/files2
磁盤使用率已飆升至 95%,觸發了嚴重預警,準備擴容
核心需求:
- ? 新增一塊4TB硬盤掛載至
/data2/app/files2
- ? 文件無論放在哪里原有訪問URL不能變(如
http://a.域名.com/files2/a.txt
)
?? 方案:Nginx智能路由實現無縫擴容
我們采用 主備式多路徑存儲架構,利用Nginx的 try_files
和命名location功能,實現:“先查舊盤,找不到自動查新盤,用戶端完全無感”
使用技術 nginx命名location
示例
location @name { ... }
官方文檔原文是這樣解釋的:The “@” prefix defines a named
location. Such a location is not used for a regular
request processing, but instead used for request redirection.
They cannot be nested, and cannot contain nested locations.
大概意思:“@”前綴定義了一個命名位置。這樣的位置不用于常規請求處理,而是用于請求重定向。它們不能嵌套,也不能包含嵌套位置。
? 實現目標架構流程圖
??? 實戰配置:
新增一塊盤的情況
nginx
server { listen 80;
server_name a.域名.com;
location ~* ^/files2/ {alias /home/data/files2/;
try_files $uri @newfile_storage;
}
location @newfile_storage {
alias /data2/app/files2/;
try_files $uri =404;
}
}
新增多塊盤的情況
nginx
location ~*^/files2/ {
root /home/data;
try_files $uri $uri/@filestorage1;
}
location @filestorage1 {
alias /data2/app/files2/1/;
try_files $uri $uri/@filestorage2;
}
location @filestorage2 {
alias /data2/app/files2/2/;
try_files $uri $uri/@filestorage3;
}
location @filestorage3 {
alias /data3/app/files3/;
try_files $uri $uri /=404;
}
?? 配置解析:
1. 主入口location
nginx
location ~* ^/files2/ {
alias /home/data/files2/;
try_files $uri @newfile_storage;
}
~* ^/files2/:不區分大小寫匹配/files2/路徑
alias:映射到物理路徑
try_files:優先查找主存儲,找不到則跳轉命名位置徑@
newfile_storage
2. 命名location(新存儲)
ngin
location @newfile_storage {
alias /data2/app/files2/;
try_files $uri =404;
}
@newfile_storage:內部標記,外部無法直接訪問
=404:最終未找到返回404
# 重新加載配置
# 遷移后驗證
mv 2023-01-video.png /data2/app/files2/
curl -I http://a.domain.com/files2/2023-01-video.png
方案優勢總結
| |
---|
零代碼改動 | |
URL永久有效 | |
客戶端無感知 | |
易擴展 | |
安全可控 | |
結語
存儲擴容不應成為業務瓶頸。通過Nginx的 try_files
+ named location
機制,實現了:“程序不改、URL不變、遷移無感、擴展靈活”
適合系統做低成本、高可用的存儲橫向擴容。
閱讀原文:原文鏈接
該文章在 2025/8/15 12:10:47 編輯過