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 20. Configuring a Fabric's Maven Proxy
Abstract
					The Fabric Ensemble creates a Maven proxy to access the repositories from which artifacts are distributed to the fabric's containers. You can modify the default settings to use a different set of repositories or make an internal repository accessible.
				
Overview
Copy linkLink copied to clipboard!
			The Fabric Ensemble creates a Maven proxy to facilitate access to the artifacts required by the containers in the fabric. Each Fabric Server deployed in the fabric runs an instance of a Maven proxy. The ensemble aggregates all of the proxies so that it appears to the Fabric Agents as a single Maven proxy.
		
			The Fabric Agents use the fabric's Maven proxy to access the known repositories. This ensures that all of the containers use the same set of repositories and artifacts.
		
Note
				Advanced users can configure each Fabric server to act as a proxy for a different set of repositories. However, this is not a recommended set up.
			
Note
				Fuse Management Console provides tooling for uploading bundles using the Maven proxy. You can also add the fabric's Maven Proxy to a POM file so that bundles can be distributed to the ensemble as part of an automated build process.
			
Default repositories
Copy linkLink copied to clipboard!
			By default a fabric's Maven proxy is configured to be a proxy for the following Maven repositories:
		
- Maven Central (http://repo1.maven.org/maven2)
- Fuse Public (https://repo.fusesource.com/nexus/content/groups/public)
- Fuse Releases (https://repo.fusesource.com/nexus/content/repositories/releases)
- Fuse Early Access (https://repo.fusesource.com/nexus/content/groups/ea)
- JBoss Public (https://repository.jboss.org/nexus/content/repositories/public)
- SpringSource (http://repository.springsource.com/maven/bundles/release, http://repository.springsource.com/maven/bundles/external)
- User's Local (~/.m2/repository)
Changing the repositories
Copy linkLink copied to clipboard!
			To change the repositories the ensemble proxies:
		
- Create a new profile version. From the command console this is done using the fabric:version-create command. See section "fabric:version-create" in "Console Reference" for more information.
- Change theorg.ops4j.pax.url.mvn.repositoriesproperty in theio.fabric8.agentPID of thedefaultprofile. Example 20.1, “Configuring the Maven Proxy URL” shows the console command for editing this property.Example 20.1. Configuring the Maven Proxy URL JBossFuse:karaf@root> fabric:profile-edit -p io.fabric8.agent/org.ops4j.pax.url.mvn.repositories = file:${runtime.home}/${karaf.default.repository}@snapshots@id=karaf-default, file:${runtime.data}/maven/upload@snapshots@id=fabric-upload, http://repo1.maven.org/maven2@id=central, https://repo.fusesource.com/nexus/content/groups/public@id=fusepublic, https://repository.jboss.org/nexus/content/repositories/public@id=jbosspublic, https://repo.fusesource.com/nexus/content/repositories/releases@id=jbossreleases, https://repo.fusesource.com/nexus/content/groups/ea@id=jbossearlyaccess, http://repository.springsource.com/maven/bundles/release@id=ebrreleases, http://repository.springsource.com/maven/bundles/external@id=ebrexternalJBossFuse:karaf@root> fabric:profile-edit -p io.fabric8.agent/org.ops4j.pax.url.mvn.repositories = file:${runtime.home}/${karaf.default.repository}@snapshots@id=karaf-default, file:${runtime.data}/maven/upload@snapshots@id=fabric-upload, http://repo1.maven.org/maven2@id=central, https://repo.fusesource.com/nexus/content/groups/public@id=fusepublic, https://repository.jboss.org/nexus/content/repositories/public@id=jbosspublic, https://repo.fusesource.com/nexus/content/repositories/releases@id=jbossreleases, https://repo.fusesource.com/nexus/content/groups/ea@id=jbossearlyaccess, http://repository.springsource.com/maven/bundles/release@id=ebrreleases, http://repository.springsource.com/maven/bundles/external@id=ebrexternalCopy to Clipboard Copied! Toggle word wrap Toggle overflow NoteTheio.fabric8.agentPID is refined in all of the fabric profiles. Setting the proxy URL, theorg.ops4j.pax.url.mvn.repositoriesproperty, in thedefaultprofile ensures that all of the other fabric profiles share the same Maven proxy setting.ImportantThefabricprofile'sio.fabric8.mavenPID, which ultimately controls the Maven proxy, imports its value from thedefaultprofile'sio.fabric8.agentPID. You should not change the settings of theio.fabric8.mavenPID.Alternatively, instead of resetting the entire list of repositories, you can append a new entry to the repository list by invokingfabric:profile-editwith the--appendoption, as follows:JBossFuse:karaf@root> profile-edit --pid io.fabric8.agent/org.ops4j.pax.url.mvn.repositories='http://fusewin.tpb.lab.eng.brq.redhat.com:8081/nexus/content/repositories/fuse-qe-repo@id=fuse-qa' --append default 1.1 JBossFuse:karaf@root> profile-edit --pid io.fabric8.agent/org.ops4j.pax.url.mvn.repositories='http://fusewin.tpb.lab.eng.brq.redhat.com:8081/nexus/content/repositories/fuse-qe-repo@id=fuse-qa' --append default 1.1Copy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Roll the changes out the fabric by upgrading the containers to the new profile version.ImportantYou cannot test this configuration change out on a few containers to validate it. The change must be made to the entire fabric or it will result in conflicts.
Using an HTTP proxy with the Maven proxy
Copy linkLink copied to clipboard!
			Using fabric's built-in Maven proxy, all nodes communicate directly with each other over HTTP. If you need to secure this communication (as when fabric's maven proxy must request maven artifacts from remote repositories), you can configure an HTTP proxy in fabric using a Maven 
settings.xml file that includes an HTTP proxy configuration.
		
			To do so, follow these steps:
		
- Prepare an HTTP proxy settings file (see Example 20.2, “Example HTTP proxy settings.xmlfile” for example content), and put it in the Red Hat JBoss Fuse InstallDir/fuse/directory.
- Start up JBoss Fuse, and create a fabric. For details, see ???.
- Specify the name and location of the HTTP settings file. At theJBossFuse:karaf@root>command line, type:profile-edit --pid io.fabric8.maven/io.fabric8.maven.settings=/home/fuse/http-proxy-settings.xml default profile-edit --pid io.fabric8.maven/io.fabric8.maven.settings=/home/fuse/http-proxy-settings.xml defaultCopy to Clipboard Copied! Toggle word wrap Toggle overflow 
- Remove the org.ops4j.pax,url.mvn.repositories property from thedefaultprofile. At theJBossFuse:karaf@root>command line, type:profile-edit --delete --pid io.fabric8.agent/org.ops4j.pax.url.mvn.repositories default profile-edit --delete --pid io.fabric8.agent/org.ops4j.pax.url.mvn.repositories defaultCopy to Clipboard Copied! Toggle word wrap Toggle overflow Removing this property causes the Maven proxy to pick up repositories from Maven's/home/.m2/settings.xmlfile, pointed to in the/home/fuse/http-proxy-settings.xmlfile.All fabric Maven proxy requests for remote repositories will now be redirected to the HTTP proxy server.
Example 20.2. Example HTTP proxy settings .xml file