Golang Linux系统下源码编译安装步骤

答案是:从源码编译安装Golang需先获取源码并配置构建环境,再通过引导Go版本编译生成二进制文件,最后设置GOROOT、GOPATH和PATH环境变量以完成配置。

golang linux系统下源码编译安装步骤

在Linux系统下从源码编译安装Golang,核心步骤无非是获取Go的源代码,然后通过系统自带的编译工具链将其构建成可执行文件,并最终配置好相应的环境变量。这通常是为了获取最新的Go版本、进行特定环境的定制,或者仅仅是想深入了解Go的构建过程。

解决方案

要从源码编译安装Golang,你需要确保系统具备一些基本的构建工具,比如

gcc

git

。如果你之前没有安装过Go,或者想编译一个比当前系统Go版本更新的版本,你可能还需要一个旧版本的Go作为引导(bootstrap)。

准备构建环境确保你的Linux发行版安装了C编译器(通常是

gcc

)和

git

。例如,在Debian/Ubuntu系:

sudo apt updatesudo apt install build-essential git

在CentOS/RHEL系:

立即学习“go语言免费学习笔记(深入)”;

sudo yum groupinstall "Development Tools"sudo yum install git

获取Go源代码Go的源代码托管在GitHub上。你可以选择克隆官方仓库:

git clone https://go.googlesource.com/go $HOME/go-src

这里我习惯性地把它放到

$HOME/go-src

,你可以选择任何你觉得合适的地方。如果你想编译特定版本,克隆后记得切换到对应的tag:

cd $HOME/go-srcgit checkout go1.22.0 # 替换为你想要的版本

设置引导Go版本 (GOROOT_BOOTSTRAP)这一步非常关键,也常常是新手容易忽略的地方。Go是用Go语言自身编写的,所以编译Go需要一个已经存在的Go编译器。

如果你是首次安装Go,或者想编译的Go版本与当前系统Go版本差异较大,你需要下载一个预编译的二进制版本作为引导。可以从Go官方下载页面下载一个与你目标版本相近的稳定版本,解压到某个目录,比如

$HOME/go-bootstrap

。然后设置环境变量

GOROOT_BOOTSTRAP

指向这个引导Go的安装路径。

export GOROOT_BOOTSTRAP=$HOME/go-bootstrap/go

如果你的系统已经有一个足够新(通常是比你目标版本早两三个小版本以内)的Go环境,并且它的

GOROOT

已经设置在

PATH

中,那么这一步可以省略,构建脚本会尝试使用它。但为了稳妥起见,明确指定通常更好。

开始编译进入源代码的

src

目录,并执行

all.bash

脚本。这个脚本会完成所有的编译工作。

cd $HOME/go-src/src./all.bash

这个过程可能会持续几分钟到十几分钟,具体取决于你的机器性能。如果一切顺利,你会看到

ALL TESTS PASSED

的字样。

配置环境变量编译完成后,Go的二进制文件会生成在

$HOME/go-src/bin

目录下。你需要将这个路径添加到系统的

PATH

环境变量中,并设置

GOROOT

GOPATH

。编辑你的shell配置文件,比如

~/.bashrc

~/.zshrc

~/.profile

# Go 语言的安装路径export GOROOT=$HOME/go-src# Go 语言的工作空间,用于存放你的项目代码和第三方库export GOPATH=$HOME/go# 将 Go 的 bin 目录添加到 PATHexport PATH=$PATH:$GOROOT/bin:$GOPATH/bin

保存文件后,执行

source ~/.bashrc

(或其他对应文件)使环境变量生效。

验证安装打开一个新的终端,运行

go version

go env

来验证Go是否正确安装和配置。

go versiongo env

如果显示了你编译的Go版本信息,并且

go env

中的

GOROOT

GOPATH

指向你设置的路径,那么恭喜你,安装成功了。

为什么选择源码编译安装Golang,而不是使用包管理器?

选择从源码编译安装Go,而不是简单地通过

apt

yum

brew

等包管理器,这背后通常有几个驱动因素,它并非总是最优解,但特定场景下却显得不可或缺。

