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.Este conteúdo não está disponível no idioma selecionado.
2.3. Using OSGi Configuration Properties
Overview
Copiar o linkLink copiado para a área de transferência!
					The OSGi Configuration Admin service defines a mechanism for passing configuration settings to an OSGi bundle. You do not have to use this service for configuration, but it is typically the most convenient way of configuring applications deployed in Red Hat JBoss Fuse (including FABs and OSGi bundles).
				
Persistent ID
Copiar o linkLink copiado para a área de transferência!
					In the OSGi Configuration Admin service, a persistent ID is a name that identifies a group of related configuration properties. In JBoss Fuse, every persistent ID, PersistentID, is implicitly associated with a file named 
PersistentID.cfg in the ESBInstallDir/etc/ directory. If the corresponding file exists, it can be used to initialize the values of properties belonging to the PersistentID property group.
				
					For example, the 
etc/org.ops4j.pax.url.mvn.cfg file is used to set the properties associated with the org.ops4j.pax.url.mvn persistent ID (for the PAX Mvn URL handler).
				Using OSGi configuration properties in Spring
Copiar o linkLink copiado para a área de transferência!
					Spring DM provides support for OSGi configuration, enabling you to substitute variables in a Spring XML file using values obtained from the OSGi Configuration Admin service.
				
Spring example
Copiar o linkLink copiado para a área de transferência!
					Example 2.1, “Using OSGi Configuration Properties in Spring XML” shows how to pass the value of the 
prefix variable to the constructor of the myTransform bean in Spring XML, where the value of prefix is set by the OSGi Configuration Admin service.
				Example 2.1. Using OSGi Configuration Properties in Spring XML
					The syntax, 
${prefix}, substitutes the value of the prefix variable into the Spring XML file. The OSGi properties are set up using the following XML elements:
				- osgix:cm-properties
- To integrate Spring properties with the properties from the OSGi Configuration Admin service, insert anosgix:cm-propertieselement into the Spring XML file. This element creates a bean that gets injected with all of the properties from the OSGiManagedServiceinstance that is identified by thepersistent-idattribute. The minimal configuration consists of an emptyosgix:cm-propertieselement that sets thepersistent-idattribute and theidattribute—for example:<osgix:cm-properties id="preProps" persistent-id="org.fusesource.example"/> <osgix:cm-properties id="preProps" persistent-id="org.fusesource.example"/>Copy to Clipboard Copied! Toggle word wrap Toggle overflow For an example of how the persistent ID relates to OSGi configuration settings, see the example in the section called “Add OSGi configurations to the feature”.If you want to define defaults for some of the properties in the Spring XML file, addpropelements as children of theosgix:cm-propertieselement, as shown in Example 2.1, “Using OSGi Configuration Properties in Spring XML”.
- ctx:property-placeholder
- Property placeholder is a Spring mechanism that enables you to use the syntax,${PropName}, to substitute variables in a Spring XML file. By defining actx:property-placeholderelement with a reference to theprePropsbean (as in Example 2.1, “Using OSGi Configuration Properties in Spring XML”), you enable the property placeholder mechanism to substitute any of the variables from theprePropsbean (which encapsulates the OSGi configuration properties) into the Spring XML file.
Blueprint example
Copiar o linkLink copiado para a área de transferência!
					Example 2.2, “Using OSGi Configuration Properties in Blueprint” shows how to pass the value of the 
prefix variable to the constructor of the myTransform bean in blueprint XML, where the value of prefix is set by the OSGi Configuration Admin service.
				Example 2.2. Using OSGi Configuration Properties in Blueprint
					The syntax, 
{{prefix}}, substitutes the value of the prefix variable into the blueprint XML file. The OSGi properties are set up using the following XML elements:
				- cm:property-placeholder
- This element gives you access to the properties associated with the specified persistent ID. After defining this element, you can use the syntax,{{PropName}}, to substitute variables belonging to the specified persistent ID.
- cm:property-placeholder/cm:default-properties
- You can optionally specify default values for properties by definingcm:propertyelements inside thecm:default-propertieselement. If the correspondingetc/PersistentID.cfgfile defines property values, however, these will be used instead.