org.jboss.as.host.controller.ProcessControllerConnectionService Maven / Gradle / Ivy
/*
* JBoss, Home of Professional Open Source.
* Copyright 2011, Red Hat, Inc., and individual contributors
* as indicated by the @author tags. See the copyright.txt file in the
* distribution for a full listing of individual contributors.
*
* This is free software; you can redistribute it and/or modify it
* under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation; either version 2.1 of
* the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this software; if not, write to the Free
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
*/
package org.jboss.as.host.controller;
import static java.security.AccessController.doPrivileged;
import static org.jboss.as.host.controller.HostControllerMessages.MESSAGES;
import javax.net.SocketFactory;
import java.io.IOException;
import java.net.InetSocketAddress;
import java.util.Map;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.ThreadFactory;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
import org.jboss.as.process.ProcessControllerClient;
import org.jboss.as.process.ProcessInfo;
import org.jboss.as.process.ProcessMessageHandler;
import org.jboss.as.process.protocol.ProtocolClient;
import org.jboss.as.protocol.StreamUtils;
import org.wildfly.security.manager.action.GetAccessControlContextAction;
import org.jboss.msc.service.Service;
import org.jboss.msc.service.ServiceName;
import org.jboss.msc.service.StartContext;
import org.jboss.msc.service.StartException;
import org.jboss.msc.service.StopContext;
import org.jboss.threads.JBossThreadFactory;
/**
* Provides a client for interacting with the process controller.
*
* @author Emanuel Muckenhuber
*/
class ProcessControllerConnectionService implements Service {
static final ServiceName SERVICE_NAME = ServiceName.JBOSS.append("host", "controller", "process-controller-connection");
private final HostControllerEnvironment environment;
private final byte[] authCode;
private volatile ProcessControllerClient client;
private volatile ServerInventory serverInventory;
private static final int WORK_QUEUE_SIZE = 256;
private static final int THREAD_POOL_CORE_SIZE = 1;
private static final int THREAD_POOL_MAX_SIZE = 4;
ProcessControllerConnectionService(final HostControllerEnvironment environment, final byte[] authCode) {
this.environment = environment;
this.authCode = authCode;
}
void setServerInventory(ServerInventory serverInventory) {
this.serverInventory = serverInventory;
}
/** {@inheritDoc} */
@Override
public synchronized void start(StartContext context) throws StartException {
final ProcessControllerClient client;
try {
final ThreadFactory threadFactory = new JBossThreadFactory(new ThreadGroup("ProcessControllerConnection-thread"), Boolean.FALSE, null, "%G - %t", null, null, doPrivileged(GetAccessControlContextAction.getInstance()));
final ThreadPoolExecutor executorService = new ThreadPoolExecutor(THREAD_POOL_CORE_SIZE, THREAD_POOL_MAX_SIZE, 30L, TimeUnit.MILLISECONDS, new LinkedBlockingQueue(WORK_QUEUE_SIZE), threadFactory);
final ProtocolClient.Configuration configuration = new ProtocolClient.Configuration();
configuration.setReadExecutor(executorService);
configuration.setServerAddress(new InetSocketAddress(environment.getProcessControllerAddress(), environment.getProcessControllerPort().intValue()));
configuration.setBindAddress(new InetSocketAddress(environment.getHostControllerAddress(), environment.getHostControllerPort()));
configuration.setThreadFactory(threadFactory);
configuration.setSocketFactory(SocketFactory.getDefault());
client = ProcessControllerClient.connect(configuration, authCode, new ProcessMessageHandler() {
@Override
public void handleProcessAdded(final ProcessControllerClient client, final String processName) {
if (serverInventory == null){
throw MESSAGES.noServerInventory();
}
if(ManagedServer.isServerProcess(processName)) {
serverInventory.serverProcessAdded(processName);
}
}
@Override
public void handleProcessStarted(final ProcessControllerClient client, final String processName) {
if (serverInventory == null){
throw MESSAGES.noServerInventory();
}
if(ManagedServer.isServerProcess(processName)) {
serverInventory.serverProcessStarted(processName);
}
}
@Override
public void handleProcessStopped(final ProcessControllerClient client, final String processName, final long uptimeMillis) {
if (serverInventory == null){
throw MESSAGES.noServerInventory();
}
if(ManagedServer.isServerProcess(processName)) {
serverInventory.serverProcessStopped(processName);
}
}
@Override
public void handleProcessRemoved(final ProcessControllerClient client, final String processName) {
if (serverInventory == null){
throw MESSAGES.noServerInventory();
}
if(ManagedServer.isServerProcess(processName)) {
serverInventory.serverProcessRemoved(processName);
}
}
@Override
public void handleProcessInventory(final ProcessControllerClient client, final Map inventory) {
if (serverInventory == null){
throw MESSAGES.noServerInventory();
}
serverInventory.processInventory(inventory);
}
@Override
public void handleConnectionShutdown(final ProcessControllerClient client) {
if(serverInventory == null) {
return;
}
serverInventory.connectionFinished();
}
@Override
public void handleConnectionFailure(final ProcessControllerClient client, final IOException cause) {
if(serverInventory == null) {
return;
}
serverInventory.connectionFinished();
}
@Override
public void handleConnectionFinished(final ProcessControllerClient client) {
if(serverInventory == null) {
return;
}
serverInventory.connectionFinished();
}
@Override
public void handleOperationFailed(ProcessControllerClient client, OperationType operation, String processName) {
if (serverInventory == null){
throw MESSAGES.noServerInventory();
}
if(ManagedServer.isServerProcess(processName)) {
serverInventory.operationFailed(processName, operation);
}
}
});
} catch(IOException e) {
throw new StartException(e);
}
this.client = client;
}
/** {@inheritDoc} */
@Override
public synchronized void stop(StopContext context) {
final ProcessControllerClient client = this.client;
this.client = null;
StreamUtils.safeClose(client);
}
/** {@inheritDoc} */
@Override
public synchronized ProcessControllerConnectionService getValue() throws IllegalStateException, IllegalArgumentException {
return this;
}
public synchronized ProcessControllerClient getClient() throws IllegalStateException, IllegalArgumentException {
final ProcessControllerClient client = this.client;
if(client == null) {
throw new IllegalStateException();
}
return client;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy