golang编译成Linux可运行文件

简介: 本文介绍了如何在 Linux 上编译和运行 Golang 程序,涵盖了本地编译和交叉编译的步骤。通过这些步骤,您可以轻松地将 Golang 程序编译成适合 Linux 平台的可执行文件,并在目标服务器上运行。掌握这些技巧,可以提高开发和部署 Golang 应用的效率。

使用 Golang 编译 Linux 可运行文件

Golang(或 Go)是一种开源编程语言,因其简单、高效、并发编程支持而备受欢迎。本文将详细介绍如何使用 Golang 编译生成可以在 Linux 上运行的可执行文件。

一、安装 Golang

1.1 下载 Golang

从 Golang 官方网站下载适合你操作系统的安装包:Golang 下载页面

1.2 安装 Golang

在 Ubuntu 上安装:

sudo apt update
sudo apt install -y golang
​

在 CentOS 上安装:

sudo yum update
sudo yum install -y golang
​

验证安装:

go version
​

输出类似于:

go version go1.16.3 linux/amd64
​

二、编写 Golang 程序

2.1 创建工作目录

mkdir -p ~/go/src/hello
cd ~/go/src/hello
​

2.2 编写示例程序

创建 main.go 文件并添加以下内容:

package main

import "fmt"

func main() {
    fmt.Println("Hello, World!")
}
​

三、编译 Golang 程序

3.1 本地编译

如果你在 Linux 环境下开发并编译,可以直接使用 go build 命令:

go build -o hello main.go
​

这将在当前目录生成一个名为 hello 的可执行文件。

3.2 交叉编译

如果你在非 Linux 环境(如 Windows 或 macOS)下开发,需要编译生成 Linux 可执行文件,可以使用交叉编译功能。

GOOS=linux GOARCH=amd64 go build -o hello main.go
​

其中:

  • GOOS=linux:目标操作系统为 Linux
  • GOARCH=amd64:目标架构为 64 位

3.3 编译选项

  • -o <filename>:指定输出文件的名称。
  • -v:输出详细的编译信息。
  • -a:强制重新编译所有包。
  • -ldflags:设置编译时的链接器参数。

示例:

go build -o hello -v -ldflags "-s -w" main.go
​

参数解释:

  • -s:去掉符号表信息。
  • -w:去掉 DWARF 调试信息。

四、运行编译后的可执行文件

4.1 在本地运行

./hello
​

输出:

Hello, World!
​

4.2 在目标 Linux 服务器上运行

  1. 使用 scprsync 将可执行文件传输到目标 Linux 服务器:
scp hello user@linux_server:/path/to/directory
​
  1. 在目标服务器上运行可执行文件:
ssh user@linux_server
cd /path/to/directory
chmod +x hello
./hello
​

五、常见问题及解决方案

5.1 编译过程中出现权限问题

确保你有权限在目标目录中创建和修改文件。使用 sudo 或切换到具有适当权限的用户。

5.2 交叉编译后无法运行

确保交叉编译的目标架构和操作系统设置正确。使用 GOOSGOARCH 变量指定正确的目标平台。

5.3 运行时报错缺少依赖库

Golang 编译的可执行文件通常是静态链接的,不依赖外部库。如果出现缺少依赖库的错误,检查是否使用了需要动态链接的 C 库。

六、总结

本文介绍了如何在 Linux 上编译和运行 Golang 程序,涵盖了本地编译和交叉编译的步骤。通过这些步骤,您可以轻松地将 Golang 程序编译成适合 Linux 平台的可执行文件,并在目标服务器上运行。掌握这些技巧,可以提高开发和部署 Golang 应用的效率。

