hadoop-cos

org.apache.hadoop.fs.CosNFileSystem

Preconditions.checkArgument(uploadThreadPoolSize > 0,
                String.format("The uploadThreadPoolSize[%d] should be positive.", uploadThreadPoolSize));
        Preconditions.checkArgument(readAheadPoolSize > 0,
                String.format("The readAheadQueueSize[%d] should be positive.", readAheadPoolSize));
        // 核心线程数取用户配置的为准,最大线程数结合用户配置和IO密集型任务的最优线程数来看
        int ioCoreTaskSize = uploadThreadPoolSize + readAheadPoolSize;
        int ioMaxTaskSize = Math.max(uploadThreadPoolSize + readAheadPoolSize,
                Runtime.getRuntime().availableProcessors() * 2 + 1);
        if (this.getConf().get(CosNConfigKeys.IO_THREAD_POOL_MAX_SIZE_KEY) != null) {
            int ioThreadPoolMaxSize = this.getConf().getInt(
                    CosNConfigKeys.IO_THREAD_POOL_MAX_SIZE_KEY, CosNConfigKeys.DEFAULT_IO_THREAD_POOL_MAX_SIZE);
            Preconditions.checkArgument(ioThreadPoolMaxSize > 0,
                    String.format("The ioThreadPoolMaxSize[%d] should be positive.", ioThreadPoolMaxSize));
            // 如果设置了 IO 线程池的最大限制,则整个线程池需要被限制住
            ioCoreTaskSize = Math.min(ioCoreTaskSize, ioThreadPoolMaxSize);
            ioMaxTaskSize = ioThreadPoolMaxSize;
        }
int readAheadPoolSize = this.getConf().getInt(
                CosNConfigKeys.READ_AHEAD_QUEUE_SIZE,
                CosNConfigKeys.DEFAULT_READ_AHEAD_QUEUE_SIZE
        );

  • java/org/apache/hadoop/fs/CosNFSInputStream.java

以下是顺序读,随机读的判断

private synchronized void reopen(long pos) throws IOException {
...
		boolean isRandomIO = true;
        if (pos == this.nextPos) {
            isRandomIO = false;
        } else {
            while (this.readBufferQueue.size() != 0) {
                if (this.readBufferQueue.element().getStart() != pos) {
                    this.readBufferQueue.poll();
                } else {
                    break;
                }
            }
        }
...
}
        this.maxReadPartNumber = conf.getInt(
                CosNConfigKeys.READ_AHEAD_QUEUE_SIZE,
                CosNConfigKeys.DEFAULT_READ_AHEAD_QUEUE_SIZE);
        this.socketErrMaxRetryTimes = conf.getInt(
                CosNConfigKeys.CLIENT_SOCKET_ERROR_MAX_RETRIES,
                CosNConfigKeys.DEFAULT_CLIENT_SOCKET_ERROR_MAX_RETRIES);
public static final String CLIENT_SOCKET_ERROR_MAX_RETRIES = "fs.cosn.socket.error.maxRetries";
    public static final int DEFAULT_CLIENT_SOCKET_ERROR_MAX_RETRIES = 5;
this.readBufferQueue =
                new ArrayDeque<ReadBuffer>(this.maxReadPartNumber);

相关推荐

  1. hadoop-cos

    2024-06-13 23:22:02       34 阅读
  2. Hadoop

    2024-06-13 23:22:02       49 阅读
  3. Hadoop

    2024-06-13 23:22:02       43 阅读
  4. <span style='color:red;'>Hadoop</span>

    Hadoop

    2024-06-13 23:22:02      59 阅读
  5. <span style='color:red;'>Hadoop</span>

    Hadoop

    2024-06-13 23:22:02      63 阅读
  6. <span style='color:red;'>hadoop</span>

    hadoop

    2024-06-13 23:22:02      35 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-13 23:22:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-13 23:22:02       106 阅读
  3. 在Django里面运行非项目文件

    2024-06-13 23:22:02       87 阅读
  4. Python语言-面向对象

    2024-06-13 23:22:02       96 阅读

热门阅读

  1. 软件测试--第十一章 设计和维护测试用例

    2024-06-13 23:22:02       34 阅读
  2. CMake“cmake is not able to compile a simple test program”

    2024-06-13 23:22:02       34 阅读
  3. c++防止头文件重复

    2024-06-13 23:22:02       28 阅读
  4. C++学习(19)

    2024-06-13 23:22:02       34 阅读
  5. 802.11中的各种帧

    2024-06-13 23:22:02       38 阅读
  6. 雅可比矩阵奇异求解

    2024-06-13 23:22:02       36 阅读
  7. SDK version 2018.3 doesnt match hw_server version 2015.2

    2024-06-13 23:22:02       23 阅读