2012-02-18 14 views
8

FTP là giao thức kết nối TCP thuần túy, và do đó AFAIK "nhanh như nó được" khi xem xét các tùy chọn truyền tệp TCP.Truyền tập tin nhanh hơn FTP

Tuy nhiên, có một số sản phẩm khác không chạy trên TCP - ví dụ là các sản phẩm thương mại BI.DAN-GUN, faspFileCatalyst. Sản phẩm thứ hai chỉ ra problems with pure TCP và một sản phẩm có thể đọc thêm trên Wikipedia, ví dụ: bắt đầu từ Network Congestion.

Còn lựa chọn thay thế nào khác? .. cụ thể là nguồn mở? Ngoài ra, người ta sẽ nghĩ rằng đây phải là một RFC của các loại - một giao thức quy định cụ thể là có thể chạy trên UDP. Bất cứ ai biết về một giao thức như vậy, hoặc một sáng kiến? (Google SPDY thú vị nhưng không trực tiếp giải quyết việc truyền tệp nhanh nhanh)

Trả lời

6

Có một số dự án mã nguồn mở đang cố gắng xử lý chuyển tệp qua UDP. Hãy xem UFTP, Sóng thần hoặc UDT, mỗi dự án ở một giai đoạn phát triển khác.

Tùy thuộc vào độ trễ băng thông và mức độ mất túi bạn đang làm việc, mỗi dự án sẽ tạo ra một kết quả khác. Có một bài viết trên blog cố gắng so sánh 3 dự án, đây là liên kết http://www.filecatalyst.com/open-source-fast-file-transfers

9

Tại sao bạn nghĩ rằng việc sử dụng TCP làm cho việc truyền chậm hơn? TCP thường có thể sử dụng tất cả băng thông có sẵn. Sử dụng UDP thay vì không thể nhanh hơn. Trong thực tế, nếu bạn đã cố gắng thực hiện chuyển tập tin dựa trên UDP đáng tin cậy, bạn có thể sẽ thực hiện một thay thế kém hơn cho TCP - vì bạn phải tự mình thực hiện độ tin cậy.

có vấn đề về FTP là nó thực hiện nhiều lệnh yêu cầu phản hồi đồng bộ cho mọi tệp bạn chuyển và mở kết nối dữ liệu mới cho mỗi tệp. Điều này dẫn đến việc chuyển rất kém hiệu quả khi nhiều tệp nhỏ hơn đang được chuyển, vì phần lớn thời gian được dành cho các yêu cầu/phản hồi chờ đợi và thiết lập các kết nối dữ liệu thay vì thực sự chuyển dữ liệu.

Cách đơn giản để giải quyết vấn đề này là đóng gói tệp/thư mục vào lưu trữ. Trong khi bạn có thể, tất nhiên, chỉ cần làm cho các kho lưu trữ, gửi nó bằng cách sử dụng FTP hoặc tương tự, và giải nén nó ở phía bên kia, thời gian dành cho đóng gói và giải nén có thể là không thể chấp nhận. Bạn có thể tránh sự chậm trễ này bằng cách thực hiện việc đóng gói và giải nén trực tuyến. Tôi không biết bất kỳ phần mềm nào tích hợp gói/giải nén trực tuyến như vậy. Bạn có thể, tuy nhiên, chỉ cần sử dụng các chương trình nctar trong một đường ống (Linux, Windows sử dụng Cygwin):

chạy đầu tiên trên người nhận:

nc -l -p 7000 | tar x -C <destination_folder> 

này sẽ làm cho người nhận chờ đợi cho một kết nối trên cổng số 7000. Sau đó chạy trên người gửi:

