/* * Copyright 2014-2017 Real Logic Ltd. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package io.aeron.samples; import io.aeron.Aeron; import io.aeron.Publication; import io.aeron.driver.MediaDriver; import org.agrona.BufferUtil; import org.agrona.CloseHelper; import org.agrona.concurrent.UnsafeBuffer; import java.util.concurrent.TimeUnit; /** * Basic Aeron publisher application * This publisher sends a fixed number of fixed-length messages * on a channel and stream ID, then lingers to allow any consumers * that may have experienced loss a chance to NAK for and recover * any missing data. * The default values for number of messages, channel, and stream ID are * defined in {@link SampleConfiguration} and can be overridden by * setting their corresponding properties via the command-line; e.g.: * -Daeron.sample.channel=aeron:udp?endpoint=localhost:5555 -Daeron.sample.streamId=20 */ public class BasicPublisher { private static final int STREAM_ID = SampleConfiguration.STREAM_ID; private static final String CHANNEL = SampleConfiguration.CHANNEL; private static final long NUMBER_OF_MESSAGES = SampleConfiguration.NUMBER_OF_MESSAGES; private static final long LINGER_TIMEOUT_MS = SampleConfiguration.LINGER_TIMEOUT_MS; private static final boolean EMBEDDED_MEDIA_DRIVER = SampleConfiguration.EMBEDDED_MEDIA_DRIVER; private static final UnsafeBuffer BUFFER = new UnsafeBuffer(BufferUtil.allocateDirectAligned(256, 64)); public static void main(final String[] args) throws Exception { System.out.println("Publishing to " + CHANNEL + " on stream Id " + STREAM_ID); // If configured to do so, create an embedded media driver within this application rather // than relying on an external one. final MediaDriver driver = EMBEDDED_MEDIA_DRIVER ? MediaDriver.launchEmbedded() : null; final Aeron.Context ctx = new Aeron.Context(); if (EMBEDDED_MEDIA_DRIVER) { ctx.aeronDirectoryName(driver.aeronDirectoryName()); } // Connect a new Aeron instance to the media driver and create a publication on // the given channel and stream ID. // The Aeron and Publication classes implement "AutoCloseable" and will automatically // clean up resources when this try block is finished try (Aeron aeron = Aeron.connect(ctx); Publication publication = aeron.addPublication(CHANNEL, STREAM_ID)) { for (int i = 0; i < NUMBER_OF_MESSAGES; i++) { final String message = "Hello World! " + i; final byte[] messageBytes = message.getBytes(); BUFFER.putBytes(0, messageBytes); System.out.print("Offering " + i + "/" + NUMBER_OF_MESSAGES + " - "); final long result = publication.offer(BUFFER, 0, messageBytes.length); if (result < 0L) { if (result == Publication.BACK_PRESSURED) { System.out.println("Offer failed due to back pressure"); } else if (result == Publication.NOT_CONNECTED) { System.out.println("Offer failed because publisher is not connected to subscriber"); } else if (result == Publication.ADMIN_ACTION) { System.out.println("Offer failed because of an administration action in the system"); } else if (result == Publication.CLOSED) { System.out.println("Offer failed publication is closed"); break; } else { System.out.println("Offer failed due to unknown reason"); } } else { System.out.println("yay!"); } if (!publication.isConnected()) { System.out.println("No active subscribers detected"); } Thread.sleep(TimeUnit.SECONDS.toMillis(1)); } System.out.println("Done sending."); if (0 < LINGER_TIMEOUT_MS) { System.out.println("Lingering for " + LINGER_TIMEOUT_MS + " milliseconds..."); Thread.sleep(LINGER_TIMEOUT_MS); } } CloseHelper.quietClose(driver); } }