SeaweedFS在.net core下的实践方案
一直對(duì)分布式的文件儲(chǔ)存系統(tǒng)很感興趣,最開(kāi)始關(guān)注淘寶的TFS(Taobao File System),好像擱淺了,官方地址無(wú)法訪(fǎng)問(wèn),github上面,各種編譯問(wèn)題,無(wú)意間發(fā)現(xiàn)了SeaweedFS
鏈接seaweedfs
測(cè)試了一番,寫(xiě)個(gè)應(yīng)用的文章和.net core實(shí)踐的短文分享一下
SeaweedFS如何使用
SeaweedFS的Releases下面下載成品,1.20(主要原因是懶,不想去編譯)
運(yùn)行命令
weed master再掛載兩個(gè)分布的服務(wù)
weed volume -dir="D:/FileService/Volume/1" -max=1000 -mserver="localhost:9333" -port=8080weed volume -dir="D:/FileService/Volume/2" -max=1000 -mserver="localhost:9333" -port=8081我們?cè)谠L(fǎng)問(wèn)一下
http://localhost:9333/dir/assign返回可能是這樣的內(nèi)容
{"fid":"1,1642d6a0d7","url":"127.0.0.1:8081","publicUrl":"127.0.0.1:8081","count":1}我們解釋一下
fid是我們需要的上傳的參數(shù)
publicUrl是我們實(shí)際上需要上傳的地址
我們這次上傳的目標(biāo)地址是
http://publicUrl/fidhttp://127.0.0.1:8081/1,1642d6a0d7
上傳的參數(shù)file是對(duì)應(yīng)的文件,上傳類(lèi)型是form-data,就是標(biāo)準(zhǔn)的html表單提交方式
返回你的類(lèi)型可能是
{ ? ?"name": "150106109346115258.jpg", ? ?"size": 206354, ? ?"eTag": "9e663632"}這個(gè)etag,經(jīng)常做web緩存的人,肯定不陌生,http緩存的策略
訪(fǎng)問(wèn)地址則為
http://127.0.0.1:8081/1,1642d6a0d7 http://127.0.0.1:8081/1/1642d6a0d7 http://127.0.0.1:8081/1/1642d6a0d7/150106109346115258.jpgSeaweedFS支持多數(shù)據(jù)中心,這個(gè)在官方github有提到,SeaweedFS自帶健康檢查,內(nèi)部走的GRPC做健康檢查,所以請(qǐng)保持分布的服務(wù)端口,外界可訪(fǎng)問(wèn),無(wú)論是docker還是虛擬機(jī)、VPS,最終上傳還是走的那個(gè)端口
.Net Core下的實(shí)踐
我們先把兩個(gè)返回的實(shí)體對(duì)象做一下
我們?cè)俑鶕?jù)這兩個(gè)實(shí)體,設(shè)計(jì)一個(gè)上傳服務(wù)
再設(shè)計(jì)一個(gè)注入的參數(shù)
public class SeaweedFSServiceConfiguration{ ? ? ?? ? ? ??public string BaseUrl { get; set; } = "localhost:9333"; ? ? ? ? ? ? ? public string DirAssign { get; set; } = "/dir/assign";}
DirAssign這個(gè)是默認(rèn)的參數(shù),如果要用數(shù)據(jù)中心的話(huà),這個(gè)就可以自定義修改了
在Startup.cs的注入一下
測(cè)試文件上傳
先寫(xiě)一個(gè)擴(kuò)展方法,我們希望看見(jiàn)的返回地址是
http://127.0.0.1:8081/1,1642d6a0d7 http://127.0.0.1:8081/1/1642d6a0d7這個(gè)地址的后者
實(shí)現(xiàn)如下
寫(xiě)一個(gè)控制器測(cè)試上傳
構(gòu)建一下返回參數(shù)和入?yún)?/p> ? ?public class UploadFileResponseModel{public string FileName { get; set; }} ? ?public class UploadFileRequestModel{public IFormFile File { get; set; }}
控制器代碼如下
我們用postman測(cè)試一下
?
ok,上傳成功,我們?cè)L問(wèn)
http://localhost:9333/4,1ca657cf3f http://localhost:9333/4/1ca657cf3f http://127.0.0.1:8080/4,1ca657cf3f http://127.0.0.1:8080/4/1ca657cf3f前面兩個(gè)地址會(huì)轉(zhuǎn)跳到后面兩個(gè)地址
?
后記
我這代碼測(cè)試,會(huì)出現(xiàn),不返回name字段的情況
{"name": "150106109346115258.jpg","size": 206354,"eTag": "9e663632" }這種json格式是直接上傳的返回
但是我們這個(gè)上傳服務(wù)會(huì)變成
{"size": 206354,"eTag": "9e663632" }我見(jiàn)了鬼了,誰(shuí)有發(fā)現(xiàn)原因,請(qǐng)告訴我一下,拜托了
原文地址:https://www.cnblogs.com/NCoreCoder/p/10254503.html
.NET社區(qū)新聞,深度好文,歡迎訪(fǎng)問(wèn)公眾號(hào)文章匯總 http://www.csharpkit.com
總結(jié)
以上是生活随笔為你收集整理的SeaweedFS在.net core下的实践方案的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: .NETStandard FreeSql
- 下一篇: Docker最全教程——MongoDB容