我下载了 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