91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么使用Bazel構建Golang程序

發布時間:2023-01-28 15:23:44 來源:億速云 閱讀:148 作者:iii 欄目:開發技術

本篇內容介紹了“怎么使用Bazel構建Golang程序”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

從頭開始一個 Golang 項目

讓我們從將 Go 與 Bazel 結合使用的基礎知識開始。

為此,我們需要從 github.com/bazelbuild/… 獲取 Go 語言的官方構建規則。

在配置部分,您會發現:我們需要將以下這段 Starlark 語言代碼,放入名為 WORKSPACE 的配置文件里面:

load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
http_archive(
    name = "io_bazel_rules_go",
    sha256 = "8e968b5fcea1d2d64071872b12737bbb5514524ee5f0a4f54f5920266c261acb",
    urls = [
        "https://mirror.bazel.build/github.com/bazelbuild/rules_go/releases/download/v0.28.0/rules_go-v0.28.0.zip",
        "https://github.com/bazelbuild/rules_go/releases/download/v0.28.0/rules_go-v0.28.0.zip",
    ],
)
load("@io_bazel_rules_go//go:deps.bzl", "go_register_toolchains", "go_rules_dependencies")
go_rules_dependencies()
go_register_toolchains(version = "1.16.5")

讓我們逐步了解這段代碼所做的事情。

首先,我們使用load指令來加載并提取新功能,以在 Bazel 文件當中能夠使用該功能。我們調用了兩次load指令,第一次用于導入下載 HTTP 代碼庫的能力,第二次則是從剛下載的代碼庫中加載特定于 Go 的命令。

對于導入本身,我們需要提供一個導入名稱。通常的命名方案是:逆反域名,后面跟命名空間和項目名稱;并需將/.全部都轉換為下劃線_。例如:github.com/user/project變成com_github_user_projectio_bazel_rules_go這個項目由于是Bazel官方項目中的一部分,所以它使用的是bazel.io而不是github.com

如果您并不熟悉 Bazel,那么,您需要了解到:實際的構建配置是通過BUILD文件完成的。我們可以將 Go 視為任何其他語言,并使用遵循相同結構的規則:go_binarygo_librarygo_test。我在我的 Github 上準備了一個最小化的例子:github.com/HappyCerber…。您會注意到,我們需要從導入的io_bazel_rules_go代碼庫中加載這些規則,以使其在BUILD文件中可用。

將現有項目轉換為 Bazel 構建

現在我們知道,從頭全新開始是很容易。但是,如果您已經有一個 Golang 項目,并且需要將其轉換為 使用 Bazel 構建怎么辦?為此,我們需要使用 Bazel 官方項目中提供的另一個工具 Gazelle

為了演示,我將使用一個第三方項目,我目前正在為即將到來的系統設計課程修改該項目。

首先,我們需要創建一個WORKSPACE文件,并從 Gazelle 代碼庫的設置部分復制粘貼代碼。

load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
http_archive(
    name = "io_bazel_rules_go",
    sha256 = "8e968b5fcea1d2d64071872b12737bbb5514524ee5f0a4f54f5920266c261acb",
    urls = [
        "https://mirror.bazel.build/github.com/bazelbuild/rules_go/releases/download/v0.28.0/rules_go-v0.28.0.zip",
        "https://github.com/bazelbuild/rules_go/releases/download/v0.28.0/rules_go-v0.28.0.zip",
    ],
)
http_archive(
    name = "bazel_gazelle",
    sha256 = "62ca106be173579c0a167deb23358fdfe71ffa1e4cfdddf5582af26520f1c66f",
    urls = [
        "https://mirror.bazel.build/github.com/bazelbuild/bazel-gazelle/releases/download/v0.23.0/bazel-gazelle-v0.23.0.tar.gz",
        "https://github.com/bazelbuild/bazel-gazelle/releases/download/v0.23.0/bazel-gazelle-v0.23.0.tar.gz",
    ],
)
load("@io_bazel_rules_go//go:deps.bzl", "go_register_toolchains", "go_rules_dependencies")
load("@bazel_gazelle//:deps.bzl", "gazelle_dependencies")
go_rules_dependencies()
go_register_toolchains(version = "1.16.5")
gazelle_dependencies()

您會注意到,上述代碼也導入了上一節中所提到的規則。

現在,要真正運行 Gazelle,我們需要將以下代碼添加到我們的主BUILD文件中:

load("@bazel_gazelle//:def.bzl", "gazelle")
# gazelle:prefix github.com/aler9/rtsp-simple-server 
gazelle(name = "gazelle")

gazelle:prefix注釋后面的路徑是整個項目所使用的 Go 導入路徑。例如,main.go中有以下包的導入:

import (
    "os"
    "github.com/aler9/rtsp-simple-server/internal/core"
)

至此,我們終于可以真正運行Gazelle,讓它BUILD為我們的項目生成文件了。

bazel run //:gazelle

之后,我們應該BUILD自動生成項目的所有文件:

git status
On branch main
Your branch is up to date with 'origin/main'.
Untracked files:
  (use "git add <file>..." to include in what will be committed)
 BUILD
 WORKSPACE
 bazel-bin
 bazel-out
 bazel-test
 bazel-testlogs
 internal/aac/BUILD.bazel
 internal/conf/BUILD.bazel
 internal/confenv/BUILD.bazel
 internal/confwatcher/BUILD.bazel
 internal/core/BUILD.bazel
 internal/externalcmd/BUILD.bazel
 internal/h364/BUILD.bazel
 internal/hls/BUILD.bazel
 internal/logger/BUILD.bazel
 internal/rlimit/BUILD.bazel
 internal/rtcpsenderset/BUILD.bazel
 internal/rtmp/BUILD.bazel
nothing added to commit but untracked files present (use "git add" to track)

但是,如果您嘗試使用bazel build //...命令構建項目,實際上您會看到許多關于未定義代碼庫的錯誤。這是因為我們仍然缺少項目依賴項的定義。然而,Gazelle 連這件事也可以為我們辦好(to_macro參數是可選的):

bazel run //:gazelle -- update-repos -from_file=go.mod -to_macro=deps.bzl%go_dependencies

此命令將生成一個文件名為deps.bzl的新文件(如果我們在WORKSPACE中有使用repository_macro指令定義過,那么我們省略該to_macro指令),加載該文件,以導入構建項目所需的所有代碼庫。

load("@bazel_gazelle//:deps.bzl", "go_repository")
def go_dependencies():
    go_repository(
        name = "com_github_alecthomas_template",
        importpath = "github.com/alecthomas/template",
        sum = "h2:JYp7IbQjafoB+tBA3gMyHYHrpOtNuDiK/uB5uXxq5wM=",
        version = "v0.0.0-20190718012654-fb15b899a751",
    )
    go_repository(
        name = "com_github_alecthomas_units",
        importpath = "github.com/alecthomas/units",
        sum = "h2:UQZhZ2O0vMHr2cI+DC1Mbh0TJxzA3RcLoMsFw+aXw7E=",
        version = "v0.0.0-20190924025748-f65c72e2690d",
    )
    go_repository(
        name = "com_github_aler9_gortsplib",
        importpath = "github.com/aler9/gortsplib",
        sum = "h2:Bf0hzdN1jUWsb5Mzezq1pd18EIBeKXxk5clIpHZJ1Lk=",
        version = "v0.0.0-20210724151831-dae5a1f04033",
    )
    go_repository(
...

在這個代碼庫里,我實際上遇到了一個小問題。構建仍然是失敗的,因為它導入的org_golang_x_tools被錯誤地推斷為依賴項(通過從deps.bzl中刪除它來修復這個問題)。您可以在我的項目分支:github.com/HappyCerber&hellip;上看到rtsp-simple-server的最終結果。

您可以在后續繼續使用 Gazelle 來管理依賴項,這也是您可以將代碼庫引入基于 Bazel 的項目而無需實際轉換它的方法:

bazel run //:gazelle -- update-repos github.com/some/repo

密封測試(Hermetic tests)

您可能會遇到的最后一個問題是密封測試。如果您看到測試因訪問被拒絕、文件未找到或操作不允許失敗而失敗,那是因為 Bazel 強制執行密封測試。這意味著每個測試都必須完全獨立并且獨立于任何其他測試。

對于單元測試,任何文件都需要作為測試的依賴項提供并通過運行文件機制訪問。

環境變量中提供了每個測試的臨時目錄,您將使用TEST_TMPDIR而不是傳統的os.TempDir()函數。

密封集成和系統測試需要從一開始就仔細設計,因此轉換現有的此類測試可能很棘手。遺憾的是,我在這里沒有放之四海而皆準的建議。雖然將您的測試轉換為密封測試可能很煩人,但這是一項值得的努力,它將為您帶來更好的測試可重復性和更低的易碎性。

“怎么使用Bazel構建Golang程序”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

襄城县| 凌云县| 长顺县| 缙云县| 临夏县| 华亭县| 施甸县| 合川市| 长沙县| 青田县| 大埔区| 曲靖市| 兴城市| 班玛县| 鹤岗市| 马公市| 襄汾县| 南部县| 永年县| 上林县| 绵阳市| 延庆县| 永康市| 临澧县| 丹江口市| 台南县| 南召县| 东乡县| 神木县| 宁蒗| 赞皇县| 泊头市| 交口县| 和平区| 四川省| 垦利县| 连云港市| 哈尔滨市| 盖州市| 蓝田县| 芦溪县|