cd /some/folder 
tar c ./* | nc -q0 <ip_address_of_receiver>:7000 

Điều này sẽ khiến người gửi kết nối với người nhận, bắt đầu chuyển. Người gửi sẽ tạo kho lưu trữ tar, gửi nó đến người nhận, sẽ giải nén nó - tất cả cùng một lúc. Nếu cần, bạn có thể đảo ngược vai trò của người gửi và người nhận (bằng cách yêu cầu người nhận kết nối với người gửi).

Cách tiếp cận trực tuyến-tar này không có hai vấn đề về hiệu suất của FTP; nó không thực hiện bất kỳ lệnh yêu cầu-đáp ứng nào, và chỉ sử dụng một kết nối TCP duy nhất.

Tuy nhiên, lưu ý rằng điều này không an toàn; ai cũng có thể kết nối với người nhận trước khi người gửi của chúng tôi gửi, gửi cho anh ta kho lưu trữ tar của riêng mình. Nếu đây là một vấn đề, một VPN có thể được sử dụng, kết hợp với các quy tắc tường lửa thích hợp.

EDIT: bạn đã đề cập đến mất gói là sự cố với hiệu suất TCP, đây là vấn đề quan trọng, nếu trang FileCatalyst được tin tưởng.Đúng là TCP có thể thực hiện không tối ưu với các liên kết mất gói cao. Điều này là do TCP thường phản ứng tích cực với mất gói, bởi vì nó giả định mất là do tắc nghẽn; xem Additive_increase/multiplicative_decrease. Tôi không biết về bất kỳ chương trình truyền tệp miễn phí/mã nguồn mở nào có thể cố gắng khắc phục điều này bằng các giao thức tùy chỉnh. Tuy nhiên, bạn có thể thử khác nhau TCP congestion avoidance algorithms. Cụ thể, hãy thử Vegas, điều này làm không sử dụng mất gói làm tín hiệu để giảm tốc độ truyền.

+1

Bạn đã xem các liên kết tôi đã bao gồm chưa? Nếu bạn có một tập tin 500GB để chuyển, các kết nối điều khiển của FTP hoàn toàn không đáng kể, và những gì bạn kết thúc với là hiệu suất TCP thô. Điều này không nhất thiết phải được điều chỉnh để chuyển các tập tin lớn nhanh nhất có thể - đặc biệt không vượt quá các liên kết với bất kỳ mất gói nào. Các sản phẩm trong các liên kết tôi bao gồm DO thực hiện độ tin cậy bản thân, rõ ràng. – stolsvik

+0

@stolsvik bạn chưa đề cập đến các liên kết mất mát cao, mà AFAIK hiếm gặp trên Internet. Tôi đã thêm một cái gì đó về điều đó. –

+1

Trên thực tế, giao thức TCP thực sự không được thiết kế để chuyển số lượng lớn một chiều. Chắc chắn nó có thể được thực hiện để làm điều đó, nhưng TCP yêu cầu trả lại các gói theo cách gây ra các gian hàng ngắn và nó có thể là một hành động cân bằng để chọn kích thước bộ đệm và kích thước cửa sổ cho tốc độ thực sự tối ưu. Ngoài ra, việc triển khai có thể không phải lúc nào cũng thực hiện những gì mà chúng thực sự phải thực hiện với các cài đặt tùy chọn khác nhau. –

1

Cân nhắc sử dụng truyền tệp dựa trên UDP, xem JSCAPE MFT Server thực hiện giao thức độc quyền được gọi là AFTP (Giao thức truyền tệp nhanh). Vui lòng xem liên kết này:

http://www.jscape.com/blog/bid/80668/UDP-File-Transfer-up-to-100x-Faster-than-TCP

Hãy ghi nhớ rằng AFTP JSCAPE của việc tối ưu trên các kết nối đường dài mà có độ trễ mạng. Nếu không có AFTP độ trễ mạng sẽ không thực hiện bất kỳ tốt hơn so với FTP thông thường cũ (trên TCP).

Có, tôi làm việc cho JSCAPE LLC.

2

Không phải nguồn mở, nhưng tốc độ truyền của Aspera đáng để kiểm tra và không bị ảnh hưởng bởi mất gói hoặc trì hoãn mạng. You can see a chart here. Nó cũng sử dụng một giao thức độc quyền được gọi là fasp.

+0

Tôi đã đề cập đến "fasp" trong câu hỏi đầu tiên ... – stolsvik

+1

Các nguồn không phải mã nguồn mở khác là signiant và smartjog. Họ thường tham gia thi đấu với aspera trong ngành giải trí (sản xuất phim). – satoc