首页 > 代码库 > How to load jars residing over NFS in JBossAS7 classpath ? --reference
How to load jars residing over NFS in JBossAS7 classpath ? --reference
In this article we will discuss how can we load jars residing over NFS in JBoss AS-7 classpath. In some development environment, when there are multiple jars and properties files are being used by multiple servers, it is good to put all of them in a central repository, so that if the files (jar/properties files/xmls) are modified, all the servers will pickup the latest version and there will be less overhead related to copying the latest versions to individual servers
NFS allows a user on a client computer to access files over a network in a manner similar to how local storage is accessed. I installed NFS using below link :
Remote_Disk_Access_with_NFS#Installing_NFS
As JBoss AS-7 has introduced a module structure to load your custom jars. One can quickly create a custom module and put the required jars in them, with appropriate entries in module.xml . But in this case we would be needing an additional module directory, which would be residing over NFS server and we would map this to our local (client) server.
Step-1: Modify standalone.sh and add a separate module directory. To do this navigate to $JBOSS_HOME/bin and edit the file.
Search for keyword “module” and it should look like below :
..if [ "x$JBOSS_MODULEPATH" = "x" ]; then JBOSS_MODULEPATH="$JBOSS_HOME/modules"fi..
Edit the above section of your “standalone.sh” script and then add the “:” separated path of your module directories as following
..JBOSS_MODULEPATH=/mnt/nfs:$JBOSS_HOME/modules#if [ "x$JBOSS_MODULEPATH" = "x" ]; then # JBOSS_MODULEPATH="$JBOSS_HOME/modules"#fi..
Here /mnt/nfs/ is the directory, where our new module directory would be residing.
Step-2 : On the shared mount create below directory structure :
../mnt/nfs/├── aaa └── bbb └── ccc └── main ├── module.xml ├── utility_JAR.jar..
where
module.xml :
..<?xml version="1.0" encoding="UTF-8"?><module xmlns="urn:jboss:module:1.1" name="aaa.bbb.ccc"> <resources> <resource-root path="utility_JAR.jar"/> </resources></module>..
Step-3 : Now lets create a simple application which would be using utility_JAR.jar (ClassLoaderTestWAR.war). The war file will have below structure :”
..ClassLoaderTestWAR.war/├── index.jsp├── WEB-INF ├── jboss-deployment-structure.xml ├── web.xml..
Where :
index.jsp :
..<html> <head><title>ClassLoader Demo</title></head> <body bgcolor="maroon" text="white"> <center> <h1>Class Loader Demo..</h1><% aaa.bbb.TestUtility utility=new aaa.bbb.TestUtility(); String whichClassLoader=utility.sayWhichClassLoader(); System.out.println("\n\n\t -----> "+whichClassLoader); out.println("<h1>"+whichClassLoader+"</h1>");%> </body></html>..
jboss-deployment-structure.xml :
..<?xml version="1.0" encoding="UTF-8"?><jboss-deployment-structure> <deployment> <dependencies> <module name="aaa.bbb.ccc" /> </dependencies> </deployment></jboss-deployment-structure>..
web.xml :
..<web-app> <welcome-file-list> <welcome-file>index.jsp</welcome-file> </welcome-file-list></web-app>..
Step-4 : Now deploy the application and start the JBoss AS-7 server.
Step-5 : Access the application using : http://localhost:8080/ClassLoaderTestWAR
You will see something like below :
If the above output comes that means the jar was loaded from our new module directory, which resides over NFS.