We encountered a problem because we're running several process definitions within one engine deployment. This includes both entirely different processes as well as new versions of already running process definitions. Our base of automated business processes has grown over time, with older process implementations relying on the early SOA API and the newer process implementations taking advantage of the later API additions. There are dependencies to different versions of the API - and while strict backwards compatibility might have solved this issue for us, in practice this proved not quite feasible.
So what were the issues we were trying to solve?
- There are different versions of the generated API classes corresponding to different versions of the SOA services. One deployment of jBPM must be able to run processes that rely on different versions next to each other.
- We wanted to be able to configure the dependency per process definition, but also for versions of a definition, so that a new incarnation of a process may take advantage of a new (and hopefully improved) version of a web service.
- Not only the correct version of the API classes needs to be used, also the corresponding web service endpoints has to be available to the code running a process instance.
This custom configuration consists of the following:
- One line indicating the directory in which all the API jars are deployed. Take care that this directory and the jars in it are not on the standard classpath, because then you're gonna be stuck with only one version, which is not compatible with all of the calling code.
- At least one entry for each process definition. A single entry can be used for each separately deployed version of the definition (as for process2) or different entries for the different version ranges (indicated using the min_version and/or max_version attributes).
- For each process definition (version range) the jar file and endpoint for each required web service is added. The name is used for querying by the client code.
We've put the actual reading from the XML file in a utility class; for reading from XML we could have gone completely overboard and set up a schema and compiled Java classes from it with JAXB. Instead we simply used the dom4j library and a couple of simple XPath expressions to accomplish the same.
Our utility class has the following interface:
public final class ConfigurationUtil { public static URL[] getJarsForProcessDefinition(String processId, int version) throws IOException {...} public static String getEndpointForProcessDefinition( String processId, int version, String serviceName) throws IOException {...} }The first method delivers everything needed by the custom class loader's super class constructor. The second method reuses the XML parsing facility and allows the last requirement mentioned in the issues above to be satisfied efficiently.
In all, writing a custom ClassLoader was not much of a task anymore once we figured out what kind of custom configuration was applicable to our situation...
Very nice! I poached some of your code example from the config file... that was the most interesting part I thought!
ReplyDeleteHup, up to deploying this solution after the holidays! ;-)
update comment for this new site:
ReplyDeleteprofile pick has gotta go, I don't even believe you own a suit!
Hi Maurice,
ReplyDeleteI really liked your approach towards the solution. I am also working on the same problem but my concern is JBPM always returns a new instance of the custom class loader for every node in the Process Definition so that can be a problem. I know it's been a long time you worked on the problem, but can you give me a hint how you solved the problem. It would be really helpful, Thanks
This is a truly good site post. Not too many people would actually, the way you just did. I am really impressed that there is so much information about this subject that have been uncovered and you’ve done your best, with so much class. If wanted to know more about green smoke reviews, than by all means come in and check our stuff. custom writing service
ReplyDelete