错误:对象服务不是包com.twitter.finagle的成员-在生成文件Scala finagle中定义Bazel依赖项 [英] error: object Service is not a member of package com.twitter.finagle - Defining Bazel dependencies in Build file, Scala finagle

查看:0
本文介绍了错误:对象服务不是包com.twitter.finagle的成员-在生成文件Scala finagle中定义Bazel依赖项的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试将finagle-http库作为外部maven依赖项添加到我的新Bazel项目中。但是得到了以下错误。我想我在没有完全理解的情况下创建构建是做错了什么。努力学习。感谢在这方面的任何帮助。

error: object Service is not a member of package com.twitter.finagle
error: object util is not a member of package com.twitter
error: type Request is not a member of package com.twitter.finagle.http
error: object Response is not a member of package com.twitter.finagle.http
error: Symbol 'type com.twitter.finagle.Client' is missing from the classpath. This symbol is required by 'object com.twitter.finagle.Http'.
error: not found: value Await

相同的代码在使用SBT时可以正常工作。以下是代码。

import com.twitter.finagle.{Http, Service}
import com.twitter.finagle.http
import com.twitter.util.{Await, Future}

object HelloWorld extends App {
  val service = new Service[http.Request, http.Response] {
    def apply(req: http.Request): Future[http.Response] =
      Future.value(http.Response(req.version, http.Status.Ok))
  }
  val server = Http.serve(":8080", service)
  Await.ready(server)
}

工作区文件

maven_install(
    artifacts = [
        "org.apache.spark:spark-core_2.11:2.4.4",
        "org.apache.spark:spark-sql_2.11:2.4.1",
        "org.apache.spark:spark-unsafe_2.11:2.4.1",
        "org.apache.spark:spark-tags_2.11:2.4.1",
        "org.apache.spark:spark-catalyst_2.11:2.4.1",
        "com.twitter:finagle-http_2.12:21.8.0",
    ],
    repositories = [
        "https://repo.maven.apache.org/maven2/",
        "https://repo1.maven.org/maven2/",
    ]
)

生成文件

load("@io_bazel_rules_scala//scala:scala.bzl", "scala_binary")
package(default_visibility = ["//visibility:public"])

scala_binary(
    name="helloworld",
    main_class="microservices.HelloWorld",
    srcs=[
        "Main.scala",
        ],
    deps = ["spark],
)

java_library(
    name = "spark",
    exports = [
        "@maven//:com_twitter_finagle_http_2_12_21_8_0",
        ],
)

在我的初始SBT项目中工作的SBT依赖项

libraryDependencies += "com.twitter" %% "finagle-http" % "21.8.0"

推荐答案

解决了这个问题,不像在sbt中,我在Bazel中直接添加了相关的依赖项。我修改了工作区,如下所示。

maven_install(
artifacts = [
    "com.twitter:finagle-http_2.12:21.8.0",
    "com.twitter:util-core_2.12:21.8.0",
    "com.twitter:finagle-core_2.12:21.8.0",
    "com.twitter:finagle-base-http_2.12:21.8.0",
    "com.fasterxml.jackson.module:jackson-module-scala_2.12:2.11.2",
    "com.fasterxml.jackson.core:jackson-databind:2.11.2",

],
repositories = [
    "https://repo.maven.apache.org/maven2/",
    "https://repo1.maven.org/maven2/",
]

生成文件--

java_library(
name = "finagletrial",
exports = [
    "@maven//:com_twitter_finagle_http_2_12_21_8_0",
    "@maven//:com_twitter_util_core_2_12_21_8_0",
    "@maven//:com_twitter_finagle_core_2_12_21_8_0",
    "@maven//:com_twitter_finagle_base_http_2_12_21_8_0",
    "@maven//:com_fasterxml_jackson_module_jackson_module_scala_2_12_2_11_2",
    "@maven//:com_fasterxml_jackson_core_jackson_databind_2_11_2"
    ],

这篇关于错误:对象服务不是包com.twitter.finagle的成员-在生成文件Scala finagle中定义Bazel依赖项的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