<pre id="bbfd9"><del id="bbfd9"><dfn id="bbfd9"></dfn></del></pre>

          <ruby id="bbfd9"></ruby><p id="bbfd9"><mark id="bbfd9"></mark></p>

          <p id="bbfd9"></p>

          <p id="bbfd9"><cite id="bbfd9"></cite></p>

            <th id="bbfd9"><form id="bbfd9"><dl id="bbfd9"></dl></form></th>

            <p id="bbfd9"><cite id="bbfd9"></cite></p><p id="bbfd9"></p>
            <p id="bbfd9"><cite id="bbfd9"><progress id="bbfd9"></progress></cite></p>
            操作系統

            Linux下實現斷點續傳的原理介紹

            時間:2025-02-13 12:24:34 操作系統 我要投稿
            • 相關推薦

            Linux下實現斷點續傳的原理介紹

              Linux下實現斷點續傳的原理介紹

              斷點續傳是一種結合本地存儲和網絡存儲的技術,主要用來解決網絡失效時的視頻丟失問題。DVS通常本身沒有視頻存儲功能,而是必須由后端的NVR來實現視頻的存儲,因此對于網絡穩定性要求很高,網絡連接失敗、丟包嚴重、抖動等各種因素都可能造成視頻數據的丟失。斷點續傳支持從文件上次中斷的地方開始傳送數據,而并非是從文件開頭傳送。這就是斷點續傳的定義。系統都默認可以斷點續傳,但我們很少知道他的原理,下面就來看看小編的介紹吧。

              斷點續傳的原理

              其實斷點續傳的原理很簡單,就是在 Http 的請求上和一般的下載有所不同而已。

              打個比方,瀏覽器請求服務器上的一個文時,所發出的請求如下:

              假設服務器域名為 ,文件名為 down.zip。

              GET /down.zip HTTP/1.1

              Accept: image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, application/vnd.ms-

              excel, application/msword, application/vnd.ms-powerpoint, */*

              Accept-Language: zh-cn

              Accept-Encoding: gzip, deflate

              User-Agent: Mozilla/4.0 (compatible; MSIE 5.01; Windows NT 5.0)

              Connection: Keep-Alive

              服務器收到請求后,按要求尋找請求的文件,提取文件的信息,然后返回給瀏覽器,返回信息如下:

              200

              Content-Length=106786028

              Accept-Ranges=bytes

              Date=Mon, 30 Apr 2001 12:56:11 GMT

              ETag=W/“02ca57e173c11:95b”

              Content-Type=application/octet-stream

              Server=Microsoft-IIS/5.0

              Last-Modified=Mon, 30 Apr 2001 12:56:11 GMT

              所謂斷點續傳,也就是要從文件已經下載的地方開始繼續下載。所以在客戶端瀏覽器傳給 Web 服務器的時候要多加一條信息 -- 從哪里開始。

              下面是用自己編的一個“瀏覽器”來傳遞請求信息給 Web 服務器,要求從 2000070 字節開始。

              GET /down.zip HTTP/1.0

              User-Agent: NetFox

              RANGE: bytes=2000070-

              Accept: text/html, image/gif, image/jpeg, *; q=.2, */*; q=.2

              仔細看一下就會發現多了一行 RANGE: bytes=2000070-

              這一行的意思就是告訴服務器 down.zip 這個文件從 2000070 字節開始傳,前面的字節不用傳了。

              服務器收到這個請求以后,返回的信息如下:

              206

              Content-Length=106786028

              Content-Range=bytes 2000070-106786027/106786028

              Date=Mon, 30 Apr 2001 12:55:20 GMT

              ETag=W/“02ca57e173c11:95b”

              Content-Type=application/octet-stream

              Server=Microsoft-IIS/5.0

              Last-Modified=Mon, 30 Apr 2001 12:55:20 GMT

              和前面服務器返回的信息比較一下,就會發現增加了一行:

              Content-Range=bytes 2000070-106786027/106786028

              返回的代碼也改為 206 了,而不再是 200 了。

              知道了以上原理,就可以進行斷點續傳的編程了。

              Java 實現斷點續傳的關鍵幾點

              (1) 用什么方法實現提交 RANGE: bytes=2000070-。

              當然用最原始的 Socket 是肯定能完成的,不過那樣太費事了,其實 Java 的 net 包中提供了這種功能。代碼如下:

              URL url = new URL(“/down.zip”);

              HttpURLConnection httpConnection = (HttpURLConnection)url.openConnection();

              // 設置 User-Agent

              httpConnection.setRequestProperty(“User-Agent”,“NetFox”);

              // 設置斷點續傳的開始位置

              http Connection.setRequestProperty(“RANGE”,“bytes=2000070”);

              // 獲得輸入流

              InputStream input = httpConnection.getInputStream();

              從輸入流中取出的字節流就是 down.zip 文件從 2000070 開始的字節流。 大家看,其實斷點續傳用 Java 實現起來還是很簡單的吧。 接下來要做的事就是怎么保存獲得的流到文件中去了。

              保存文件采用的方法。

              我采用的是 IO 包中的 RandAccessFile 類。

              操作相當簡單,假設從 2000070 處開始保存文件,代碼如下:

              RandomAccess oSavedFile = new RandomAccessFile(“down.zip”,“rw”);

              long nPos = 2000070;

              // 定位文件指針到 nPos 位置

              oSavedFile.seek(nPos);

              byte[] b = new byte[1024];

              int nRead;

              // 從輸入流中讀入字節流,然后寫到文件中

              while((nRead=input.read(b,0,1024)) 》 0)

              {

              oSavedFile.write(b,0,nRead);

              }

              以上就是斷點續傳的原理,知道這些原理,相信大家都能夠進行編程了吧,這個技術在現在的電腦技術上也算不得什么,打家應該都注意到我們下載時都是斷點續傳吧

            【Linux下實現斷點續傳的原理介紹】相關文章:

            PHP實現HTTP斷點續傳的方法07-10

            linux下卸載apache方法介紹02-27

            Linux系統下動態庫的生成介紹05-21

            linux操作系統原理知識01-24

            linux操作系統原理知識06-12

            Java 隊列實現原理及簡單實現代碼03-18

            Linux下Git的使用08-02

            Linux全自動安裝操作實例及原理04-02

            有關Linux用軟件實現RAID的方法01-21

                    <pre id="bbfd9"><del id="bbfd9"><dfn id="bbfd9"></dfn></del></pre>

                    <ruby id="bbfd9"></ruby><p id="bbfd9"><mark id="bbfd9"></mark></p>

                    <p id="bbfd9"></p>

                    <p id="bbfd9"><cite id="bbfd9"></cite></p>

                      <th id="bbfd9"><form id="bbfd9"><dl id="bbfd9"></dl></form></th>

                      <p id="bbfd9"><cite id="bbfd9"></cite></p><p id="bbfd9"></p>
                      <p id="bbfd9"><cite id="bbfd9"><progress id="bbfd9"></progress></cite></p>
                      飘沙影院