用于编译GoldenGate for Java的Maven设置?

时间:2016-03-31 20:49:38

标签: java maven oracle-golden-gate

GoldenGate for Java未安装在公共Maven存储库中。

如何设置我的Maven构建环境来处理GoldenGate库?

2 个答案:

答案 0 :(得分:1)

这些图书馆需要点击许可协议,可在此处下载:

  

http://www.oracle.com/technetwork/middleware/goldengate/downloads/index.html

无论您正在使用哪个平台,都需要Oracle GoldenGate Application Adapters。以下命令假定您已下载文件ggs_Adapters_Linux_x64.zip,版本12.2.0.1。相应地调整版本号。

首先,提取所需的文件:

jar xvf ggs_Adapters_Linux_x64.zip ggs_Adapters_Linux_x64.tar
tar -zxvf ggs_Adapters_Linux_x64.tar ggjava/resources/lib/*

然后,使用install-plugin安装三个jar文件并相应地设置版本和组信息。

mvn org.apache.maven.plugins:maven-install-plugin:2.5.2:install-file -Dfile=ggjava/resources/lib/ggdbutil-12.2.0.1.0.012.jar -DgroupId=com.oracle.goldengate -DartifactId=ggdbutil -Dversion=12.2.0.1.0.012 -Dpackaging=jar
mvn org.apache.maven.plugins:maven-install-plugin:2.5.2:install-file -Dfile=ggjava/resources/lib/gguserexitapi-12.2.0.1.0.012.jar -DgroupId=com.oracle.goldengate -DartifactId=gguserexitapi -Dversion=12.2.0.1.0.012 -Dpackaging=jar
mvn org.apache.maven.plugins:maven-install-plugin:2.5.2:install-file -Dfile=ggjava/resources/lib/ggutil-12.2.0.1.0.012.jar -DgroupId=com.oracle.goldengate -DartifactId=ggutil -Dversion=12.2.0.1.0.012 -Dpackaging=jar

在pom.xml中添加以下属性:

<properties>
    <goldengate.version>12.2.0.1.0.012</goldengate.version>
</properties>

和这些依赖项:

    <dependency>
        <groupId>com.oracle.goldengate</groupId>
        <artifactId>ggdbutil</artifactId>
        <version>${goldengate.version}</version>
    </dependency>
    <dependency>
        <groupId>com.oracle.goldengate</groupId>
        <artifactId>gguserexitapi</artifactId>
        <version>${goldengate.version}</version>
    </dependency>
    <dependency>
        <groupId>com.oracle.goldengate</groupId>
        <artifactId>ggutil</artifactId>
        <version>${goldengate.version}</version>
    </dependency>

答案 1 :(得分:0)

您可以像Mark Harrison建议的那样手动安装它们,但这只会将它们带到您的本地存储库。如果您要将该代码库与其他人一起使用,并希望避免每个人都必须这样做,那么您必须选择:

首先推荐,安装一个maven存储库管理器,如Nexus或Artifactory,并将jar推送到那里。在那里,您只需配置本地〜/ .m2 / settings.xml以从您的repo管理器中提取工件。 设置看起来像这样:

<?xml version="1.0" encoding="UTF-8"?>
<settings xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd" xmlns="http://maven.apache.org/SETTINGS/1.0.0"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <profiles> 
    <profile>
      <repositories>
        <repository>
          <id>repo</id>
          <name>repo</name>
          <url>https://some.host.com/artifactory/repo</url>
        </repository>
      </repositories> 
      <pluginRepositories>
        <pluginRepository>
          <id>plugin-repo</id>
          <name>plugin-repo</name>
          <url>https://some.host.com/artifactory/repo</url>
        </pluginRepository>
      </pluginRepositories>
      <id>artifactory</id>
    </profile>
  </profiles>
  <activeProfiles>
    <activeProfile>artifactory</activeProfile>
  </activeProfiles>
  <servers>
    <server>
      <id>artifactory</id>
      <username>user</username>
      <password>pass</password>
    </server>
  </servers>
</settings>

值得一提的是,这只是每次env配置一次,因为每次将一个第三方jar包含在项目中时,必须安装每个第三方jar。使用这种方法,当你有一个新的第三方jar时,你只需将它部署到repo管理器,通过他们的Web UI或命令:

mvn deploy:deploy-file -DgroupId=<group-id> \
  -DartifactId=<artifact-id> \
  -Dversion=<version> \
  -Dpackaging=<type-of-packaging> \
  -Dfile=<path-to-file> \
  -DrepositoryId=<id-to-map-on-server-section-of-settings.xml> \
  -Durl=<url-of-the-repository-to-deploy>

(更多细节https://maven.apache.org/guides/mini/guide-3rd-party-jars-remote.html

第二种方法,就是简单地添加指向pom.xml所在位置的相对路径的依赖项,如下所示:

<dependency>
  <artifactId>..</artifactId>
  <groupId>..</groupId>
  <scope>system</scope>
  <systemPath>${basedir}/lib/dependency.jar</systemPath>
</dependency>

对于每个共享此代码库的人来说,更喜欢这个而不是安装的基本原理。您只需将jar上传到代码仓库,并将依赖关系指向该位置,无需安装/运行任何内容即可进行项目编译。