Examples of BBContainer


Examples of org.voltdb.utils.DBBPool.BBContainer

                FastSerializer fs = this.singletonSerializer;
                assert (fs != null);
                fs.clear();
                this.singletonLogEntry.init(ts);
                fs.writeObject(this.singletonLogEntry);
                BBContainer b = fs.getBBContainer();
                this.fstream.write(b.b.asReadOnlyBuffer());
                this.fstream.force(true);
                this.singletonLogEntry.finish();
            } catch (Exception e) {
                String message = "Failed to write single log entry for " + ts.toString();
View Full Code Here

Examples of org.voltdb.utils.DBBPool.BBContainer

    }

    public void testDefaultPoolCtor() {
        DBBPool p1 = new DBBPool();
        assertEquals(0, p1.bytesLoanedLocally());
        BBContainer containers1[] = p1.acquire( NUM_BUFFERS, INITIAL_ALLOCATION);
        assertTrue((NUM_BUFFERS * INITIAL_ALLOCATION) <= p1.bytesAllocatedGlobally());
        for (BBContainer c : containers1) {
            c.discard();
        }

        // verify that globalbytes is really all pools
        DBBPool p2 = new DBBPool();
        BBContainer containers2[] = p2.acquire( 33, INITIAL_ALLOCATION);
        assertTrue(p1.bytesAllocatedGlobally() >=
                     (p1.bytesAllocatedLocally() + p2.bytesAllocatedLocally()));

        for (BBContainer c : containers2) {
            c.discard();
View Full Code Here

Examples of org.voltdb.utils.DBBPool.BBContainer

        loadTestTables(catalog);

        sourceEngine.activateTableStream( WAREHOUSE_TABLEID, TableStreamType.RECOVERY );
        sourceEngine.activateTableStream( STOCK_TABLEID, TableStreamType.RECOVERY );

        BBContainer origin = DBBPool.allocateDirect(1024 * 1024 * 2);
        try {
            origin.b.clear();
            long address = org.voltdb.utils.DBBPool.getBufferAddress(origin.b);
            BBContainer container = new BBContainer(origin.b, address){

                @Override
                public void discard() {
                }};

View Full Code Here

Examples of org.voltdb.utils.DBBPool.BBContainer

                        for (Integer partitionId : saveFile.getPartitionIds()) {
                            partitionIds.add(partitionId);
                        }
                        if (validate && saveFile.getCompleted()) {
                            while (saveFile.hasMoreChunks()) {
                                BBContainer cont = saveFile.getNextChunk();
                                if (cont != null) {
                                    cont.discard();
                                }
                            }
                        }
                        partitionIds.removeAll(saveFile.getCorruptedPartitionIds());
                        Snapshot s = snapshots.get(saveFile.getCreateTime());
View Full Code Here

Examples of org.voltdb.utils.DBBPool.BBContainer

        builder.setStatus(status);
       
        // SerializableException
        if (error != null) {
            int size = error.getSerializedSize();
            BBContainer bc = this.buffer_pool.acquire(size);
            try {
                error.serializeToBuffer(bc.b);
            } catch (IOException ex) {
                String msg = "Failed to serialize error for " + ts;
                throw new ServerFaultException(msg, ex);
            }
            bc.b.rewind();
            builder.setError(ByteString.copyFrom(bc.b));
            bc.discard();
        }
       
        // Push dependencies back to the remote partition that needs it
        if (status == Status.OK) {
            for (int i = 0, cnt = result.size(); i < cnt; i++) {
View Full Code Here

Examples of org.voltdb.utils.DBBPool.BBContainer

                final long handle = m_handle.getAndIncrement();
                final StoredProcedureInvocation invocation =
                    new StoredProcedureInvocation(handle, procName, -1, parameters);

                final FastSerializer fs = new FastSerializer();
                final BBContainer c = fs.writeObjectForMessaging(invocation);
                do {
                    channel.write(c.b);
                    if (c.b.hasRemaining()) {
                        Thread.yield();
                    }
                }
                while(c.b.hasRemaining());
                c.discard();
                return handle;
            }
        });
    }
View Full Code Here

Examples of org.voltdb.utils.DBBPool.BBContainer

        return read;
    }

    private final void drainWriteStream(final DBBPool pool) throws IOException {
        //Safe to do this with a separate embedded synchronization because no interest ops are modded
        final BBContainer results[] = m_writeStream.swapAndSerializeQueuedWrites(pool);

        /*
         * All interactions with write stream must be protected
         * with a lock to ensure that interests ops are consistent with
         * the state of writes queued to the stream. This prevent
View Full Code Here

Examples of org.voltdb.utils.DBBPool.BBContainer

                    + m_totalAvailable + " bytes; call tryRead() first");
        }

        int bytesCopied = 0;
        while (bytesCopied < output.length) {
            BBContainer first = m_readBuffers.peekFirst();
            if (first == null) {
                // Steal the write buffer
                m_writeBuffer.b.flip();
                m_readBuffers.add(m_writeBuffer);
                first = m_writeBuffer;
                m_writeBuffer = null;
            }
            assert first.b.remaining() > 0;

            // Copy bytes from first into output
            int bytesRemaining = first.b.remaining();
            int bytesToCopy = output.length - bytesCopied;
            if (bytesToCopy > bytesRemaining) bytesToCopy = bytesRemaining;
            first.b.get(output, bytesCopied, bytesToCopy);
            bytesCopied += bytesToCopy;
            m_totalAvailable -= bytesToCopy;

            if (first.b.remaining() == 0) {
                // read an entire block: move it to the empty buffers list
                m_readBuffers.poll();
                first.discard();
            }
        }

        if (bytesCopied > 0) {
            m_globalAvailable.addAndGet(0 - bytesCopied);
View Full Code Here

Examples of org.voltdb.utils.DBBPool.BBContainer

             * Peek the first buffer and inspect it to see if it needs any special handling
             * If it is to large to use as part of a gathering write then branch and just focus on
             * writing the one
             */
            final int queuedForWrite = 0;
            final BBContainer peekedBuffer = m_queuedBuffers.peek();
            if (peekedBuffer.b.remaining() > MAX_GATHERING_WRITE) {
                /*
                 * If the buffer is not direct and it is this large it should be split up in separate writes
                 */
                if (!peekedBuffer.b.isDirect()) {
                    /**
                     * Split a big heap byte buffer into many smaller slices
                     * so Java doesn't allocate a bunch of direct ByteBuffers
                     */
                    //The source buffer for the slices that holds the memory goes in first
                    //so it will be discarded once all the slices have been read.
                    m_queuedBuffers.push(peekedBuffer);
                    final int originalPosition = peekedBuffer.b.position();
                    do {
                        final int amountToSplit = Math.min(peekedBuffer.b.remaining(), MAX_GATHERING_WRITE);
                        peekedBuffer.b.position(peekedBuffer.b.limit() - amountToSplit);
                        final BBContainer splice = DBBPool.wrapBB(peekedBuffer.b.slice());
                        m_queuedBuffers.push(splice);
                        m_messagesWritten--;//corrects message count
                        peekedBuffer.b.limit(peekedBuffer.b.position());
                        peekedBuffer.b.position(originalPosition);
                    }
View Full Code Here

Examples of org.voltdb.utils.DBBPool.BBContainer

             */
            if (b.remaining() < DBBPool.MAX_ALLOCATION_SIZE){
                m_queuedWrites.offer(new DeferredSerialization() {
                    @Override
                    public BBContainer serialize(final DBBPool pool) {
                        final BBContainer c = pool.acquire(b.remaining());
                        assert(c.b.isDirect());
                        c.b.put(b);
                        c.b.flip();
                        return c;
                    }
View Full Code Here
TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.