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

io.scalecube.examples.CustomMetadataEncodingExample Maven / Gradle / Ivy

There is a newer version: 2.7.1
Show newest version
package io.scalecube.examples;

import io.scalecube.cluster.Cluster;
import io.scalecube.cluster.ClusterImpl;
import io.scalecube.cluster.metadata.MetadataCodec;
import io.scalecube.transport.netty.websocket.WebsocketTransportFactory;
import java.nio.ByteBuffer;
import java.util.concurrent.TimeUnit;

public class CustomMetadataEncodingExample {

  /** Main method. */
  public static void main(String[] args) throws Exception {
    // Start seed cluster member Alice
    Cluster alice =
        new ClusterImpl()
            .transportFactory(WebsocketTransportFactory::new)
            .config(opts -> opts.metadataCodec(new LongMetadataCodec()))
            .startAwait();
    System.out.println(
        "[" + alice.member().id() + "] Alice's metadata: " + alice.metadata().orElse(null));

    Cluster joe =
        new ClusterImpl()
            .transportFactory(WebsocketTransportFactory::new)
            .config(opts -> opts.metadataCodec(new LongMetadataCodec()).metadata(123L))
            .membership(opts -> opts.seedMembers(alice.address()))
            .startAwait();
    System.out.println(
        "[" + joe.member().id() + "] Joe's metadata: " + joe.metadata().orElse(null));

    Cluster bob =
        new ClusterImpl()
            .transportFactory(WebsocketTransportFactory::new)
            .config(opts -> opts.metadataCodec(new LongMetadataCodec()).metadata(456L))
            .membership(opts -> opts.seedMembers(alice.address()))
            .startAwait();
    System.out.println(
        "[" + bob.member().id() + "] Bob's metadata: " + bob.metadata().orElse(null));

    TimeUnit.SECONDS.sleep(3);

    alice
        .otherMembers()
        .forEach(
            member -> {
              Long metadata = (Long) alice.metadata(member).orElse(null);
              System.out.println(
                  "Alice knows [" + member.id() + "] has `" + metadata + "` as a metadata");
            });

    joe.otherMembers()
        .forEach(
            member -> {
              Long metadata = (Long) alice.metadata(member).orElse(null);
              System.out.println(
                  "Joe knows [" + member.id() + "] has `" + metadata + "` as a metadata");
            });

    bob.otherMembers()
        .forEach(
            member -> {
              Long metadata = (Long) alice.metadata(member).orElse(null);
              System.out.println(
                  "Bob knows [" + member.id() + "] has `" + metadata + "` as a metadata");
            });

    TimeUnit.SECONDS.sleep(3);
  }

  static class LongMetadataCodec implements MetadataCodec {

    @Override
    public Object deserialize(ByteBuffer buffer) {
      return buffer.remaining() == 0 ? null : buffer.getLong();
    }

    @Override
    public ByteBuffer serialize(Object metadata) {
      if (metadata == null) {
        return null;
      }
      ByteBuffer buffer = ByteBuffer.allocate(Long.BYTES);
      buffer.putLong((Long) metadata);
      buffer.flip();
      return buffer;
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy