2

我正在尝试在 Maven 中为 GAE 使用新的 Google 插件。

与旧插件不同,一切运行顺利。

除了部署之外的所有内容。

第一个令人担忧的事情是,从一个空的开始.m2(我删除它以确保没有旧版本对我造成影响)和在初始下载阶段mvn appengine:update,maven 说

Downloaded: http://repo.maven.apache.org/maven2/com/google/appengine/appengine-tools-sdk/1.7.4/appengine-tools-sdk-1.7.4.jar (16762 KB at 788.5 KB/sec)

然后,如果我运行mvn appengine:update,它会说

[INFO] Updating Google App Engine Application
********************************************************
There is a new version of the SDK available.
-----------
Latest SDK:
Release: 1.7.5
Timestamp: Fri Jan 11 00:56:53 CET 2013
API versions: [1.0]

-----------
Your SDK:
Release: 1.7.4
Timestamp: Tue Dec 11 12:41:31 CET 2012
API versions: [1.0]

-----------

当我检查我的 .m2 文件夹时,我得到了

mog@becca:~/.m2/repository/com/google$ tree -L 2 appengine/
appengine/
├── appengine
│   ├── 1.7.4
│   └── 1.7.5
├── appengine-api-1.0-sdk
│   └── 1.7.5
├── appengine-api-stubs
│   └── 1.7.5
├── appengine-java-sdk
│   └── 1.7.5
├── appengine-maven-plugin
│   └── 1.7.5
├── appengine-testing
│   └── 1.7.5
└── appengine-tools-sdk
    └── 1.7.4

这似乎表明 1.7.5 插件的依赖项是不完整的:在 1.7.4 中有些滞后。恼人的部分是它似乎阻止了我使用 1.7.5 插件的自动 java 7 检测功能,如下图所示:

当我使用mvn appengine:update时,我收到警告:

warning: [options] bootstrap class path not set in conjunction with -source 1.6
1 warning

此警告,以及当我访问我的网站时收到错误 500 的事实,以下日志对此进行了解释:

Failed startup of context com.google.apphosting.utils.jetty.RuntimeAppEngineWebAppContext@15a4523{/,/base/data/home/apps/s~trashnao/1.365599992371450729}
org.mortbay.util.MultiException[java.lang.UnsupportedClassVersionError: fr/univnantes/atal/web/trashnao/Controller : Unsupported major.minor version 51.0, java.lang.UnsupportedClassVersionError: fr/univnantes/atal/web/trashnao/Controller : Unsupported major.minor version 51.0]
    at org.mortbay.jetty.servlet.ServletHandler.initialize(ServletHandler.java:656)

让我认为 usedappengine-tools-sdk-1.7.4还不支持通过pom.xml文件自动检测 java 7。

正如开发人员自己在此视频中所说,自动检测 java 7 目标的这一功能在 1.7.5 插件中可用。

尝试在那个问题中给出的解决方案,我收到了这条消息,而不是关于 boostrap 类的消息:

warning: Supported source version 'RELEASE_6' from annotation processor 'com.google.appengine.tools.compilation.DatastoreCallbacksProcessor' less than -source '1.7'

我想就如何解决这个问题提出任何建议。即,如何使mvn appengine:update目标--java_7在调用 appcfg 时使用该选项(相关文档

4

1 回答 1

2

我可以解决这个问题,如果您想提交问题并查看进度,请随时在此处进行:https ://code.google.com/p/appengine-maven-plugin/issues/list我会保持更新。

编辑:在 1.7.6 中修复并使用强制插件确保它不会再次发生。

于 2013-03-04T23:20:58.470 回答