当我将scala应用程序作为docker容器运行时,kamon stastsd不发送指标

时间:2018-07-05 06:26:56

标签: scala docker grafana statsd kamon

当我使用'sbt run'命令运行scala应用程序时,它会将kamon指标发送到石墨/格拉纳纳容器。然后,为我的scala应用程序创建了一个docker映像,并将其作为docker容器运行。 现在,它不会将指标发送到石墨/格拉纳纳容器。我的应用程序容器和石墨/格拉纳娜容器都在相同的docker网络下运行。

我用来运行grafana图像的命令是:docker run --network smart -d -p 80:80 -p 81:81 -p 2003:2003 -p 8125:8125/udp -p 8126:8126 8399049ce731

application.conf中的kamon配置为

  kamon {
     auto-start=true
     metric {
       tick-interval = 1 seconds
         filters {
           akka-actor {
              includes = ["*/user/*"]
              excludes = [ "*/system/**", "*/user/IO-**", "**/kamon/**" ]      
           }
           akka-router {
              includes = ["*/user/*"]
              excludes = [ "*/system/**", "*/user/IO-**", "**/kamon/**" ]      
           }
           akka-dispatcher {
              includes = ["*/user/*"]
              excludes = [ "*/system/**", "*/user/IO-**", "*kamon*", 
                  "*/kamon/*", "**/kamon/**" ]
           }
           trace {
              includes = [ "**" ]
              excludes = [ ]enter code here
            }
         }
   }

    # needed for "[error] Exception in thread "main" 
    java.lang.ClassNotFoundException: local"
     internal-config {
       akka.actor.provider = "akka.actor.LocalActorRefProvider"
     }

    statsd {
      hostname = "127.0.0.1"
      port = 8125
      # Subscription patterns used to select which metrics will be pushed 
      to StatsD. Note that first, metrics
      # collection for your desired entities must be activated under the 
      kamon.metrics.filters settings.
      subscriptions {
         histogram       = [ "**" ]
         min-max-counter = [ "**" ]
         gauge           = [ "**" ]
         counter         = [ "**" ]
         trace           = [ "**" ]
         trace-segment   = [ "**" ]
         akka-actor      = [ "**" ]
         akka-dispatcher = [ "**" ]
         akka-router     = [ "**" ]
         system-metric   = [ "**" ]
         http-server     = [ "**" ]
      }
     metric-key-generator = kamon.statsd.SimpleMetricKeyGenerator
     simple-metric-key-generator {
        application = "my-application"
        include-hostname = true
        hostname-override = none
        metric-name-normalization-strategy = normalize
     }
   }

    modules {
      kamon-scala.auto-start = yes
      kamon-statsd.auto-start = yes
      kamon-system-metrics.auto-start = yes
    }
 }

非常感谢您的帮助。

1 个答案:

答案 0 :(得分:0)

启动应用程序时,必须add AspectJ weaver as Java Agent-javaagent:aspectjweaver.jar

您可以在项目SBT配置中添加以下设置:

.settings(
  retrieveManaged := true,
  libraryDependencies += "org.aspectj" % "aspectjweaver" % aspectJWeaverV)

因此,AspectJ weaver JAR将被复制到项目根目录中的./lib_managed/jars/org.aspectj/aspectjweaver/aspectjweaver-[aspectJWeaverV].jar

然后您可以在Dockerfile中引用此JAR:

COPY ./lib_managed/jars/org.aspectj/aspectjweaver/aspectjweaver-*.jar /app- 
workdir/aspectjweaver.jar
WORKDIR /app-workdir
CMD ["java", "-javaagent:aspectjweaver.jar", "-jar", "app.jar"]