|
@ -60,12 +60,12 @@ public class SeaweedOutputStream extends OutputStream implements Syncable, Strea |
|
|
this.outputIndex = 0; |
|
|
this.outputIndex = 0; |
|
|
this.writeOperations = new ConcurrentLinkedDeque<>(); |
|
|
this.writeOperations = new ConcurrentLinkedDeque<>(); |
|
|
|
|
|
|
|
|
this.maxConcurrentRequestCount = 4 * Runtime.getRuntime().availableProcessors(); |
|
|
|
|
|
|
|
|
this.maxConcurrentRequestCount = Runtime.getRuntime().availableProcessors(); |
|
|
|
|
|
|
|
|
this.threadExecutor |
|
|
this.threadExecutor |
|
|
= new ThreadPoolExecutor(maxConcurrentRequestCount, |
|
|
= new ThreadPoolExecutor(maxConcurrentRequestCount, |
|
|
maxConcurrentRequestCount, |
|
|
maxConcurrentRequestCount, |
|
|
10L, |
|
|
|
|
|
|
|
|
120L, |
|
|
TimeUnit.SECONDS, |
|
|
TimeUnit.SECONDS, |
|
|
new LinkedBlockingQueue<Runnable>()); |
|
|
new LinkedBlockingQueue<Runnable>()); |
|
|
this.completionService = new ExecutorCompletionService<>(this.threadExecutor); |
|
|
this.completionService = new ExecutorCompletionService<>(this.threadExecutor); |
|
@ -113,7 +113,7 @@ public class SeaweedOutputStream extends OutputStream implements Syncable, Strea |
|
|
break; |
|
|
break; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
// System.out.println(path + " [" + (outputIndex + currentOffset) + "," + ((outputIndex + currentOffset) + writableBytes) + ")"); |
|
|
|
|
|
|
|
|
// System.out.println(path + " [" + (outputIndex + currentOffset) + "," + ((outputIndex + currentOffset) + writableBytes) + ") " + buffer.capacity()); |
|
|
buffer.put(data, currentOffset, writableBytes); |
|
|
buffer.put(data, currentOffset, writableBytes); |
|
|
outputIndex += writableBytes; |
|
|
outputIndex += writableBytes; |
|
|
currentOffset += writableBytes; |
|
|
currentOffset += writableBytes; |
|
@ -227,7 +227,7 @@ public class SeaweedOutputStream extends OutputStream implements Syncable, Strea |
|
|
bufferToWrite.flip(); |
|
|
bufferToWrite.flip(); |
|
|
int bytesLength = bufferToWrite.limit() - bufferToWrite.position(); |
|
|
int bytesLength = bufferToWrite.limit() - bufferToWrite.position(); |
|
|
|
|
|
|
|
|
if (threadExecutor.getQueue().size() >= maxConcurrentRequestCount * 2) { |
|
|
|
|
|
|
|
|
if (threadExecutor.getQueue().size() >= maxConcurrentRequestCount) { |
|
|
waitForTaskToComplete(); |
|
|
waitForTaskToComplete(); |
|
|
} |
|
|
} |
|
|
final Future<Void> job = completionService.submit(() -> { |
|
|
final Future<Void> job = completionService.submit(() -> { |
|
|