24.1 部署-交叉编译、压缩二进制文件、Docker容器

2024-06-19 09:28

本文主要是介绍24.1 部署-交叉编译、压缩二进制文件、Docker容器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 交叉编译

Go语言的优越性之一是可在众多环境下运行,其中包括:

  • 操作系统
    • windows、darwin、plan9、solaris、linux、netbsd/openbsd/freebsd、android
  • 体系架构
    • 386/amd64、arm/arm64、ppc64/ppc64le、mips/mipsle/mips64/mips64le

使用go env命令可以查看当前系统环境。

  • 64位Windows 10
    • GOOS=windows
    • GOARCH=amd64
  • 32位Ubuntu 16
    • GOOS=linux
    • GOARCH=386

所谓交叉编译,是指在任意平台上基于一份源代码,编译生成可运行于其它任意平台的二进制可执行文件。

在执行go build命令时,设置以下两个环境变量:

  • 通过GOOS指定目标操作系统
  • 通过GOARCH指定目标体系架构

在64位Windows 10上编译生成可运行于32位Ubuntu 16的可执行文件:

  • GOOS=linux GOARCH=386 go build main.go

在32位Ubuntu 16上编译生成可运行于64位Windows 10的可执行文件:

  • GOOS=windows GOARCH=amd64 go build main.go
// 交叉编译
// 执行如下命令,分别为32和64位Windows操作系统构建可执行程序:
// 
// GOOS=windows GOARCH=386 go build -o win32.exe main.go 
// GOOS=windows GOARCH=amd64 go build -o win64.exe main.go 
package mainimport ("fmt""unsafe"
)func main() {var i int fmt.Println(unsafe.Sizeof(i))
}
// 打印输出:PS > ./win32.exe4PS > ./win64.exe8

 2. 压缩二进制文件

发布Go语言编译生成的二进制可执行程序非常简单,其中包含了程序运行所需要的一切,因此无需考虑依赖问题。

  • 执行如下命令,构建原始大小的二进制文件:
    • go build -o large.exe main.go

即便是不足1KB的源代码文件(如main.go),编译生成的可执行文件(如large.exe)也高达近1.9MB。

  • Go语言编译生成的可执行文件中包含了整个Go语言运行时环境,虽然其体积较大,但它不需要任何依赖,就能在编译时指定的目标平台上直接运行。
  • 编译时指定省略符号表调试信息DWARF表,得到的可执行文件会略小一些(1.3MB)。
    • go build -o medium.exe -ldflags="-s -w" main.go 

如果希望得到更小的可执行文件,可以考虑使用二进制压缩工具UPX,但这样得到的可执行文件在运行时会先自动解压缩,因此启动时间会稍长

  • 执行如下命令,借助UPX工具将可执行文件进一步压缩至478KB:
    • upx -o small.exe medium.exe

注:针对windows系统,upx5.91以上版本才可以兼任64为.exe文件的压缩。

压缩二进制可执行文件大小的重要性取决于程序的部署场景。

  • 经高速网络部署到服务器上的可执行程序,通常无需考虑大小问题
  • 部署在存储空间有限的硬件设备上的可执行程序,当然是越小越好
  • 通过包管理器下载的命令行工具,文件大小的重要性介于二者之间

Go语言设计小组正在不懈努力,以进一步压缩编译器生成的二进制可执行文件的体积,每推出一个新版本,可执行文件的字节数都会有所下降。

// 压缩二进制文件
// 执行如下命令,构建原始大小的二进制文件:
// go build -o large.exe main.go 
// 执行如下命令,在构建过程中省略符号表、调试信息和DWARF表,以压缩二进制文件的大小:
// go build -o medium.exe -ldflags="-s -w" main.go 
// 执行如下命令,借助UPX工具对二进制文件做进一步压缩:
// ./upx/upx -o small.exe medium.exe
package main
import ("fmt""unsafe"
)func main() {var i int fmt.Println(unsafe.Sizeof(i))
}

3. Docker容器

Docker是一种在虚拟机中运行应用程序的流行方式,它提供了一种轻量级的方式,可确保无论计算机使用的是哪种操作系统和硬件架构,应用程序都能在完全相同的环境中运行。

