Using Maven for Coldfusion project

前端 未结 2 530
攒了一身酷
攒了一身酷 2021-02-04 14:14

I have to deal with what is pretty ugly and large blob of ColdFusion code which up to this day is maintained by direct modifications on production server (don\'t ask). I managed

2条回答
  •  南笙
    南笙 (楼主)
    2021-02-04 14:28

    First, here's another blog you might find helpful.

    build-tools-maven-and-coldfusion

    I haven't tried to build ColdFusion with Maven, but I have experience with managing Maven builds for a large company. There are a few things for you to consider.

    Project structure

    Coldfusion cfm and cfc files should be put in src/main/resources so they are bundled in the jar (the blog referenced above overrides the Maven convention to put them in src. this is ok, but could be a problem if you later need to add anything else to the project).

    I'd probably keep cfc and cfm files in separate projects with appropriate dependency declarations to link them, this keeps your cfc projects as libraries and helps reuse. It is also worth considering the granularity of the cfc projects. Generally Maven's dependency management helps you keep artifacts small, with little need to worry about finding all the jars.

    Deployment

    The simplest way to deliver the artifacts is to use the maven-war-plugin to create a war containing your artifacts and all their transitive dependencies. This makes each application self-contained, which can be useful. The downside of this is that you'll end up bundling the same artifacts repeatedly and they can be quite large. To mitigate this you can either use the assembly-plugin to create custom packages excluding the common components, or you can specify that certain components (e.g. ColdSpring) are scope provided, this means they won't be included in the war.

    Version Management

    Maven encourages a proliferation of dependencies, by default each dependency declaration has a version, this can cause maintenance issues, particularly when you want to bump the version of an external dependency. You can mitigate this by defining a parent POM or an "app" POM. Either would have a dependencyManagement section declaring the details (groupId, artifactId, and version) for common artifacts. Any POM inheriting from the parent need not declare the dependency version as it will be inherited (note this doesn't mean that all children will have all dependencies, only that any that declare a dependency don't need to declare the version). If you define an "app" project with packaging "pom" and a dependencyManagement section, you can reference it with scope import (from Maven 2.0.9 onwards), this will import the dependencyManagement section from the "app" project to the project POM. See the dependency documentation for more details.

    If you declare a dependency with a scope in the dependencyManagement section, that scope will be inherited unless it is overridden in the child POM. Related to the deployment section above, this means that you can declare the common libraries scope provided in the parent to ensure they are not bundled in each applciation.

    Naming Conventions You'll need a naming convention for the packages to avoid collisions. It's probably best to follow the Maven convention and use java package-like groupIds (org.apache.maven for maven.apache.org) and the jar name for the artifact. This convention would give the groupId "org.coldspringframework" and artifactId "coldspring" for ColdSpring.

    Further distinctions might need to be made across the company. For example, if you have a web and core team, you could give the web team the groupIds com.mycompany.web.* and the core team com.mycompany.core.*

    Dependency Management

    You'll need to add your CFC packages to a Maven repository such as Nexus so they are accessible to other builds across the enterprise.

    If you want to keep the CFC packages separate to the jars. You can specify a custom packaging type, so that they won't be mixed up with any Java artifacts. If you create a custom packaging type, the artifacts can have the ".jar" extension, but any dependency declaration must have the type set.

    Here's an example following those conventions:

    
      org.coldspringframework
      coldspring
      1.2
      
      cfc
    
    

    There's a section in the Nexus book that describes custom lifecycles (follow the links for more details. Essentially you need to create a plugin with a META-INf/plexus/components.xml to describe the plexus mechanics (what archiver to use, what extension to output etc).

    The components.xml would look something like this:

    
      
        
          org.apache.maven.lifecycle.mapping.LifecycleMapping
          cfc
          org.apache.maven.lifecycle.mapping.DefaultLifecycleMapping
          
            
              org.apache.maven.plugins:maven-resources-plugin:resources
              com.hsbc.maven.plugins:maven-jar-plugin:jar          
              org.apache.maven.plugins:maven-install-plugin:install
              org.apache.maven.plugins:maven-deploy-plugin:deploy
            
          
        
        
          org.apache.maven.artifact.handler.ArtifactHandler
          cfc
          org.apache.maven.artifact.handler.DefaultArtifactHandler
          
            jar
            cfc
            cfc
          
        
         
           org.codehaus.plexus.archiver.Archiver
           cfc
           org.codehaus.plexus.archiver.zip.ZipArchiver
           per-lookup
         
         
           org.codehaus.plexus.archiver.UnArchiver
           cfc
           org.codehaus.plexus.archiver.zip.ZipUnArchiver
           per-lookup
         
      
    
    

提交回复
热议问题