首先,版本控制的极致需求。包管理器提供的Go版本往往不是最新的,或者说,它们在更新速度上总是滞后于Go官方发布。对于那些希望第一时间体验Go最新特性、测试某个即将发布的版本,或者需要针对特定Go版本进行开发和调试的开发者来说,源码编译是获取“第一手”Go版本的唯一途径。有时,你甚至可能需要编译Go的开发分支(

master

分支),以便参与Go语言本身的开发,或者测试某个还未合入主线的实验性功能。

其次,定制化和透明度。源码编译给了你完全的控制权。你可以检查、修改甚至调试Go语言自身的代码。这对于那些需要深入理解Go运行时、垃圾回收机制,或者想为Go贡献代码的开发者来说,是极其宝贵的。虽然普通开发者很少会去修改Go语言本身,但了解其构建过程,对理解整个生态系统都有帮助。比如,你可能想在某个嵌入式系统上编译Go,而那个系统没有现成的Go包,那么源码编译就是唯一的路。

当然,我们也要承认,源码编译带来的复杂性也更高。它需要你手动处理依赖、设置环境变量,并且在更新时也需要重复这些步骤。而包管理器则省去了这些麻烦,自动化程度高,对于日常开发来说,通常是更便捷的选择。所以,在选择编译方式时,我总是会权衡:我是否真的需要最新版本?我是否需要对Go本身进行定制或深入研究?如果答案是肯定的,那么源码编译就是值得投入的。

源码编译过程中常见的错误及如何排查?

源码编译Go虽然提供极致的控制,但也意味着你可能会遇到一些比包管理器安装更“原始”的问题。这些错误往往指向环境配置或依赖缺失。

go: cannot find GOROOT directory” 或 “go: cannot find GOROOT_BOOTSTRAP”

原因分析:这是最常见的错误之一。它通常意味着你的系统找不到一个可用的Go编译器来启动构建过程。

GOROOT_BOOTSTRAP

没有正确设置,或者指向的路径不包含一个有效的Go安装。排查方法:检查

GOROOT_BOOTSTRAP

环境变量是否已设置,并且其值是否指向一个完整且可用的Go安装目录(例如

$HOME/go-bootstrap/go

,而不是

$HOME/go-bootstrap/go/bin

)。确保你下载的引导Go版本与你的系统架构兼容,并且其二进制文件(如

go

命令)存在于

$GOROOT_BOOTSTRAP/bin

下。如果你的系统已经有Go,可以尝试先

unset GOROOT_BOOTSTRAP

,让

all.bash

脚本尝试使用系统默认的Go。

“gcc: command not found” 或 “make: command not found”

原因分析:你的系统缺少基本的C/C++编译器或构建工具。Go的运行时和一些标准库是用C编写的,需要这些工具来编译。排查方法:在Debian/Ubuntu上运行

sudo apt install build-essential

。在CentOS/RHEL上运行

sudo yum groupinstall "Development Tools"

。确认安装完成后,再次尝试编译。

网络连接问题导致依赖获取失败

原因分析:在编译过程中,Go可能会尝试从网络下载一些模块或工具。如果你的网络不稳定或者有防火墙限制,这部分可能会失败。排查方法:确保你的网络连接正常。如果是在公司内部网络,可能需要配置代理。Go支持

HTTP_PROXY

HTTPS_PROXY

环境变量。检查是否有

GOPROXY

环境变量,有时错误的

GOPROXY

设置也会导致下载失败。可以尝试

unset GOPROXY

权限问题

原因分析:如果你尝试将Go编译或安装到系统目录(如

/usr/local/go

)而没有足够的权限,可能会遇到写入失败的错误。排查方法:确保你正在编译的目录(例如

$HOME/go-src

)你有完全的读写权限。如果一定要安装到系统目录,使用

sudo

命令,但这通常不推荐直接在源码编译时使用,因为可能会导致一些文件权限混乱。更好的做法是编译到用户目录,然后将

GOROOT/bin

添加到全局

PATH

遇到错误时,最重要的是仔细阅读终端输出的错误信息。Go的构建脚本通常会给出相当详细的提示。同时,查阅Go官方的安装文档也是一个好习惯,它会提供最新的编译指南和常见问题解答。

如何正确配置Golang环境变量以确保系统识别?

正确配置Go语言的环境变量是确保系统能够找到并执行Go命令、管理项目依赖以及构建应用程序的关键。这不仅仅是把Go的路径加到

PATH

里那么简单,

GOROOT

GOPATH

这两个核心变量扮演着不同的角色,理解它们对于高效使用Go至关重要。

GOROOT

:Go语言的安装根目录

作用:它指向Go语言SDK本身的安装位置。Go编译器、标准库、工具链(如

go build

,

go run

,

go test

等)都位于这个目录下。系统需要知道

GOROOT

才能找到这些核心组件。配置:在源码编译后,

GOROOT

通常就是你克隆Go源代码的目录,也就是Go编译后的产物所在目录。

export GOROOT=$HOME/go-src # 假设你将源码编译到此

GOPATH

:Go语言的工作空间

作用:在Go Modules出现之前,

GOPATH

是Go项目组织代码、存放第三方库和编译生成二进制文件的默认工作空间。它通常包含三个子目录:

src

:存放你的Go项目源代码和第三方库源代码。

pkg

:存放编译后的包文件(

.a

文件)。

bin

:存放通过

go install

命令编译生成的二进制可执行文件。Go Modules时代的变化:自Go 1.11引入Go Modules后,

GOPATH

对于依赖管理的重要性大大降低。项目不再强制要求放在

GOPATH/src

下,依赖也通过

go.mod

文件在项目目录内管理。然而,

GOPATH/bin

仍然是一个非常重要的目录,许多Go工具(如

gopls

delve

等)通过

go install 

安装后,它们的二进制文件会默认存放在

$GOPATH/bin

中。因此,保持

GOPATH

的设置,并将其

bin

目录加入

PATH

,仍然是最佳实践。配置:你可以将其设置为你希望的任何目录,通常是用户主目录下的一个子目录。

export GOPATH=$HOME/go # 这是一个常见的设置,你也可以选择其他路径

确保这个目录存在:

mkdir -p $HOME/go

PATH

:系统可执行文件搜索路径

作用:这是Linux系统用来查找可执行命令的目录列表。当你输入一个命令时,系统会按顺序在

PATH

中的每个目录里查找该命令。配置:你需要将

$GOROOT/bin

$GOPATH/bin

都添加到

PATH

中,这样你才能直接在任何终端运行

go

命令,以及通过

go install

安装的各种Go工具。

export PATH=$PATH:$GOROOT/bin:$GOPATH/bin

注意,

$PATH

在前,保证了系统原有的命令优先级。

将环境变量持久化

为了让这些环境变量在每次打开新终端时都自动生效,你需要将它们添加到你的shell配置文件中。最常见的配置文件是

~/.bashrc

(Bash shell)、

~/.zshrc

(Zsh shell)或

~/.profile

编辑文件:使用你喜欢的文本编辑器打开这些文件,例如:

nano ~/.bashrc

添加内容:将上述三行

export

命令添加到文件末尾。保存并生效:保存文件后,在当前终端执行

source ~/.bashrc

(或对应文件)来立即加载新的环境变量。对于新打开的终端,这些变量会自动生效。

验证配置

在完成配置并使之生效后,务必打开一个新的终端窗口,然后运行以下命令进行验证:

go versiongo env GOROOTgo env GOPATHecho $PATH

确保

go version

显示的是你编译的Go版本,

go env GOROOT

go env GOPATH

显示的是你设置的路径,并且

echo $PATH

的输出中包含了

$GOROOT/bin

$GOPATH/bin

。如果一切正常,你的Go环境就配置成功了,可以开始愉快的Go开发之旅了。

以上就是Golang Linux系统下源码编译安装步骤的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1403122.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月15日 19:18:35
下一篇 2025年12月15日 19:18:52

相关推荐

  • 如何用dom2img解决网页打印样式不显示的问题?

    用dom2img解决网页打印样式不显示的问题 想将网页以所见即打印的的效果呈现,需要采取一些措施,特别是在使用了bootstrap等大量采用外部css样式的框架时。 问题根源 在常规打印操作中,浏览器通常会忽略css样式等非必要的页面元素,导致打印出的结果与网页显示效果不一致。这是因为打印机制只识别…

    2025年12月24日
    800
  • Bootstrap 中如何让文字浮于阴影之上?

    文字浮于阴影之上 文中提到的代码片段中 元素中的文字被阴影元素 所遮挡,如何让文字显示在阴影之上? bootstrap v3和v5在处理此类问题方面存在差异。 解决方法 在bootstrap v5中,给 元素添加以下css样式: .banner-content { position: relativ…

    2025年12月24日
    000
  • Bootstrap 5:如何将文字置于阴影之上?

    文字重叠阴影 在 bootstrap 5 中,将文字置于阴影之上时遇到了困难。在 bootstrap 3 中,此问题并不存在,但升级到 bootstrap 5 后却无法实现。 解决方案 为了解决这个问题,需要给 元素添加以下样式: .banner-content { position: relati…

    2025年12月24日
    400
  • Bootstrap 5 如何将文字置于阴影上方?

    如何在 bootstrap 5 中让文字位于阴影上方? 在将网站从 bootstrap 3 升级到 bootstrap 5 后,用户遇到一个问题:文字内容无法像以前那样置于阴影层之上。 解决方案: 为了将文字置于阴影层上方,需要给 banner-content 元素添加以下 css 样式: .ban…

    2025年12月24日
    100
  • HTML、CSS 和 JavaScript 中的简单侧边栏菜单

    构建一个简单的侧边栏菜单是一个很好的主意,它可以为您的网站添加有价值的功能和令人惊叹的外观。 侧边栏菜单对于客户找到不同项目的方式很有用,而不会让他们觉得自己有太多选择,从而创造了简单性和秩序。 今天,我将分享一个简单的 HTML、CSS 和 JavaScript 源代码来创建一个简单的侧边栏菜单。…

    2025年12月24日
    200
  • 前端代码辅助工具:如何选择最可靠的AI工具?

    前端代码辅助工具:可靠性探讨 对于前端工程师来说,在HTML、CSS和JavaScript开发中借助AI工具是司空见惯的事情。然而,并非所有工具都能提供同等的可靠性。 个性化需求 关于哪个AI工具最可靠,这个问题没有一刀切的答案。每个人的使用习惯和项目需求各不相同。以下是一些影响选择的重要因素: 立…

    2025年12月24日
    300
  • 带有 HTML、CSS 和 JavaScript 工具提示的响应式侧边导航栏

    响应式侧边导航栏不仅有助于改善网站的导航,还可以解决整齐放置链接的问题,从而增强用户体验。通过使用工具提示,可以让用户了解每个链接的功能,包括设计紧凑的情况。 在本教程中,我将解释使用 html、css、javascript 创建带有工具提示的响应式侧栏导航的完整代码。 对于那些一直想要一个干净、简…

    2025年12月24日
    000
  • 布局 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在这里查看视觉效果: 固定导航 – 布局 – codesandbox两列 – 布局 – codesandbox三列 – 布局 – codesandbox圣杯 &#8…

    2025年12月24日
    000
  • 隐藏元素 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看隐藏元素的视觉效果 – codesandbox 隐藏元素 hiding elements hiding elements hiding elements hiding elements hiding element…

    2025年12月24日
    400
  • HTMLrev 上的免费 HTML 网站模板

    HTMLrev 是唯一的人工策划的库专门专注于免费 HTML 模板,适用于由来自世界各地慷慨的模板创建者制作的网站、登陆页面、投资组合、博客、电子商务和管理仪表板世界。 这个人就是我自己 Devluc,我已经工作了 1 年多来构建、改进和更新这个很棒的免费资源。我自己就是一名模板制作者,所以我知道如…

    2025年12月24日
    300
  • 居中 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看垂直中心 – codesandbox 和水平中心的视觉效果。 通过 css 居中 垂直居中 centering centering centering centering centering centering立即…

    2025年12月24日 好文分享
    300
  • 如何在 Laravel 框架中轻松集成微信支付和支付宝支付?

    如何用 laravel 框架集成微信支付和支付宝支付 问题:如何在 laravel 框架中集成微信支付和支付宝支付? 回答: 建议使用 easywechat 的 laravel 版,easywechat 是一个由腾讯工程师开发的高质量微信开放平台 sdk,已被广泛地应用于许多 laravel 项目中…

    2025年12月24日
    000
  • 如何在移动端实现子 div 在父 div 内任意滑动查看?

    如何在移动端中实现让子 div 在父 div 内任意滑动查看 在移动端开发中,有时我们需要让子 div 在父 div 内任意滑动查看。然而,使用滚动条无法实现负值移动,因此需要采用其他方法。 解决方案: 使用绝对布局(absolute)或相对布局(relative):将子 div 设置为绝对或相对定…

    2025年12月24日
    000
  • 移动端嵌套 DIV 中子 DIV 如何水平滑动?

    移动端嵌套 DIV 中子 DIV 滑动 在移动端开发中,遇到这样的问题:当子 DIV 的高度小于父 DIV 时,无法在父 DIV 中水平滚动子 DIV。 无限画布 要实现子 DIV 在父 DIV 中任意滑动,需要创建一个无限画布。使用滚动无法达到负值,因此需要使用其他方法。 相对定位 一种方法是将子…

    2025年12月24日
    000
  • 移动端项目中,如何消除rem字体大小计算带来的CSS扭曲?

    移动端项目中消除rem字体大小计算带来的css扭曲 在移动端项目中,使用rem计算根节点字体大小可以实现自适应布局。但是,此方法可能会导致页面打开时出现css扭曲,这是因为页面内容在根节点字体大小赋值后重新渲染造成的。 解决方案: 要避免这种情况,将计算根节点字体大小的js脚本移动到页面的最前面,即…

    2025年12月24日
    000
  • Nuxt 移动端项目中 rem 计算导致 CSS 变形,如何解决?

    Nuxt 移动端项目中解决 rem 计算导致 CSS 变形 在 Nuxt 移动端项目中使用 rem 计算根节点字体大小时,可能会遇到一个问题:页面内容在字体大小发生变化时会重绘,导致 CSS 变形。 解决方案: 可将计算根节点字体大小的 JS 代码块置于页面最前端的 标签内,确保在其他资源加载之前执…

    2025年12月24日
    200
  • Nuxt 移动端项目使用 rem 计算字体大小导致页面变形,如何解决?

    rem 计算导致移动端页面变形的解决方法 在 nuxt 移动端项目中使用 rem 计算根节点字体大小时,页面会发生内容重绘,导致页面打开时出现样式变形。如何避免这种现象? 解决方案: 移动根节点字体大小计算代码到页面顶部,即 head 中。 原理: flexível.js 也遇到了类似问题,它的解决…

    2025年12月24日
    000
  • 形状 – CSS 挑战

    您可以在 github 仓库中找到这篇文章中的所有代码。 您可以在此处查看 codesandbox 的视觉效果。 通过css绘制各种形状 如何在 css 中绘制正方形、梯形、三角形、异形三角形、扇形、圆形、半圆、固定宽高比、0.5px 线? shapes 0.5px line .square { w…

    2025年12月24日
    000
  • 如何用 CSS 禁止手机端页面屏幕拖动?

    css 禁止手机端屏幕拖动 在手机端浏览网页时,常常会遇到屏幕拖动导致页面内容错乱或无法操作的情况。为了解决这个问题,可以使用 css 的 overflow 属性来禁止屏幕拖动。 解决方案 针对给定的代码,可以在 元素中添加以下 css 样式: 立即学习“前端免费学习笔记(深入)”; body{ov…

    2025年12月24日
    000
  • 如何禁用手机端屏幕拖动功能?

    解决手机端屏幕拖动问题 在移动设备上,当设备屏幕存在内容超出边界时,可以通过拖动屏幕来浏览。但有时,我们希望禁用这种拖动功能,例如当导航菜单展开时。 实施方法 要禁止屏幕拖动,可以为 body 元素添加 overflow:hidden 样式。这将禁用滚动条并阻止屏幕拖动,无论内容是否超出边界。 以下…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信