Package co.paralleluniverse.galaxy.server

Examples of co.paralleluniverse.galaxy.server.MainMemoryEntry


                monitor.addObjectServed();
                store.write(id, msg.getNode(), 1, new byte[0], null);
                send(Message.PUTX(msg, id, new short[0], 1, null));
                return true;
            } else if ((owner = store.casOwner(id, SERVER, msg.getNode())) == msg.getNode()) { // if owner is server, then transfer ownership
                MainMemoryEntry entry = store.read(id);
                if (LOG.isDebugEnabled())
                    LOG.debug("Owner of line {} is now node {} (previously owned by server)", hex(id), msg.getNode());
                monitor.addOwnerWrite();
                monitor.addObjectServed();
                send(Message.PUTX(msg, id, new short[0], entry.version, ByteBuffer.wrap(entry.data)));
View Full Code Here


                rs = getLine.executeQuery();
                rs.next();
                final long version = rs.getLong(1);
                final byte[] data = rs.getBytes(2);
                conn.commit();
                return new MainMemoryEntry(version, data);
            } finally {
                if (rs != null)
                    rs.close();
            }
        } catch (SQLException e) {
View Full Code Here

     * When GET is received and server is owner then reply with PUTX
     */
    @Test
    public void whenGETAndServerIsOwnerThenReplyPUTX() throws Exception {
        when(store.casOwner(id(154), sh(0), sh(10))).thenReturn(sh(10));
        when(store.read(id(154))).thenReturn(new MainMemoryEntry(1234, new byte[]{3, 4, 5}));
        final LineMessage get = Message.GET(sh(10), id(154));
        mm.receive(get);

        verify(store).casOwner(id(154), sh(0), sh(10));
        verify(store).read(id(154));
View Full Code Here

            try (ResultSet rs = getLine.executeQuery()) {
                rs.next();
                final long version = rs.getLong(1);
                final byte[] data = rs.getBytes(2);
                conn.commit();
                return new MainMemoryEntry(version, data);
            }
        } catch (SQLException e) {
            throw Throwables.propagate(e);
        }
    }
View Full Code Here

                monitor.addObjectServed();
                store.write(id, msg.getNode(), 1, new byte[0], null);
                send(Message.PUTX(msg, id, new short[0], 0, 1, null));
                return true;
            } else if ((owner = store.casOwner(id, SERVER, msg.getNode())) == msg.getNode()) { // if owner is server, then transfer ownership
                MainMemoryEntry entry = store.read(id);
                if (LOG.isDebugEnabled())
                    LOG.debug("Owner of line {} is now node {} (previously owned by server)", hex(id), msg.getNode());
                monitor.addOwnerWrite();
                monitor.addObjectServed();
                send(Message.PUTX(msg, id, new short[0], 0, entry.version, ByteBuffer.wrap(entry.data)));
View Full Code Here

        if (LOG.isDebugEnabled())
            LOG.debug("WRITE " + hex(id) + " ver: " + version + " data: " + (data != null ? "(" + data.length + " bytes)" : "null"));

        final DatabaseEntry key = new DatabaseEntry(Longs.toByteArray(id));
        final DatabaseEntry dbEntry = new DatabaseEntry();
        entryBinding.objectToEntry(new MainMemoryEntry(version, data), dbEntry);

        mainStore.put((Transaction) txn, key, dbEntry);
        // try to write owner, but only if nonexistent (i.e will happen at first put only)
        ownerDirectory.putNoOverwrite((Transaction) txn, key, new DatabaseEntry(Shorts.toByteArray(owner)));
    }
View Full Code Here

    @Override
    public MainMemoryEntry read(long id) {
        final DatabaseEntry dbEntry = new DatabaseEntry();
        OperationStatus status = mainStore.get(null, new DatabaseEntry(Longs.toByteArray(id)), dbEntry, LockMode.READ_COMMITTED);
        if (status == OperationStatus.SUCCESS) {
            final MainMemoryEntry entry = entryBinding.entryToObject(dbEntry);
            return entry;
        } else
            return null;
    }
View Full Code Here

        final DatabaseEntry key = new DatabaseEntry();
        final DatabaseEntry value = new DatabaseEntry();
        try (Cursor cursor = mainStore.openCursor(null, CursorConfig.DEFAULT)) {
            while (cursor.getNext(key, value, LockMode.DEFAULT) == OperationStatus.SUCCESS) {
                long id = Longs.fromByteArray(key.getData());
                final MainMemoryEntry entry = entryBinding.entryToObject(value);
                ps.println("Id : " + hex(id) + " version: " + entry.version + " data: (" + entry.data.length + " bytes).");
            }
        }
    }
View Full Code Here

            final long version = in.readLong();
            //final int dataLength = in.readUnsignedShort();
            final int dataLength = in.getBufferLength() - in.getBufferOffset();
            final byte[] data = new byte[dataLength];
            in.readFast(data);
            return new MainMemoryEntry(version, data);
        }
View Full Code Here

            final long version = in.readLong();
            //final int dataLength = in.readUnsignedShort();
            final int dataLength = in.getBufferLength() - in.getBufferOffset();
            final byte[] data = new byte[dataLength];
            in.readFast(data);
            return new MainMemoryEntry(version, data);
        }
View Full Code Here

TOP

Related Classes of co.paralleluniverse.galaxy.server.MainMemoryEntry

Copyright © 2018 www.massapicom. 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.