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

alluxio.membership.DefaultServiceEntity Maven / Gradle / Ivy

There is a newer version: 313
Show newest version
/*
 * The Alluxio Open Foundation licenses this work under the Apache License, version 2.0
 * (the "License"). You may not use this work except in compliance with the License, which is
 * available at www.apache.org/licenses/LICENSE-2.0
 *
 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
 * either express or implied, as more fully set forth in the License.
 *
 * See the NOTICE file distributed with this work for information regarding copyright ownership.
 */

package alluxio.membership;

import com.google.gson.Gson;
import com.google.gson.GsonBuilder;
import com.google.gson.InstanceCreator;
import com.google.gson.annotations.Expose;
import io.etcd.jetcd.support.CloseableClient;

import java.io.ByteArrayInputStream;
import java.io.Closeable;
import java.io.IOException;
import java.io.InputStreamReader;
import java.nio.charset.StandardCharsets;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.concurrent.locks.ReentrantLock;
import javax.annotation.concurrent.GuardedBy;

/**
 * Base Entity class including information to register to Etcd
 * when using EtcdMembershipManager.
 * It will be serialized to JSON format to store on etcd, including
 * only those fields with marked @Expose annotation.
 */
public abstract class DefaultServiceEntity implements Closeable {
  private CloseableClient mKeepAliveClient;
  // (package visibility) to do keep alive(heartbeating),
  // initialized at time of service registration
  private AlluxioEtcdClient.Lease mLease = null;
  // TTL and timeout for lease
  private long mLeaseTTLInSec = AlluxioEtcdClient.DEFAULT_LEASE_TTL_IN_SEC;
  private long mLeaseTimeoutInSec = AlluxioEtcdClient.DEFAULT_TIMEOUT_IN_SEC;
  @Expose
  @com.google.gson.annotations.SerializedName("ServiceEntityName")
  protected String mServiceEntityName; // unique service alias
  // revision number of kv pair of registered entity on etcd, used for CASupdate
  protected long mRevision;
  public final ReentrantLock mLock = new ReentrantLock();
  // For {@link ServiceDiscoveryRecipe#RetryKeepAliveObserver}
  // to act on events such as lease keepalive connection ended or errors.
  // {@link ServiceDiscoveryRecipe#checkAllForReconnect} will periodically
  // check and resume the connection.
  public AtomicBoolean mNeedReconnect = new AtomicBoolean(false);

  /**
   * CTOR for DefaultServiceEntity.
   */
  public DefaultServiceEntity() {}

  /**
   * CTOR for ServiceEntity with given ServiceEntity name.
   * @param serviceEntityName
   */
  public DefaultServiceEntity(String serviceEntityName) {
    mServiceEntityName = serviceEntityName;
  }

  /**
   * Get service entity name.
   * @return service entity name
   */
  public String getServiceEntityName() {
    return mServiceEntityName;
  }

  /**
   * Set keep alive client.
   * @param keepAliveClient
   */
  public void setKeepAliveClient(CloseableClient keepAliveClient) {
    mKeepAliveClient = keepAliveClient;
  }

  /**
   * Get the keepalive client instance.
   * @return jetcd keepalive client
   */
  public CloseableClient getKeepAliveClient() {
    return mKeepAliveClient;
  }

  /**
   * @return lease
   */
  public AlluxioEtcdClient.Lease getLease() {
    return mLease;
  }

  /**
   * Set lease.
   * @param lease
   */
  @GuardedBy("mLock")
  public void setLease(AlluxioEtcdClient.Lease lease) {
    mLease = lease;
  }

  /**
   * Get the revision number of currently registered DefaultServiceEntity
   * on ETCD.
   * @return revision number
   */
  public long getRevisionNumber() {
    return mRevision;
  }

  /**
   * Set revision number.
   * @param revisionNumber
   */
  public void setRevisionNumber(long revisionNumber) {
    mRevision = revisionNumber;
  }

  /**
   * @return lock for atomically modifying certain fields
   */
  ReentrantLock getLock() {
    return mLock;
  }

  /**
   * Get the TTL for lease in seconds.
   * @return TTL
   */
  public long getLeaseTTLInSec() {
    return mLeaseTTLInSec;
  }

  /**
   * Set the TTL for lease in seconds.
   * @param ttl
   */
  public void setLeaseTTLInSec(long ttl) {
    mLeaseTTLInSec = ttl;
  }

  /**
   * Get the timeout for lease in seconds.
   * @return timeout
   */
  public long getLeaseTimeoutInSec() {
    return mLeaseTimeoutInSec;
  }

  /**
   * Set the timeout for lease in seconds.
   * @param timeout
   */
  public void setLeaseTimeoutInSec(long timeout) {
    mLeaseTimeoutInSec = timeout;
  }

  /**
   * Serialize the ServiceEntity to bytes.
   * @return serialized data
   */
  public byte[] serialize() {
    Gson gson = new GsonBuilder()
        .excludeFieldsWithoutExposeAnnotation()
        .create();
    return gson.toJson(this).getBytes(StandardCharsets.UTF_8);
  }

  /**
   * Deserialize the ServiceEntity from bytes.
   * @param buf
   */
  public void deserialize(byte[] buf) {
    DefaultServiceEntity obj = this;
    InstanceCreator creator = type -> obj;
    Gson gson = new GsonBuilder()
        .excludeFieldsWithoutExposeAnnotation()
        .registerTypeAdapter(DefaultServiceEntity.class, creator)
        .create();
    gson.fromJson(new InputStreamReader(new ByteArrayInputStream(buf)), DefaultServiceEntity.class);
  }

  @Override
  public void close() throws IOException {
    if (mKeepAliveClient != null) {
      mKeepAliveClient.close();
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy