com.tencent.polaris.plugins.connector.common.ServiceUpdateTask Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of polaris-all Show documentation
Show all versions of polaris-all Show documentation
All in one project for polaris-java
The newest version!
/*
* Tencent is pleased to support the open source community by making polaris-java available.
*
* Copyright (C) 2021 THL A29 Limited, a Tencent company. All rights reserved.
*
* Licensed under the BSD 3-Clause License (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://opensource.org/licenses/BSD-3-Clause
*
* 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 com.tencent.polaris.plugins.connector.common;
import com.tencent.polaris.api.config.global.ClusterType;
import com.tencent.polaris.api.plugin.server.EventHandler;
import com.tencent.polaris.api.plugin.server.ServerEvent;
import com.tencent.polaris.api.plugin.server.ServiceEventHandler;
import com.tencent.polaris.api.pojo.ServiceEventKey;
import com.tencent.polaris.logging.LoggerFactory;
import com.tencent.polaris.plugins.connector.common.constant.ServiceUpdateTaskConstant.Status;
import com.tencent.polaris.plugins.connector.common.constant.ServiceUpdateTaskConstant.Type;
import org.slf4j.Logger;
import java.util.Random;
import java.util.concurrent.atomic.AtomicLong;
import java.util.concurrent.atomic.AtomicReference;
/**
* Abstract service update task class.
*
* @author Haotian Zhang
*/
public abstract class ServiceUpdateTask implements Runnable, Comparable {
private static final Logger LOG = LoggerFactory.getLogger(ServiceUpdateTask.class);
protected final ServiceEventHandler serviceEventHandler;
protected final DestroyableServerConnector serverConnector;
protected final AtomicReference targetClusterType = new AtomicReference<>();
protected final AtomicReference taskType = new AtomicReference<>();
protected final AtomicReference taskStatus = new AtomicReference<>();
protected final ServiceEventKey serviceEventKey;
protected final AtomicLong lastUpdateTime = new AtomicLong(0);
protected final AtomicLong successUpdates = new AtomicLong(0);
private final long refreshIntervalMs;
private final EventHandler eventHandler;
public ServiceUpdateTask(ServiceEventHandler handler, DestroyableServerConnector connector) {
this.serviceEventHandler = handler;
this.serverConnector = connector;
this.serviceEventKey = handler.getServiceEventKey();
this.refreshIntervalMs = handler.getRefreshIntervalMs() + (new Random()).nextInt(1000);
this.eventHandler = handler.getEventHandler();
taskType.set(Type.FIRST);
taskStatus.set(Status.READY);
targetClusterType.set(handler.getTargetCluster());
}
@Override
public int compareTo(ServiceUpdateTask o) {
return taskType.get().ordinal() - o.taskType.get().ordinal();
}
public ServiceEventKey getServiceEventKey() {
return serviceEventKey;
}
public EventHandler getEventHandler() {
return eventHandler;
}
public ClusterType getTargetClusterType() {
return targetClusterType.get();
}
public boolean setType(Type last, Type current) {
return taskType.compareAndSet(last, current);
}
public boolean setStatus(Status last, Status current, boolean isSpread) {
return taskStatus.compareAndSet(last, current);
}
public boolean setStatus(Status last, Status current) {
return setStatus(last, current, false);
}
public void setLastUpdateTime(long currentTime) {
lastUpdateTime.set(currentTime);
}
public Type getTaskType() {
return taskType.get();
}
public void retry() {
serverConnector.retryServiceUpdateTask(this);
}
@Override
public void run() {
try {
execute();
} catch (Throwable throwable) {
handle(throwable);
}
}
/**
* Business to be executed.
*/
public void execute() {
}
/**
* Business with serviceUpdateTask to be executed.
*/
public void execute(ServiceUpdateTask serviceUpdateTask) {
}
/**
* Throwable to be handled.
*
* @param throwable
*/
protected abstract void handle(Throwable throwable);
public abstract boolean notifyServerEvent(ServerEvent serverEvent);
public Status getTaskStatus() {
return taskStatus.get();
}
/**
* 加入调度队列
*/
public void addUpdateTaskSet() {
if (taskType.compareAndSet(Type.FIRST, Type.LONG_RUNNING)) {
targetClusterType.set(ClusterType.SERVICE_DISCOVER_CLUSTER);
serverConnector.addLongRunningTask(this);
LOG.info("[ServerConnector]task for service {} has been scheduled updated", this);
}
}
/**
* 判断是否需要更新
*
* @return boolean
*/
public boolean needUpdate() {
if (taskType.get() != Type.LONG_RUNNING || taskStatus.get() != Status.READY) {
return false;
}
long nowMs = System.currentTimeMillis();
return nowMs - lastUpdateTime.get() >= refreshIntervalMs;
}
@Override
public String toString() {
return "ServiceUpdateTask{" +
"serviceEventHandler=" + serviceEventHandler +
", serverConnector=" + serverConnector +
", targetClusterType=" + targetClusterType.get() +
", taskType=" + taskType.get() +
", taskStatus=" + taskStatus.get() +
", serviceEventKey=" + serviceEventKey +
", lastUpdateTime=" + lastUpdateTime +
", successUpdates=" + successUpdates +
", refreshIntervalMs=" + refreshIntervalMs +
", eventHandler=" + eventHandler +
'}';
}
public long getRefreshIntervalMs() {
return refreshIntervalMs;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy