首页
/ solisoft/fasty项目ARMv8架构Docker镜像构建指南

solisoft/fasty项目ARMv8架构Docker镜像构建指南

2025-07-06 00:57:36作者:庞队千Virginia

概述

本文详细解析solisoft/fasty项目中针对ARMv8架构的Docker镜像构建过程。该Dockerfile精心设计,为ARMv8平台构建了一个完整的Web应用开发环境,集成了OpenResty、Lua生态系统、Node.js工具链以及多个关键依赖库。

基础镜像选择

构建过程从Ubuntu 20.04基础镜像开始,这是一个长期支持(LTS)版本,提供了稳定的基础环境:

FROM ubuntu:20.04

选择这个版本是因为它在ARM架构上有良好的支持,并且社区维护周期长,适合生产环境使用。

系统依赖安装

首先安装了一系列基础开发工具和库:

RUN apt-get -qq update && apt-get -qqy install vim zlib1g-dev libreadline-dev \
    libncurses5-dev libpcre3-dev libssl-dev gcc perl make git-core \
    libsass-dev glib2.0-dev libexpat1-dev \
    libjpeg-dev libwebp-dev libpng-dev libexif-dev libgif-dev wget \
    libx265-dev libde265-dev libheif-dev build-essential pkg-config libglib2.0-dev python3-pip libgirepository1.0-dev

这些依赖包括:

  • 开发工具链(gcc, make等)
  • 图像处理相关库(libjpeg, libpng等)
  • 网络和安全相关库(libssl-dev等)
  • Python工具链(python3-pip)

构建系统配置

项目使用了Meson和Ninja作为构建系统:

RUN pip3 install --user meson
RUN pip3 install --user ninja
RUN mv ~/.local/bin/meson /usr/bin/meson
RUN mv ~/.local/bin/ninja /usr/bin/ninja

Meson是一个现代化的构建系统,相比传统的autotools或CMake,它更简洁高效,特别适合大型项目。Ninja则是一个小型构建系统,专注于速度。

VIPS图像处理库安装

VIPS是一个高效的图像处理库,被许多现代Web应用使用:

ARG VIPS_VERSION=8.14.5
RUN wget https://github.com/libvips/libvips/archive/refs/tags/v${VIPS_VERSION}.tar.gz \
    && tar -xf v${VIPS_VERSION}.tar.gz \
    && cd libvips-${VIPS_VERSION} \
    && meson build \
    && cd build \
    && meson compile \
    && meson test \
    && meson install

这里使用了Meson的完整构建流程:配置(configure)、编译(compile)、测试(test)和安装(install)。

OpenResty安装

OpenResty是基于Nginx的Web平台,集成了LuaJIT:

ARG OPENRESTY_VERSION=1.21.4.2
RUN wget https://openresty.org/download/openresty-${OPENRESTY_VERSION}.tar.gz \
    && tar xf openresty-${OPENRESTY_VERSION}.tar.gz \
    && cd openresty-${OPENRESTY_VERSION} \
    && ./configure -j2 \
    && make -j2 \
    && make install

OpenResty为fasty项目提供了高性能的Web服务能力,同时支持Lua脚本扩展。

Lua生态系统配置

LuaRocks安装

LuaRocks是Lua的包管理器:

ARG LUAROCKS_VERSION=3.8.0
RUN apt-get -qqy install lua5.1 liblua5.1-0-dev unzip zip
RUN wget https://luarocks.org/releases/luarocks-${LUAROCKS_VERSION}.tar.gz \
    && tar zxpf luarocks-${LUAROCKS_VERSION}.tar.gz \
    && cd luarocks-${LUAROCKS_VERSION} \
    && ./configure && make \
    && make install

Lapis框架安装

Lapis是基于OpenResty的Lua Web框架:

ARG LAPIS_VERSION=1.16.0
RUN luarocks install --server=http://rocks.moonscript.org/manifests/leafo lapis $LAPIS_VERSION
RUN luarocks install moonscript
RUN luarocks install lapis-console

同时还安装了其他有用的Lua库:

RUN luarocks install stringy
RUN luarocks install busted
RUN luarocks install sass
RUN luarocks install web_sanitize
RUN luarocks install luasec
RUN luarocks install luaexpat 1.4.1-1
RUN luarocks install cloud_storage
RUN luarocks install lua-resty-jwt
RUN luarocks install fun
RUN apt-get -qqy install libyaml-dev
RUN luarocks --server=http://rocks.moonscript.org install lyaml

这些库为fasty项目提供了丰富的功能支持,包括:

  • 字符串处理(stringy)
  • 测试框架(busted)
  • CSS预处理器(sass)
  • HTML净化(web_sanitize)
  • 安全通信(luasec)
  • XML处理(luaexpat)
  • 云存储(cloud_storage)
  • JWT认证(lua-resty-jwt)
  • 函数式编程(fun)
  • YAML处理(lyaml)

Node.js生态系统配置

使用n工具安装Node.js LTS版本:

RUN wget https://raw.githubusercontent.com/visionmedia/n/master/bin/n && \
    chmod +x n && mv n /usr/bin/n && n lts

安装前端开发工具链:

RUN npm install -g yarn@1.22.11 \
    forever@4.0.1 \
    @riotjs/cli@6.0.5 \
    @babel/core@7.15.5 \
    terser@5.7.2 \
    tailwindcss@3.0.23 \
    autoprefixer@10.3.4 \
    postcss@8.3.6

这些工具为fasty项目提供了:

  • 包管理(yarn)
  • 进程守护(forever)
  • Riot.js组件编译(@riotjs/cli)
  • JavaScript转译(@babel/core)
  • 代码压缩(terser)
  • CSS工具链(tailwindcss, autoprefixer, postcss)

其他关键工具安装

wkhtmltopdf

用于HTML转PDF:

RUN wget https://github.com/wkhtmltopdf/packaging/releases/download/0.12.6-1/wkhtmltox_0.12.6-1.focal_arm64.deb
RUN apt-get -qqy install ./wkhtmltox_0.12.6-1.focal_arm64.deb

ArangoDB客户端

ArangoDB是一个多模型数据库:

RUN wget https://download.arangodb.com/arangodb310/Community/Linux/arangodb3-client_3.10.2-1_arm64.deb
RUN apt-get -qqy install ./arangodb3-client_3.10.2-1_arm64.deb

工作目录和环境变量

最后设置工作目录和环境变量:

WORKDIR /var/www
ENV LAPIS_OPENRESTY $OPENRESTY_PREFIX/nginx/sbin/nginx

构建优化技巧

  1. 并行构建:使用-j2参数充分利用双核CPU
  2. 清理策略:安装完成后删除源代码和临时文件
  3. 版本固定:所有组件都指定了具体版本,确保一致性
  4. 最小化安装:使用-qqy参数减少输出和自动确认

总结

这个Dockerfile为ARMv8架构精心构建了一个完整的Web开发环境,特别适合运行fasty项目。它集成了高性能的OpenResty服务器、丰富的Lua生态系统、现代化的前端工具链以及多种实用工具,为开发者提供了一个开箱即用的环境。

登录后查看全文
热门项目推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
178
262
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
866
513
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
183
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
261
302
kernelkernel
deepin linux kernel
C
22
5
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
598
57
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
332
1.08 K