目录
相关文章
|
2天前
|
弹性计算 人工智能 安全
对话 | ECS如何构筑企业上云的第一道安全防线
随着中小企业加速上云,数据泄露、网络攻击等安全威胁日益严重。阿里云推出深度访谈栏目,汇聚产品技术专家,探讨云上安全问题及应对策略。首期节目聚焦ECS安全性,提出三道防线:数据安全、网络安全和身份认证与权限管理,确保用户在云端的数据主权和业务稳定。此外,阿里云还推出了“ECS 99套餐”,以高性价比提供全面的安全保障,帮助中小企业安全上云。
对话 | ECS如何构筑企业上云的第一道安全防线
|
10天前
|
调度 云计算 芯片
云超算技术跃进,阿里云牵头制定我国首个云超算国家标准
近日,由阿里云联合中国电子技术标准化研究院主导制定的首个云超算国家标准已完成报批,不久后将正式批准发布。标准规定了云超算服务涉及的云计算基础资源、资源管理、运行和调度等方面的技术要求,为云超算服务产品的设计、实现、应用和选型提供指导,为云超算在HPC应用和用户的大范围采用奠定了基础。
179610 21
|
19天前
|
人工智能 自然语言处理 前端开发
从0开始打造一款APP:前端+搭建本机服务,定制暖冬卫衣先到先得
通义灵码携手科技博主@玺哥超carry 打造全网第一个完整的、面向普通人的自然语言编程教程。完全使用 AI,再配合简单易懂的方法,只要你会打字,就能真正做出一个完整的应用。
9560 27
|
5天前
|
机器学习/深度学习 分布式计算 供应链
阿里云先知安全沙龙(上海站) ——大模型基础设施安全攻防
大模型基础设施的安全攻防体系涵盖恶意输入防御和基础设施安全,包括框架、三方库、插件、平台、模型和系统安全。关键漏洞如CVE-2023-6019(Ray框架命令注入)、CVE-2024-5480(PyTorch分布式RPC)及llama.cpp中的多个漏洞,强调了代码安全性的重要性。模型文件安全方面,需防范pickle反序列化等风险,建议使用Safetensors格式。相关实践包括构建供应链漏洞库、智能化漏洞分析和深度检测,确保全方位防护。
|
7天前
|
JSON 分布式计算 数据处理
加速数据处理与AI开发的利器:阿里云MaxFrame实验评测
随着数据量的爆炸式增长,传统数据分析方法逐渐显现出局限性。Python作为数据科学领域的主流语言,因其简洁易用和丰富的库支持备受青睐。阿里云推出的MaxFrame是一个专为Python开发者设计的分布式计算框架,旨在充分利用MaxCompute的强大能力,提供高效、灵活且易于使用的工具,应对大规模数据处理需求。MaxFrame不仅继承了Pandas等流行数据处理库的友好接口,还通过集成先进的分布式计算技术,显著提升了数据处理的速度和效率。
|
23天前
|
Cloud Native Apache 流计算
资料合集|Flink Forward Asia 2024 上海站
Apache Flink 年度技术盛会聚焦“回顾过去,展望未来”,涵盖流式湖仓、流批一体、Data+AI 等八大核心议题,近百家厂商参与,深入探讨前沿技术发展。小松鼠为大家整理了 FFA 2024 演讲 PPT ,可在线阅读和下载。
5169 15
资料合集|Flink Forward Asia 2024 上海站
|
3天前
|
机器学习/深度学习 人工智能 安全
通义视觉推理大模型QVQ-72B-preview重磅上线
Qwen团队推出了新成员QVQ-72B-preview,这是一个专注于提升视觉推理能力的实验性研究模型。提升了视觉表示的效率和准确性。它在多模态评测集如MMMU、MathVista和MathVision上表现出色,尤其在数学推理任务中取得了显著进步。尽管如此,该模型仍存在一些局限性,仍在学习和完善中。
|
1月前
|
人工智能 自动驾驶 大数据
预告 | 阿里云邀您参加2024中国生成式AI大会上海站,马上报名
大会以“智能跃进 创造无限”为主题,设置主会场峰会、分会场研讨会及展览区,聚焦大模型、AI Infra等热点议题。阿里云智算集群产品解决方案负责人丛培岩将出席并发表《高性能智算集群设计思考与实践》主题演讲。观众报名现已开放。
|
15天前
|
Docker 容器
|
18天前
|
消息中间件 人工智能 运维
12月更文特别场——寻找用云高手,分享云&AI实践
我们寻找你,用云高手,欢迎分享你的真知灼见!
1340 76