小編給大家分享一下多圖片/文件服務(wù)器的實(shí)現(xiàn)過(guò)程是什么,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
成都創(chuàng)新互聯(lián)公司是專(zhuān)業(yè)的天鎮(zhèn)網(wǎng)站建設(shè)公司,天鎮(zhèn)接單;提供成都做網(wǎng)站、網(wǎng)站設(shè)計(jì),網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專(zhuān)業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行天鎮(zhèn)網(wǎng)站開(kāi)發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專(zhuān)業(yè)做搜索引擎喜愛(ài)的網(wǎng)站,專(zhuān)業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來(lái)合作!寫(xiě)在前面
圖片/文件服務(wù)器,顧名思義就是存文件唄,有的人用阿里云的現(xiàn)有服務(wù),有的把文件Post到文件服務(wù)器,在文件服務(wù)器一端用一個(gè)應(yīng)用程序來(lái)接收并保存,方法各不相同。老司機(jī)們各種服務(wù)器已經(jīng)玩爛了。在使用圖片/文件多服務(wù)器的幾個(gè)問(wèn)題就在于:
1.web上傳的文件如何post到文件服務(wù)器上及其速度如何,占用帶寬和耗時(shí)如何。
2.如何使文件均衡的分布在各臺(tái)圖片服務(wù)器上。
3.如何拓展新的圖片服務(wù)器,并保障對(duì)已分配的內(nèi)容影響降到最小。
本篇分享一方面希望有經(jīng)驗(yàn)的司機(jī)給點(diǎn)意見(jiàn),另一方面分享給新司機(jī)和記錄自己的歷程。
第一分鐘確定最終目標(biāo)
1.各文件服務(wù)器不僅提供存儲(chǔ)功能,還要有對(duì)外服務(wù)能力,以降低各個(gè)Web服務(wù)器的帶寬占用和磁盤(pán)IO消耗。
2.提供簡(jiǎn)便和容易的可橫向拓展能力
3.Async異步IO保證線程非阻塞。
4.文件快速到達(dá)圖片服務(wù)器
第三分鐘否定自己
1.否認(rèn)采取Http Post圖片到圖片服務(wù)器的方式
2.否認(rèn)采取Hash取模算法
3.否認(rèn)使用一致性哈希,避免服務(wù)器橫向拓展后文件移動(dòng),即使是少量的
第五分鐘確定實(shí)現(xiàn)方式
1.把文件服務(wù)器磁盤(pán)共享出一個(gè)文件夾,作為特定用戶間“網(wǎng)絡(luò)磁盤(pán)”,就是說(shuō)該共享文件夾,只有web服務(wù)器有權(quán)限訪問(wèn),你可以參照局域網(wǎng)內(nèi)如何共享文件夾或者阿里云共享文件夾。
2.通過(guò)IIS虛擬目錄,將其物理路徑指向網(wǎng)絡(luò)磁盤(pán)。你知道共享文件夾間使用Tcp/Ip協(xié)議和Netbios協(xié)議通信。
3.配置WebConfig訪問(wèn)網(wǎng)絡(luò)磁盤(pán)身份(用戶名和密碼)—必須配置哦
4.第一步所共享的文件,在文件服務(wù)器部署在IIS下WebApp中的一個(gè)文件下,以便暴露URL路徑。因?yàn)槟阒繧IS除了使用文件讀取的方式,是不可以獲取父級(jí)文件夾中的任何內(nèi)容的。
4.確定根據(jù)文件名均勻分配圖片位置的方式—文件后綴名方式,后綴名采用"文件名-01"(一號(hào)服務(wù)器),后綴名采用"文件名-02"(二號(hào)服務(wù)器),隨機(jī)數(shù)使用Random來(lái)取,隨機(jī)數(shù)是幾,我們就存在幾號(hào)服務(wù)器。經(jīng)過(guò)多次測(cè)試100萬(wàn)次隨機(jī),1,2,3分別得到33W次左右,保障了均衡。在將來(lái)拓展的時(shí)候,Random隨機(jī)數(shù)多開(kāi)啟幾位就行了,不需要文件的移動(dòng),也沒(méi)有reshash。并且在橫向拓展服務(wù)器數(shù)量后,希望保證已有三臺(tái)服務(wù)器不繼續(xù)存儲(chǔ)文件,Random范圍可調(diào)。在數(shù)據(jù)庫(kù)或者緩存中我們已經(jīng)存下了文件名稱(chēng),并且其有后綴名,在為前臺(tái)返回圖片URL的時(shí)候,只需要根據(jù)后綴名稱(chēng),來(lái)拼出文件服務(wù)器IP或域名。
第七分鐘按照步驟動(dòng)手操作
1.部署FileServerApp,其功能是對(duì)圖片暴露URL,其實(shí)很簡(jiǎn)單啦,建立一個(gè)Asp.Net空項(xiàng)目,建立出存儲(chǔ)圖片的文件夾。并將該文件夾共享給Web服務(wù)器,細(xì)節(jié)看最后一節(jié)的部署圖。
2.假定你已經(jīng)實(shí)現(xiàn)文件夾共享
3.在IIS站點(diǎn)下新建虛擬目錄,注意物理路徑指向的是網(wǎng)絡(luò)共享文件夾的網(wǎng)絡(luò)路徑
4.在Webconfig下
5.使用Server.MapPath可以獲取FileServer2的網(wǎng)絡(luò)路徑,并使用你的讀寫(xiě)文件方式對(duì)目錄中的文件進(jìn)行讀寫(xiě)。
6.寫(xiě)入文件建議使用Async的方式,異步IO會(huì)在你將IO請(qǐng)求包發(fā)給網(wǎng)絡(luò)驅(qū)動(dòng)或者磁盤(pán)驅(qū)動(dòng)后,返回去處理其他事情,在將來(lái)的某個(gè)時(shí)刻,文件寫(xiě)入成功,狀態(tài)機(jī)恢復(fù)你的上下文并以同步的方式繼續(xù)向下執(zhí)行,能大大提高你Web服務(wù)器的吞吐能力。
寫(xiě)在最后的重點(diǎn)
如果還有模糊的地方,看這里就全明白啦
以上是多圖片/文件服務(wù)器的實(shí)現(xiàn)過(guò)程是什么的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!