0

下载了 New Relic 2.12.0 并根据 Heroku java 配置文档进行了配置。

我将包内容解压缩到我的 spring mvc 应用程序目录的根目录,如下图所示

在此处输入图像描述

接下来,我将新文件推送到 Heroku:

$ git add newrelic
$ git commit -m 'add newrelic'
$ git push heroku master

最后,我引导了新的遗物代理:

$ heroku config:add JAVA_OPTS='-Xmx384m -Xss512k -XX:+UseCompressedOops -javaagent:newrelic/newrelic.jar'

之后,我的应用程序因以下错误而失败,并且似乎无法找到 newrelic.jar 文件。

新的 relic 文档说 JVM 参数(例如 -javaagent:newrelic/newrelic.jar)应该包含 newrelic.jar 文件的完整路径,但根据 Heroku 文档,-javaagent:newrelic/newrelic.jar 就是所有需要的.

2013-01-15T19:41:11+00:00 heroku[web.1]: Starting process with command `java -Xmx384m -Xss512k -XX:+UseCompressedOops -javaagent:newrelic/newrelic.jar -Dspring.profiles.active=prod -jar target/dependency/webapp-runner.jar --port 47412 target/*.war`
2013-01-15T19:41:11+00:00 app[web.1]: agent library failed to init: instrument
2013-01-15T19:41:11+00:00 app[web.1]: Error occurred during initialization of VM
2013-01-15T19:41:11+00:00 app[web.1]: Error opening zip file or JAR manifest missing : newrelic/newrelic.jar
2013-01-15T19:41:12+00:00 heroku[web.1]: Process exited with status 1
2013-01-15T19:41:12+00:00 heroku[web.1]: State changed from starting to crashed

更新

在我的网络测功机上检查了 newrelic 目录后,我注意到 jar 文件丢失了。现在我正在调查丢失 jar 文件的原因。

在此处输入图像描述

更新

我的应用程序目录根目录中的 .gitignore 文件不包括 jar 文件,这会阻止部署 newrelic.jar 文件。

<<<<<<< HEAD
/target
/.classpath
/.project
/.settings
/tomcat.*
/.idea
/*.iml
=======
*.class

# Package Files #
*.jar
*.war
*.ear
4

2 回答 2

3

您是否可能在.gitignore文件中留下了忽略 jar 的内容?如果你heroku run bash然后ls newrelic你看到那里的罐子吗?

于 2013-01-16T22:21:17.833 回答
0

目标/依赖文件夹中缺少的 jar 文件也有同样的问题。

对我来说,问题是 pom 文件(由 Heroku 示例提供)

这是我的工作POM:

                <executions>
                 <execution>
                    <phase>package</phase>
                    <goals>
                        <goal>copy</goal>
                    </goals>
                    <configuration>
                        <artifactItems>
                            <artifactItem>
                                <groupId>org.eclipse.jetty</groupId>
                                <artifactId>jetty-runner</artifactId>
                                <version>9.2.3.v20140905</version>
                                <destFileName>jetty-runner.jar</destFileName>
                            </artifactItem>
                            <artifactItem>
                                <groupId>com.newrelic.agent.java</groupId>
                                <artifactId>newrelic-agent</artifactId>
                                <version>3.12.0</version>
                                <destFileName>newrelic-agent.jar</destFileName>
                            </artifactItem>
                        </artifactItems>
                    </configuration>
                  </execution>
                </executions>

并且肯定还会添加 New Relic 作为依赖项...

        <dependency>
           <groupId>com.newrelic.agent.java</groupId>
           <artifactId>newrelic-api</artifactId>
           <version>3.12.0</version>
        </dependency>
于 2014-12-18T19:11:02.010 回答