Ejemplo n.º 1
0
  @Override
  public Block write(Block block) {

    int bufferId =
        assignor.assign(block.getBlockId(), block.getPrimaryDiskId(), block.getReplicaLevel());

    BufferRegion region = getBufferRegion(bufferId, block.getReplicaLevel());

    return region.write(block);
  }
Ejemplo n.º 2
0
  @Override
  public List<Block> getBlocksInTheSameRegion(Block block) {

    int bufferId =
        assignor.assign(block.getBlockId(), block.getPrimaryDiskId(), block.getReplicaLevel());

    BufferRegion region = getBufferRegion(bufferId, block.getReplicaLevel());

    return region.getBufferedBlocks();
  }
Ejemplo n.º 3
0
  @Override
  public Block remove(Block block) {

    if (block == null) return null;

    int bufferId =
        assignor.assign(block.getBlockId(), block.getPrimaryDiskId(), block.getReplicaLevel());

    BufferRegion region = getBufferRegion(bufferId, block.getReplicaLevel());

    return region.remove(block.getBlockId());
  }
Ejemplo n.º 4
0
  @Override
  public List<Block> getBlocksCorrespondingToSpecifiedDisk(int diskId) {
    List<Block> result = new ArrayList<>();

    for (List<BufferRegion> regions : regionTable.values()) {
      for (BufferRegion region : regions) {
        for (Block block : region.getBufferedBlocks()) {
          if (block.getOwnerDiskId() == diskId) result.add(block);
        }
      }
    }
    return result;
  }
Ejemplo n.º 5
0
 @Override
 public int getCorrespondingBufferId(Block block) {
   return assignor.assign(block.getBlockId(), block.getPrimaryDiskId(), block.getReplicaLevel());
 }