Docker使用容器来确保应用程序位于操作系统的沙箱环境之中,其开销比完整的虚拟机要小。

通过Docker可以建立部署管道,这意味着开发人员只需将源代码提交到仓库,几分钟后它们就以可执行文件的形式,被自动发布到基于不同操作系统和硬件架构的生产环境之中。

Docker可用于WindowsLinuxmacOS等操作系统。

Go语言官方网站维护着一些Docker映像,可以直接在里面编译代码并运行。

// web服务器
// 侦听8000端口的Web服务器 
package mainimport "net/http"func rootHandler(w http.ResponseWriter,r *http.Request) {w.Write([]byte("Hello World!"))
}func main() {http.HandleFunc("/", rootHandler)http.ListenAndServe(":8000", nil)
}

基于Go语言的Web服务器已开发完成,准备部署到生产环境。

  • main.go

编写一个Docker文件,包含以下内容:

  • 将Go语言源代码文件复制到容器中
  • 编译Go语言源文件得到可执行文件
  • 暴露该Go语言服务器的侦听端口号

执行如下命令,在本地计算机上构建映像

  • docker build -t server-go

执行如下命令,在本地计算机上运行容器

  • docker run -p 8000:8000 server-go:latest

执行如下命令,查看容器标识并关闭容器

  • docker ps
  • docker stop <容器标识>

// Docker文件
FROM golang:1.9
COPY main.go /		-- 复制main.go到docker容器的根目录
RUN go build -o /server /main.go	-- 对main.go在docker虚拟机环境中进行编译
EXPOSE 8000		--暴露容器的8000端口
ENTRYPOINT ["/server"]	--容器的执行入口

这篇关于24.1 部署-交叉编译、压缩二进制文件、Docker容器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1074633

相关文章

闲置电脑也能活出第二春?鲁大师AiNAS让你动动手指就能轻松部署

对于大多数人而言,在这个“数据爆炸”的时代或多或少都遇到过存储告急的情况,这使得“存储焦虑”不再是个别现象,而将会是随着软件的不断臃肿而越来越普遍的情况。从不少手机厂商都开始将存储上限提升至1TB可以见得,我们似乎正处在互联网信息飞速增长的阶段,对于存储的需求也将会不断扩大。对于苹果用户而言,这一问题愈发严峻,毕竟512GB和1TB版本的iPhone可不是人人都消费得起的,因此成熟的外置存储方案开

如何用Docker运行Django项目

本章教程,介绍如何用Docker创建一个Django,并运行能够访问。 一、拉取镜像 这里我们使用python3.11版本的docker镜像 docker pull python:3.11 二、运行容器 这里我们将容器内部的8080端口,映射到宿主机的80端口上。 docker run -itd --name python311 -p

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

hdu1565(状态压缩)

本人第一道ac的状态压缩dp,这题的数据非常水,很容易过 题意:在n*n的矩阵中选数字使得不存在任意两个数字相邻,求最大值 解题思路: 一、因为在1<<20中有很多状态是无效的,所以第一步是选择有效状态,存到cnt[]数组中 二、dp[i][j]表示到第i行的状态cnt[j]所能得到的最大值,状态转移方程dp[i][j] = max(dp[i][j],dp[i-1][k]) ,其中k满足c

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

maven 编译构建可以执行的jar包

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」👈,「stormsha的知识库」👈持续学习,不断总结,共同进步,为了踏实,做好当下事儿~ 专栏导航 Python系列: Python面试题合集,剑指大厂Git系列: Git操作技巧GO

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

容器编排平台Kubernetes简介

目录 什么是K8s 为什么需要K8s 什么是容器(Contianer) K8s能做什么? K8s的架构原理  控制平面(Control plane)         kube-apiserver         etcd         kube-scheduler         kube-controller-manager         cloud-controlle

在 Windows 上部署 gitblit

在 Windows 上部署 gitblit 在 Windows 上部署 gitblit 缘起gitblit 是什么安装JDK部署 gitblit 下载 gitblit 并解压配置登录注册为 windows 服务 修改 installService.cmd 文件运行 installService.cmd运行 gitblitw.exe查看 services.msc 缘起