Fuse 6 is no longer supported
As of February 2025, Red Hat Fuse 6 is no longer supported. If you are using Fuse 6, please upgrade to Red Hat build of Apache Camel.Chapter 11. Configuring JBoss Fuse
Abstract
					Red Hat JBoss Fuse uses the OSGi Configuration Admin service to manage the configuration of OSGi services. How you feed information to the configuration service depends on how the container is deployed.
				
11.1. Introducing JBoss Fuse Configuration
Copy linkLink copied to clipboard!
OSGi configuration
Copy linkLink copied to clipboard!
				The OSGi Configuration Admin service specifies the configuration information for deployed services and ensures that the services receive that data when they are active.
			
				A configuration is a list of name-value pairs read from a 
.cfg file in the InstallDir/etc directory. The file is interpreted using the Java properties file format. The filename is mapped to the persistent identifier (PID) of the service that is to be configured. In OSGi, a PID is used to identify a service across restarts of the container.
			Configuration files
Copy linkLink copied to clipboard!
				You can configure the Red Hat JBoss Fuse runtime using the following files:
			
| Filename | Description | 
|---|---|
| broker.xml | Configures the default Apache ActiveMQ broker in a Fabric (used in combination with the io.fabric8.mq.fabric.server-default.cfgfile). | 
| config.properties | The main configuration file for the container See Section 11.2, “Setting OSGi Framework and Initial Container Properties” for details. | 
| keys.properties | Lists the users who can access the JBoss Fuse runtime using the SSH key-based protocol. The file's contents take the format username=publicKey,role | 
| org.apache.aries.transaction.cfg | Configures the transaction feature | 
| org.apache.felix.fileinstall-deploy.cfg | Configures a watched directory and polling interval for hot deployment. | 
| org.apache.karaf.features.cfg | Configures a list of feature repositories to be registered and a list of features to be installed when JBoss Fuse starts up for the first time. | 
| org.apache.karaf.features.obr.cfg | Configures the default values for the features OSGi Bundle Resolver (OBR). | 
| org.apache.karaf.jaas.cfg | Configures options for the Karaf JAAS login module. Mainly used for configuring encrypted passwords (disabled by default). | 
| org.apache.karaf.log.cfg | Configures the output of the log console commands. See Section 16.2, “Logging Configuration”. | 
| org.apache.karaf.management.cfg | 
								Configures the JMX system. See Chapter 13, Configuring JMX for details.
							 | 
| org.apache.karaf.shell.cfg | 
								Configures the properties of remote consoles. For more information see Section 8.1, “Configuring a Container for Remote Access”.
							 | 
| org.apache.servicemix.jbi.cfg | 
								Configures the shutdown timeout for the JBI container.
							 | 
| org.apache.servicemix.nmr.cfg | 
								Configures the default thread pool settings for JBI. See Configuring JBI Component Thread Pools.
							 | 
| org.apache.servicemix.components.Name.cfg | 
								Configures the thread pool settings specifically for the Name JBI component. See Configuring JBI Component Thread Pools.
							 | 
| org.fusesource.bai.agent.cfg | Configures the Fuse BAI (Business Activity Insight) feature, if it is installed. | 
| io.fabric8.maven.cfg | Configures the Maven repositories used by the Fabric Maven Proxy when downloading artifacts, (The Fabric Maven Proxy is used for provisioning new containers on a remote host.) | 
| io.fabric8.mq.fabric.server-default.cfg | Configures the default Apache ActiveMQ broker in a Fabric (used in combination with the broker.xmlfile). | 
| org.jclouds.shell.cfg | Configures options for formatting the output of jclouds:*console commands. | 
| org.ops4j.pax.logging.cfg | 
								Configures the logging system. For more, see Section 16.2, “Logging Configuration”.
							 | 
| org.ops4j.pax.url.mvn.cfg | Configures additional URL resolvers. | 
| org.ops4j.pax.web.cfg | Configures the default Jetty container (Web server). See Securing the Web Console. | 
| startup.properties | Specifies which bundles are started in the container and their start-levels. Entries take the format bundle=start-level. | 
| system.properties | 
								Specifies Java system properties. Any properties set in this file are available at runtime using  System.getProperties(). See Setting System and Config Properties for more. | 
| users.properties | Lists the users who can access the JBoss Fuse runtime either remotely or via the web console. The file's contents take the format username=password,role | 
| setenvorsetenv.bat | This file is in the /bindirectory. It is used to set JVM options. The file's contents take the format JAVA_MIN_MEM=512M, where 512M is the minimum size of Java memory. See Setting Java Options for more information. | 
Configuration file naming convention
Copy linkLink copied to clipboard!
				The file naming convention for configuration files depends on whether the configuration is intended for an OSGi Managed Service or for an OSGi Managed Service factory.
			
				The configuration file for an OSGi Managed Service obeys the following naming convention:
			
<PID>.cfg
<PID>.cfg
				Where 
<PID> is the persistent ID of the OSGi Managed Service (as defined in the OSGi Configuration Admin specification). A persistent ID is normally dot-delimited—for example, org.ops4j.pax.web.
			
				The configuration file for an OSGi Managed Service Factory obeys the following naming convention:
			
<PID>-<InstanceID>.cfg
<PID>-<InstanceID>.cfg
				Where 
<PID> is the persistent ID of the OSGi Managed Service Factory. In the case of a managed service factory's <PID>, you can append a hyphen followed by an arbitrary instance ID, <InstanceID>. The managed service factory then creates a unique service instance for each <InstanceID> that it finds.
			JBI component configuration
Copy linkLink copied to clipboard!
				In addition to the container's configuration files, the 
InstallDir/etc folder may contain a number of configuration files for the JBI components that ship with Red Hat JBoss Fuse.
			
				The component configuration files are named using the scheme 
org.apache.servicemix.components.ComponentName.cfg. For example, you would configure the JMS component using a file called org.apache.servicemix.components.jms.cfg.
			
				The contents of a component's configuration file is largely component specific. However, each component configuration file contains properties for configuring the thread pool used by the component to process message exchanges. See ??? for details.
			
Setting Java Options
Copy linkLink copied to clipboard!
				Java Options can be set using the 
/bin/setenv file in Linux, or the bin/setenv.bat file for Windows. Use this file to directly set a group of Java options: JAVA_MIN_MEM, JAVA_MAX_MEM, JAVA_PERM_MEM, JAVA_MAX_PERM_MEM. Other Java options can be set using the EXTRA_JAVA_OPTS variable.
			
				For example, to allocate minimum memory for the JVM use 
 
Copy to Clipboard
Copied!
 
 
Toggle word wrap
Toggle overflow
 
 
				 To set a Java option other than the direct options, use 
 
Copy to Clipboard
Copied!
 
 
Toggle word wrap
Toggle overflow
 
 
				 For example, 
 
Copy to Clipboard
Copied!
 
 
Toggle word wrap
Toggle overflow
 
 
			
JAVA_MIN_MEM=512M # Minimum memory for the JVM
JAVA_MIN_MEM=512M # Minimum memory for the JVMEXTRA_JAVA_OPTS="Java option"
EXTRA_JAVA_OPTS="Java option"EXTRA_JAVA_OPTS="-XX:+UseG1GC"
EXTRA_JAVA_OPTS="-XX:+UseG1GC"