![JAR search and dependency download from the Maven repository](/logo.png)
azkaban.executor.Executor Maven / Gradle / Ivy
/*
* Copyright 2014 LinkedIn Corp.
*
* 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 azkaban.executor;
import azkaban.utils.Utils;
import java.util.Date;
/**
* Class to represent an AzkabanExecutorServer details for ExecutorManager
*
* @author gaggarwa
*/
public class Executor implements Comparable {
private final int id;
private final String host;
private final int port;
private boolean isActive;
// cached copy of the latest statistics from the executor.
private ExecutorInfo cachedExecutorStats;
private Date lastStatsUpdatedTime;
/**
*
* Construct an Executor Object
* Note: port should be a within unsigned 2 byte
* integer range
*
*/
public Executor(final int id, final String host, final int port, final boolean isActive) {
if (!Utils.isValidPort(port)) {
throw new IllegalArgumentException(String.format(
"Invalid port number %d for host %s, executor_id %d", port, host, id));
}
this.id = id;
this.host = host;
this.port = port;
this.isActive = isActive;
}
@Override
public int hashCode() {
final int prime = 31;
int result = 1;
result = prime * result + (this.isActive ? 1231 : 1237);
result = prime * result + ((this.host == null) ? 0 : this.host.hashCode());
result = prime * result + this.id;
result = prime * result + this.port;
return result;
}
@Override
public boolean equals(final Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof Executor)) {
return false;
}
final Executor other = (Executor) obj;
if (this.isActive != other.isActive) {
return false;
}
if (this.host == null) {
if (other.host != null) {
return false;
}
} else if (!this.host.equals(other.host)) {
return false;
}
if (this.id != other.id) {
return false;
}
if (this.port != other.port) {
return false;
}
return true;
}
@Override
public String toString() {
return String.format("%s:%s (id: %s)",
null == this.host || this.host.length() == 0 ? "(empty)" : this.host,
this.port, this.id);
}
public String getHost() {
return this.host;
}
public int getPort() {
return this.port;
}
public boolean isActive() {
return this.isActive;
}
public void setActive(final boolean isActive) {
this.isActive = isActive;
}
public int getId() {
return this.id;
}
public ExecutorInfo getExecutorInfo() {
return this.cachedExecutorStats;
}
public void setExecutorInfo(final ExecutorInfo info) {
this.cachedExecutorStats = info;
this.lastStatsUpdatedTime = new Date();
}
/**
* Gets the timestamp when the executor info is last updated.
*
* @return date object represents the timestamp, null if the executor info of this specific
* executor is never refreshed.
*/
public Date getLastStatsUpdatedTime() {
return this.lastStatsUpdatedTime;
}
@Override
public int compareTo(final Executor o) {
return null == o ? 1 : this.hashCode() - o.hashCode();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy