为什么Golang开发的软件单文件直接丢到各种Linux系统就能运行?

开发 后端 Linux
那么Go语言是如何独步江湖的呢?Go的编译器生成的静态链接的GO应用二进制文件,已包含了可供完整载入内存和需要的所有指令。

提到跨平台开发,就首先想到C语言,准确的说应该叫ANSI C。

ANSI C是由美国国家标准协会(ANSI)及国际标准化组织(ISO)推出的关于C语言的标准。ANSI C 主要标准化了现存的实现, 同时增加了一些来自 C++ 的内容 (主要是函数原型) 并支持多国字符集 (包括备受争议的三字符序列)。ANSI C 标准同时规定了 C 运行期库例程的标准。一些开源项目根据ANSI C标准进行开发后,可移植行就非常好。

但无奈,随着新指令集的CPU不断出现,如果开发者自己要从ANSI C方式去编码,实现减少由于不同软硬件架构的差异对上层应用的影响,那属实要做很大的基础工作。

所以当更加专业的语言Go出来后,由于设计者基于既往设计C语言的成功经验去粗取精,又结合近二三十年来的CPU架构和操作系统、云计算的新趋势,而造出了Go这样的多平台多CPU通吃的语言。正是这种定位,所以Go语言在可执行文件的链接方面就与众不同。

比如当小白不小心把linux系统的底层加载程序 ld-linux.so 文件删掉了,

准备跑路吧~~ 

因为此后系统内所有 C/C++/Python/Nodejs/PHP/Java等语言开发编译的可执行文件,全都启动失败,出现莫名其妙的错误,比如cp命令是存在于 /usr/bin/cp 路径的文件,但此时调用cp,报错No such file or directry 。

这是因为以上Python等所列的语言,本质上都是C语言开发的,它们的可执行文件的底层链接的系统动态库,要想运行都先依赖于 ld-linux.so 帮它们处理好ELF的二进制可执行文件、链接库的代码段落、数据段等内容加载到内存,然后CPU根据二进制指令执行代码逻辑,处理数据,完成计算任务。而这个底层的 ld-linux.so 动态库文件一旦自身不保,那么,其他依赖的软件当然全部异常。

而我们之前编译的Go的main函数测试二进制文件main。仍然能启动。

那么Go语言是如何独步江湖的呢?可以推断,Go的链接方式不使用ld-linux.so。

Go的编译器生成的静态链接的GO应用二进制文件,已包含了可供完整载入内存和需要的所有指令。既然这样,不管是Linux发行版A还是B系统自带的glibC 的版本是否过时,是否过新,跟GO能否正常运行关系不大。GO软件运行所需的都已经自给自足了。也因此Go可以带着它的干粮,不管丢到哪里就可以在那里运行。

当然,这离不开Go语言开发团队背后做了很多底层适配兼容,帮应用开发者省去了这份操心。也让这门语言兑现了它所吹过的牛。

下图为Golang 最新版1.21.5所支持的CPU架构、操作系统信息,实际Go目前能支持的已经超过这些平台范围。部分小众的系统架构也支持,图中未列出。

责任编辑:赵宁宁 来源: 深入理解Linux
相关推荐

2020-12-30 10:04:46

userMapper接口

2020-10-21 09:16:49

Linux开源操作系统

2014-08-04 15:30:39

Linux开源软件

2022-02-13 20:31:26

SpringBootjarmanifests

2020-05-07 16:30:32

Spring BootJava

2024-04-03 09:01:34

SpringTomcat容器

2023-11-30 08:16:19

SpringjarTomcat

2021-04-18 18:12:07

Linux开发操作系统

2021-03-10 09:40:50

Linux命令文件

2011-01-10 15:55:20

LinuxWindowsWine

2010-06-13 15:26:42

2016-11-08 11:06:20

2019-07-29 07:50:42

Linux内存Windows

2018-07-27 09:41:45

Linux系统服务器

2020-07-15 09:29:23

Python开发工具

2020-07-06 07:37:58

Linux虚拟

2020-09-09 09:38:47

GoLangNodeJS编程语言

2010-06-07 14:13:10

Linux 开发工具

2011-03-24 09:28:47

Linux文件系统barrier

2009-12-14 18:27:21

Linux操作系统
点赞
收藏

51CTO技术栈公众号