All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.apache.activemq.artemis.shaded.org.jgroups.protocols.LocalTransport Maven / Gradle / Ivy

There is a newer version: 2.33.0
Show newest version
package org.apache.activemq.artemis.shaded.org.jgroups.protocols;

import org.apache.activemq.artemis.shaded.org.jgroups.Address;
import org.apache.activemq.artemis.shaded.org.jgroups.View;

/**
 * A local transport is used for sending messages only to single (or all) members of the same host.
 * @author Bela Ban
 * @since  5.2.0
 */
public interface LocalTransport {
    /**
     * Calls after the local transport has been created.
     * @param transport A reference to TP
     */
    LocalTransport init(TP transport) throws Exception;
    LocalTransport start() throws Exception;
    LocalTransport stop();
    LocalTransport destroy();
    LocalTransport resetStats();

    LocalTransport viewChange(View v);

    /** Returns true if addr is a local member, false otherwise */
    boolean isLocalMember(Address addr);

    /**
     * Sends a message to a given local member. The caller should check before whether dest is a local member;
     * an implementation is not required to do so, but may nevertheless perform the check (and throw an
     * exception if the destination is not local).
     * @param dest The address of the member to which to send the message. Must be non-null
     * @param buf The buffer to send
     * @param offset The offset at which the data starts
     * @param length The number of bytes to send
     * @exception Exception Thrown when the send failed, e.g. when dest isn't a local address.
     */
    void sendTo(Address dest, byte[] buf, int offset, int length) throws Exception;

    /**
     * Sends a message to all local members.
     * @param buf The buffer to send
     * @param offset The offset at which the data starts
     * @param length The number of bytes to send
     * @exception Exception Thrown when the send failed.
     */
    void sendToAll(byte[] buf, int offset, int length) throws Exception;
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy