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

org.jboss.as.host.controller.HostControllerEnvironment Maven / Gradle / Ivy

There is a newer version: 8.2.1.Final
Show newest version
/*
 * JBoss, Home of Professional Open Source.
 * Copyright 2012, 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 org.jboss.as.host.controller.HostControllerMessages.MESSAGES;

import java.io.File;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.util.Collections;
import java.util.Map;

import org.jboss.as.controller.RunningMode;
import org.jboss.as.controller.operations.common.ProcessEnvironment;
import org.jboss.as.controller.persistence.ConfigurationFile;
import org.jboss.as.network.NetworkUtils;
import org.jboss.as.process.DefaultJvmUtils;
import org.jboss.as.version.ProductConfig;
import org.wildfly.security.manager.WildFlySecurityManager;

/**
 * Encapsulates the runtime environment for a host controller.
 * This is parsed when the host controller is initially started, a process reload reuses the host controller environment.
 *
 * @author Brian Stansberry
 */
public class HostControllerEnvironment extends ProcessEnvironment {


    /////////////////////////////////////////////////////////////////////////
    //                   Configuration Value Identifiers                   //
    /////////////////////////////////////////////////////////////////////////

    /**
     * Constant that holds the name of the system property
     * for specifying the {@link #getHomeDir() home directory}.
     */
    public static final String HOME_DIR = "jboss.home.dir";

    /**
     * Constant that holds the name of the system property for specifying the directory returned from
     * {@link #getModulesDir()}.
     *
     * 

* Defaults to HOME_DIR/modules/ *

* * This system property has no real meaning and should not be regarded as providing any sort of useful * information. The "modules" directory is the default location from which JBoss Modules looks to find * modules. However, this behavior is in no way controlled by this system property, nor is it guaranteed that * modules will be loaded from only one directory, nor is it guaranteed that the "modules" directory will be one * of the directories used. Finally, the structure and contents of any directories from which JBoss Modules loads * resources is not something available from this class. Users wishing to interact with the modular classloading * system should use the APIs provided by JBoss Modules * * * @deprecated has no useful meaning */ @Deprecated public static final String MODULES_DIR = "jboss.modules.dir"; /** * Constant that holds the name of the system property * for specifying {@link #getDomainBaseDir()} the domain base directory}. * *

Defaults to HOME_DIR/domain. */ public static final String DOMAIN_BASE_DIR = "jboss.domain.base.dir"; /** * Constant that holds the name of the system property * for specifying {@link #getDomainConfigurationDir()} the domain configuration directory}. * *

Defaults to DOMAIN_BASE_DIR/configuration . */ public static final String DOMAIN_CONFIG_DIR = "jboss.domain.config.dir"; /** * Constant that holds the name of the system property * for specifying {@link #getDomainDataDir()} the domain data directory}. * *

Defaults to DOMAIN_BASE_DIR/data. */ public static final String DOMAIN_DATA_DIR = "jboss.domain.data.dir"; /** * Constant that holds the name of the system property * for specifying {@link #getDomainContentDir()} the domain content repository directory}. * *

Defaults to DOMAIN_DATA_DIR/content. */ public static final String DOMAIN_CONTENT_DIR = "jboss.domain.content.dir"; /** * Deprecated variant of {@link #DOMAIN_CONTENT_DIR}. * * @deprecated use {@link #DOMAIN_CONTENT_DIR} */ @Deprecated public static final String DOMAIN_DEPLOYMENT_DIR = "jboss.domain.deployment.dir"; /** * Constant that holds the name of the system property * for specifying {@link #getDomainLogDir()} the domain log directory}. * *

Defaults to DOMAIN_BASE_DIR/log. */ public static final String DOMAIN_LOG_DIR = "jboss.domain.log.dir"; /** * Constant that holds the name of the system property * for specifying {@link #getDomainServersDir()} the managed domain server parent directory}. * *

Defaults to DOMAIN_BASE_DIR/servers. */ public static final String DOMAIN_SERVERS_DIR = "jboss.domain.servers.dir"; /** * Constant that holds the name of the system property * for specifying {@link #getDomainTempDir()} the domain temporary file storage directory}. * *

Defaults to DOMAIN_BASE_DIR/tmp . */ public static final String DOMAIN_TEMP_DIR = "jboss.domain.temp.dir"; /** * Constant that holds the name of the system property for specifying the local part of the name of the host that this * server is running on. */ public static final String HOST_NAME = "jboss.host.name"; /** * Constant that holds the name of the system property for specifying the fully-qualified name of the host that this server * is running on. */ public static final String QUALIFIED_HOST_NAME = "jboss.qualified.host.name"; /** * Common alias between domain and standalone mode. Uses jboss.domain.temp.dir on domain mode, * and jboss.server.temp.dir on standalone server mode. */ public static final String CONTROLLER_TEMP_DIR = "jboss.controller.temp.dir"; /** * The default system property used to store bind address information from the command-line (-b). */ public static final String JBOSS_BIND_ADDRESS = "jboss.bind.address"; /** * Prefix for the system property used to store qualified bind address information from the command-line (-bxxx). */ public static final String JBOSS_BIND_ADDRESS_PREFIX = JBOSS_BIND_ADDRESS + "."; /** * The default system property used to store multicast address information from the command-line (-u). */ public static final String JBOSS_DEFAULT_MULTICAST_ADDRESS = "jboss.default.multicast.address"; /** * The default system property used to store the master Host Controller's native management interface address * from the command line. */ public static final String JBOSS_DOMAIN_MASTER_ADDRESS = "jboss.domain.master.address"; /** * The default system property used to store the master Host Controller's native of the master port from the command line. */ public static final String JBOSS_DOMAIN_MASTER_PORT = "jboss.domain.master.port"; /** * The system property used to store the name of the default domain configuration file. If not set, * the default domain configuration file is "domain.xml". The default domain configuration file is only * relevant if the user does not use the {@code -c} or {@code --domain-config} command line switches * to explicitly set the domain configuration file. */ public static final String JBOSS_DOMAIN_DEFAULT_CONFIG = "jboss.domain.default.config"; /** * The system property used to store the name of the default host configuration file. If not set, * the default domain configuration file is "host.xml". The default domain configuration file is only * relevant if the user does not use the {@code --host-config} command line switch * to explicitly set the host configuration file. */ public static final String JBOSS_HOST_DEFAULT_CONFIG = "jboss.host.default.config"; private final Map hostSystemProperties; private final InetAddress processControllerAddress; private final Integer processControllerPort; private final InetAddress hostControllerAddress; private final Integer hostControllerPort; private final File homeDir; private final File modulesDir; private final File domainBaseDir; private final File domainConfigurationDir; private final ConfigurationFile hostConfigurationFile; private final String domainConfig; private final String initialDomainConfig; private ConfigurationFile domainConfigurationFile; private final File domainContentDir; private final File domainDataDir; private final File domainLogDir; private final File domainServersDir; private final File domainTempDir; private final File defaultJVM; private final boolean isRestart; private final boolean backupDomainFiles; private final boolean useCachedDc; private final RunningMode initialRunningMode; private final ProductConfig productConfig; private final String qualifiedHostName; private final String hostName; private final String modulePath; private volatile String hostControllerName; private final HostRunningModeControl runningModeControl; public HostControllerEnvironment(Map hostSystemProperties, boolean isRestart, String modulePath, InetAddress processControllerAddress, Integer processControllerPort, InetAddress hostControllerAddress, Integer hostControllerPort, String defaultJVM, String domainConfig, String initialDomainConfig, String hostConfig, String initialHostConfig, RunningMode initialRunningMode, boolean backupDomainFiles, boolean useCachedDc, ProductConfig productConfig) { if (hostSystemProperties == null) { throw MESSAGES.nullVar("hostSystemProperties"); } this.hostSystemProperties = Collections.unmodifiableMap(hostSystemProperties); if (modulePath == null) { throw MESSAGES.nullVar("modulePath"); } if (processControllerAddress == null) { throw MESSAGES.nullVar("processControllerAddress"); } if (processControllerPort == null) { throw MESSAGES.nullVar("processControllerPort"); } if (hostControllerAddress == null) { throw MESSAGES.nullVar("hostControllerAddress"); } if (hostControllerPort == null) { throw MESSAGES.nullVar("hostControllerPort"); } this.processControllerPort = processControllerPort; this.processControllerAddress = processControllerAddress; this.hostControllerAddress = hostControllerAddress; this.hostControllerPort = hostControllerPort; this.isRestart = isRestart; this.modulePath = modulePath; this.initialRunningMode = initialRunningMode; this.runningModeControl = new HostRunningModeControl(initialRunningMode, RestartMode.SERVERS); // Calculate host and default server name String hostName = hostSystemProperties.get(HOST_NAME); String qualifiedHostName = hostSystemProperties.get(QUALIFIED_HOST_NAME); if (qualifiedHostName == null) { Map env = null; // if host name is specified, don't pick a qualified host name that isn't related to it qualifiedHostName = hostName; if (qualifiedHostName == null) { env = WildFlySecurityManager.getSystemEnvironmentPrivileged(); // POSIX-like OSes including Mac should have this set qualifiedHostName = env.get("HOSTNAME"); } if (qualifiedHostName == null) { // Certain versions of Windows qualifiedHostName = env.get("COMPUTERNAME"); } if (qualifiedHostName == null) { try { qualifiedHostName = NetworkUtils.canonize(InetAddress.getLocalHost().getHostName()); } catch (UnknownHostException e) { qualifiedHostName = null; } } if (qualifiedHostName != null && qualifiedHostName.matches("^\\d+\\.\\d+\\.\\d+\\.\\d+$|:")) { // IP address is not acceptable qualifiedHostName = null; } if (qualifiedHostName == null) { // Give up qualifiedHostName = "unknown-host.unknown-domain"; } else { qualifiedHostName = qualifiedHostName.trim().toLowerCase(); } } this.qualifiedHostName = qualifiedHostName; this.hostControllerName = qualifiedHostName; if (hostName == null) { // Use the host part of the qualified host name final int idx = qualifiedHostName.indexOf('.'); hostName = idx == -1 ? qualifiedHostName : qualifiedHostName.substring(0, idx); } this.hostName = hostName; File home = getFileFromProperty(HOME_DIR); this.homeDir = home; if (homeDir == null) { throw MESSAGES.missingHomeDirConfiguration(HOME_DIR); } if (!homeDir.exists() || !homeDir.isDirectory()) { throw MESSAGES.homeDirectoryDoesNotExist(homeDir); } WildFlySecurityManager.setPropertyPrivileged(HOME_DIR, this.homeDir.getAbsolutePath()); @SuppressWarnings("deprecation") File tmp = getFileFromProperty(MODULES_DIR); if (tmp == null) { tmp = new File(this.homeDir, "modules"); } else if (!tmp.exists() || !tmp.isDirectory()) { throw MESSAGES.modulesDirectoryDoesNotExist(tmp); } this.modulesDir = tmp; @SuppressWarnings("deprecation") String deprecatedModDir = MODULES_DIR; WildFlySecurityManager.setPropertyPrivileged(deprecatedModDir, this.modulesDir.getAbsolutePath()); tmp = getFileFromProperty(DOMAIN_BASE_DIR); if (tmp == null) { tmp = new File(this.homeDir, "domain"); } if (!tmp.exists()) { throw MESSAGES.domainBaseDirectoryDoesNotExist(tmp); } else if (!tmp.isDirectory()) { throw MESSAGES.domainBaseDirectoryIsNotADirectory(tmp); } this.domainBaseDir = tmp; WildFlySecurityManager.setPropertyPrivileged(DOMAIN_BASE_DIR, this.domainBaseDir.getAbsolutePath()); tmp = getFileFromProperty(DOMAIN_CONFIG_DIR); if (tmp == null) { tmp = new File(this.domainBaseDir, "configuration"); } if (!tmp.exists() || !tmp.isDirectory()) { throw MESSAGES.configDirectoryDoesNotExist(tmp); } this.domainConfigurationDir = tmp; WildFlySecurityManager.setPropertyPrivileged(DOMAIN_CONFIG_DIR, this.domainConfigurationDir.getAbsolutePath()); final String defaultHostConfig = WildFlySecurityManager.getPropertyPrivileged(JBOSS_HOST_DEFAULT_CONFIG, "host.xml"); hostConfigurationFile = new ConfigurationFile(domainConfigurationDir, defaultHostConfig, initialHostConfig == null ? hostConfig : initialHostConfig, initialHostConfig == null); this.domainConfig = domainConfig; this.initialDomainConfig = initialDomainConfig; tmp = getFileFromProperty(DOMAIN_DATA_DIR); if (tmp == null) { tmp = new File(this.domainBaseDir, "data"); } this.domainDataDir = tmp; if (domainDataDir.exists()) { if (!domainDataDir.isDirectory()) { throw MESSAGES.domainDataDirectoryIsNotDirectory(domainDataDir); } } else { if (!domainDataDir.mkdirs()) { throw MESSAGES.couldNotCreateDomainDataDirectory(domainDataDir); } } WildFlySecurityManager.setPropertyPrivileged(DOMAIN_DATA_DIR, this.domainDataDir.getAbsolutePath()); @SuppressWarnings("deprecation") String deprecatedDepDir = DOMAIN_DEPLOYMENT_DIR; tmp = getFileFromProperty(DOMAIN_CONTENT_DIR); if (tmp == null) { tmp = getFileFromProperty(deprecatedDepDir); } if (tmp == null) { tmp = new File(this.domainDataDir, "content"); } this.domainContentDir = tmp; if (domainContentDir.exists()) { if (!domainContentDir.isDirectory()) { throw MESSAGES.domainContentDirectoryIsNotDirectory(domainContentDir); } } else if (!domainContentDir.mkdirs()) { throw MESSAGES.couldNotCreateDomainContentDirectory(domainContentDir); } WildFlySecurityManager.setPropertyPrivileged(DOMAIN_CONTENT_DIR, this.domainContentDir.getAbsolutePath()); WildFlySecurityManager.setPropertyPrivileged(deprecatedDepDir, this.domainContentDir.getAbsolutePath()); tmp = getFileFromProperty(DOMAIN_LOG_DIR); if (tmp == null) { tmp = new File(this.domainBaseDir, "log"); } if (tmp.exists()) { if (!tmp.isDirectory()) { throw MESSAGES.logDirectoryIsNotADirectory(tmp); } } else if (!tmp.mkdirs()) { throw MESSAGES.couldNotCreateLogDirectory(tmp); } this.domainLogDir = tmp; WildFlySecurityManager.setPropertyPrivileged(DOMAIN_LOG_DIR, this.domainLogDir.getAbsolutePath()); tmp = getFileFromProperty(DOMAIN_SERVERS_DIR); if (tmp == null) { tmp = new File(this.domainBaseDir, "servers"); } if (tmp.exists()) { if (!tmp.isDirectory()) { throw MESSAGES.serversDirectoryIsNotADirectory(tmp); } } else if (!tmp.mkdirs()) { throw MESSAGES.couldNotCreateServersDirectory(tmp); } this.domainServersDir = tmp; WildFlySecurityManager.setPropertyPrivileged(DOMAIN_SERVERS_DIR, this.domainServersDir.getAbsolutePath()); tmp = getFileFromProperty(DOMAIN_TEMP_DIR); if (tmp == null) { tmp = new File(this.domainBaseDir, "tmp"); } if (tmp.exists()) { if (!tmp.isDirectory()) { throw MESSAGES.domainTempDirectoryIsNotADirectory(tmp); } } else if (!tmp.mkdirs()){ throw MESSAGES.couldNotCreateDomainTempDirectory(tmp); } this.domainTempDir = tmp; WildFlySecurityManager.setPropertyPrivileged(DOMAIN_TEMP_DIR, this.domainTempDir.getAbsolutePath()); if(defaultJVM != null) { if (defaultJVM.equals("java")) { defaultJVM = DefaultJvmUtils.findJavaExecutable(DefaultJvmUtils.getCurrentJvmHome()); } this.defaultJVM = new File(defaultJVM); } else { this.defaultJVM = null; } this.backupDomainFiles = backupDomainFiles; this.useCachedDc = useCachedDc; this.productConfig = productConfig; } /** * Gets the address the process controller passed to this process * to use in communicating with it. * * @return the process controller's address */ public InetAddress getProcessControllerAddress() { return processControllerAddress; } /** * Gets the port number the process controller passed to this process * to use in communicating with it. * * @return the process controller's port */ public Integer getProcessControllerPort() { return processControllerPort; } /** * Gets the address the process controller told this Host Controller to use for communication with it. * Not related to communication with management clients. * * @return the address used for inter-process communication with the Process Controller */ public InetAddress getHostControllerAddress() { return hostControllerAddress; } /** * Gets the port the process controller told this Host Controller to use for communication with it. * Not related to communication with management clients. * * @return the port used for inter-process communication with the Process Controller */ public Integer getHostControllerPort() { return hostControllerPort; } /** * Gets whether this was a restarted host controller. * * @return if it was restarted */ public boolean isRestart() { return isRestart; } /** * Whether we should maintain a copy of the domain configuration file even though we are not the * master host controller for the domain. This is only relevant if we are not the master host controller. * * @return true if we should grab the files */ public boolean isBackupDomainFiles() { return backupDomainFiles; } /** * Whether we should try to start up with a locally cached copy of the domain configuration file rather than * trying to connect to a master host controller. This only has an effect if we are not configured to * act as the master host controller for the domain. * * @return true if we start with a locally cached copy of the domain configuration file */ public boolean isUseCachedDc() { return useCachedDc; } /** * Gets the {@link RunningMode} that was in effect when this Host Controller was launched. * * @return the initial running mode */ public RunningMode getInitialRunningMode() { return initialRunningMode; } /** * Get the {@link HostRunningModeControl} containing the current running mode of the host controller * * @return the running mode control */ public HostRunningModeControl getRunningModeControl() { return runningModeControl; } /** * Gets the {@link ProductConfig} detected at startup. * * @return the product config. Will not be {@code null} */ public ProductConfig getProductConfig() { return productConfig; } /** * Gets the root directory for this JBoss installation. * * @return the root directory */ public File getHomeDir() { return homeDir; } /** * A filesystem location that has no real meaning and should not be regarded as providing any sort of useful * information. The "modules" directory is the default location from which JBoss Modules looks to find * modules. However, this behavior is in no way controlled by the value returned by this method, nor is it guaranteed that * modules will be loaded from only one directory, nor is it guaranteed that the "modules" directory will be one * of the directories used. Finally, the structure and contents of any directories from which JBoss Modules loads * resources is not something available from this class. Users wishing to interact with the modular classloading * system should use the APIs provided by JBoss Modules. * * @return a file * * @deprecated has no reliable meaning */ @Deprecated public File getModulesDir() { return modulesDir; } /** * Gets the base directory in which managed domain files are stored. *

Defaults to {@link #getHomeDir() JBOSS_HOME}/domain

* * @return the domain base directory. */ public File getDomainBaseDir() { return domainBaseDir; } /** * Gets the directory in which managed domain configuration files are stored. *

Defaults to {@link #getDomainBaseDir()} domainBaseDir}/configuration

* * @return the domain configuration directory. */ public File getDomainConfigurationDir() { return domainConfigurationDir; } /** * Gets the directory in which a Host Controller or Process Controller can store private internal state that * should survive a process restart. *

Defaults to {@link #getDomainBaseDir()} domainBaseDir}/data

* * @return the internal state persistent storage directory for the Host Controller and Process Controller. */ public File getDomainDataDir() { return domainDataDir; } /** * Gets the directory in which a Host Controller will store domain-managed user content (e.g. deployments or * rollout plans.) * *

Defaults to {@link #getDomainDataDir()} domainDataDir}/content

* * @return the domain managed content storage directory */ public File getDomainContentDir() { return domainContentDir; } /** * Deprecated previous name for {@link #getDomainContentDir()}. * @return the domain managed content storage directory. * * @deprecated use {@link #getDomainContentDir()} */ @Deprecated public File getDomainDeploymentDir() { return domainContentDir; } /** * Gets the directory in which a Host Controller or Process Controller can write log files. *

Defaults to {@link #getDomainBaseDir()} domainBaseDir}/log

* * @return the log file directory for the Host Controller and Process Controller. */ public File getDomainLogDir() { return domainLogDir; } /** * Gets the directory under domain managed servers will write any persistent data. Each server will * have its own subdirectory. *

Defaults to {@link #getDomainBaseDir()} domainBaseDir}/servers

* * @return the root directory for domain managed servers */ public File getDomainServersDir() { return domainServersDir; } /** * Gets the directory in which a Host Controller or Process Controller can store private internal state that * does not need to survive a process restart. *

Defaults to {@link #getDomainBaseDir()} domainBaseDir}/tmp

* * @return the internal state temporary storage directory for the Host Controller and Process Controller. */ public File getDomainTempDir() { return domainTempDir; } /** * Gets the location of the default java executable to use when launch managed domain servers. * * @return the location of the default java executable */ public File getDefaultJVM() { return defaultJVM; } /** * Initial set of system properties provided to this Host Controller at boot via the command line. * @return the properties */ public Map getHostSystemProperties() { return hostSystemProperties; } /** * Get the fully-qualified host name detected at server startup. * * @return the qualified host name */ public String getQualifiedHostName() { return qualifiedHostName; } /** * Get the local host name detected at server startup. Note that this is not the same * as the {@link #getHostControllerName() host controller name}. Defaults to the portion of * {@link #getQualifiedHostName() the qualified host name} following the first '.'. * * @return the local host name */ public String getHostName() { return hostName; } /** * Gets the name by which this host controller is known in the domain. Default to the * {@link #getQualifiedHostName() qualified host name} if the {@code name} attribute is not * specified on the root element of the host configuration file (e.g. host.xml). * * @return the name of the host controller */ public String getHostControllerName() { return hostControllerName; } @Override protected String getProcessName() { return hostControllerName; } @Override protected void setProcessName(String processName) { if (processName != null) { this.hostControllerName = processName; } } @Override protected boolean isRuntimeSystemPropertyUpdateAllowed(String propertyName, String propertyValue, boolean bootTime) { // Currently any system-property in host.xml should not be applied to the HC runtime. This method // should not be invoked. throw MESSAGES.hostControllerSystemPropertyUpdateNotSupported(); } @Override protected void systemPropertyUpdated(String propertyName, String propertyValue) { // no-op } public ConfigurationFile getHostConfigurationFile() { return hostConfigurationFile; } public ConfigurationFile getDomainConfigurationFile() { return domainConfigurationFile; } String getDomainConfig() { return domainConfig; } String getInitialDomainConfig() { return initialDomainConfig; } /** * This shouldn't really be a property of this class, * but we expose it in the management API resource for the HC environment, * so we store it here. * * @param domainConfigurationFile the config file, or {@code null} in a slave HC without --backup --cached-dc */ void setDomainConfigurationFile(ConfigurationFile domainConfigurationFile) { this.domainConfigurationFile = domainConfigurationFile; } String getModulePath() { return modulePath; } /** * Get a File from configuration. * @param name the name of the property * @return the CanonicalFile form for the given name. */ private File getFileFromProperty(final String name) { String value = hostSystemProperties.get(name); File result = (value != null) ? new File(value) : null; // AS7-1752 see if a non-existent relative path exists relative to the home dir if (result != null && homeDir != null && !result.exists() && !result.isAbsolute()) { File relative = new File(homeDir, value); if (relative.exists()) { result = relative; } } return result; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy