Imrpove upload speed by spam sending
This commit is contained in:
@@ -343,8 +343,7 @@ export class FileSystemClient {
|
|||||||
|
|
||||||
this.activeUploads.set(transferId, upload)
|
this.activeUploads.set(transferId, upload)
|
||||||
|
|
||||||
// Stream chunks one at a time, waiting for each to be sent
|
// Stream all chunks without waiting for ACKs
|
||||||
;(async () => {
|
|
||||||
for (let chunkIndex = 0; chunkIndex < totalChunks; chunkIndex++) {
|
for (let chunkIndex = 0; chunkIndex < totalChunks; chunkIndex++) {
|
||||||
const offset = chunkIndex * chunkSize
|
const offset = chunkIndex * chunkSize
|
||||||
const end = Math.min(offset + chunkSize, fileSize)
|
const end = Math.min(offset + chunkSize, fileSize)
|
||||||
@@ -356,12 +355,12 @@ export class FileSystemClient {
|
|||||||
data: chunkData
|
data: chunkData
|
||||||
}
|
}
|
||||||
|
|
||||||
// Wait for chunk to be sent before continuing
|
// Send chunk as fire-and-forget message
|
||||||
await socket.emit(FSMessages.FSUploadData, uploadData)
|
socket.emit(FSMessages.FSUploadData, uploadData)
|
||||||
|
|
||||||
upload.chunksSent++
|
upload.chunksSent++
|
||||||
|
|
||||||
// Report progress after chunk is actually sent
|
// Report progress
|
||||||
if (onProgress) {
|
if (onProgress) {
|
||||||
onProgress({
|
onProgress({
|
||||||
transferId,
|
transferId,
|
||||||
@@ -376,7 +375,6 @@ export class FileSystemClient {
|
|||||||
|
|
||||||
// All chunks sent - now wait for completion message from server
|
// All chunks sent - now wait for completion message from server
|
||||||
// The timeout will handle if server doesn't respond
|
// The timeout will handle if server doesn't respond
|
||||||
})()
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -198,27 +198,12 @@ function createWebSocket() {
|
|||||||
unresponsiveTimeoutId = setTimeout(() => disconnect('unresponsive'), reconnectTimeoutTime)
|
unresponsiveTimeoutId = setTimeout(() => disconnect('unresponsive'), reconnectTimeoutTime)
|
||||||
}
|
}
|
||||||
|
|
||||||
function emit<T>(event: MessageFns<T>, data: T): Promise<void> {
|
function emit<T>(event: MessageFns<T>, data: T) {
|
||||||
return new Promise((resolve) => {
|
if (!ws || ws.readyState !== WebSocket.OPEN) return
|
||||||
if (!ws || ws.readyState !== WebSocket.OPEN) {
|
|
||||||
resolve()
|
|
||||||
return
|
|
||||||
}
|
|
||||||
const type = getNameFromMessageType(event)
|
const type = getNameFromMessageType(event)
|
||||||
const wsm = Message.create() as Record<string, unknown>
|
const wsm = Message.create() as Record<string, unknown>
|
||||||
wsm[type] = data
|
wsm[type] = data
|
||||||
send(wsm as Message)
|
send(wsm as Message)
|
||||||
|
|
||||||
// Wait for buffer to flush before resolving
|
|
||||||
const checkBuffer = () => {
|
|
||||||
if (!ws || ws.bufferedAmount === 0) {
|
|
||||||
resolve()
|
|
||||||
} else {
|
|
||||||
setTimeout(checkBuffer, 5)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
checkBuffer()
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function unsubscribeToMessageFromServer<T>(event_type: MessageFns<T>) {
|
function unsubscribeToMessageFromServer<T>(event_type: MessageFns<T>) {
|
||||||
|
|||||||
Reference in New Issue
Block a user