如何在 Docker 中运行 Aspose.Slides for Java
Contents
[
Hide
]
介绍
本指南解释如何使用 Aspose Slides 与 Docker 将 Java 应用程序容器化。主要优势包括:
- 跨平台兼容性 - 在 Windows、macOS 和 Linux 上运行
- 依赖隔离 - 无需系统范围的安装
- 简化部署 - 轻松共享和执行
1. Docker 安装
Windows
要求:
- Windows 10/11 Pro/Enterprise/Education(64 位)并启用 WSL 2
- 对于 Home 版:需要手动安装 WSL 2
步骤:
- 下载 Docker Desktop for Windows
- 运行安装程序并按照设置向导操作
- 出现提示时重启计算机
- 验证安装:
docker --version
macOS
要求:
- macOS 10.15(Catalina)或更高版本
- Apple Silicon 或 Intel 处理器
步骤:
- 下载 Docker Desktop for Mac
- 将应用程序拖动到
Applications文件夹 - 启动 Docker 并等待初始化
- 验证安装:
docker --version
Linux (Ubuntu/Debian)
安装:
# 更新软件包列表
sudo apt update && sudo apt upgrade -y
# 安装前置依赖
sudo apt install -y \
apt-transport-https \
ca-certificates \
curl \
software-properties-common
# 添加 Docker 官方 GPG 密钥
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg
# 添加稳定版仓库
echo "deb [arch=amd64 signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
# 安装 Docker 引擎
sudo apt update
sudo apt install -y docker-ce docker-ce-cli containerd.io
# 允许当前用户运行 Docker 命令
sudo usermod -aG docker $USER
newgrp docker
# 验证安装
docker --version
2. Dockerfile 配置
基础镜像
FROM ubuntu:24.04
注意:使用来自 Docker Hub 的 官方 Ubuntu 镜像。
依赖项
RUN apt-get install -y openjdk-11-jdk wget fontconfig ttf-mscorefonts-installer
- OpenJDK 11:Java 运行时环境
- 字体包:包含 Microsoft Core 字体
Aspose.Slides 设置
ENV ASPOSE_VERSION=25.3
ENV ASPOSE_JAR=aspose-slides-${ASPOSE_VERSION}-jdk16.jar
ENV ASPOSE_URL=https://releases.aspose.com/java/repo/com/aspose/aspose-slides/${ASPOSE_VERSION}/${ASPOSE_JAR}
- 固定版本下载 Aspose Slides 库
3. 项目设置
文件结构
aspose-docker/
├── Dockerfile # 容器配置
├── TestAspose.java # 应用程序代码
└── output/ # 包含生成的 PDF 的文件夹(自动创建)
Dockerfile
创建一个名为 Dockerfile 的文件,内容如下:
FROM ubuntu:24.04
# 设置环境变量
ENV JAVA_HOME=/usr/lib/jvm/java-11-openjdk-amd64
ENV PATH=$JAVA_HOME/bin:$PATH
ENV APP_DIR=/tmp
ENV ASPOSE_VERSION=25.3
ENV ASPOSE_JAR=aspose-slides-${ASPOSE_VERSION}-jdk16.jar
ENV ASPOSE_URL=https://releases.aspose.com/java/repo/com/aspose/aspose-slides/${ASPOSE_VERSION}/${ASPOSE_JAR}
# 创建工作目录
RUN mkdir -p ${APP_DIR}
WORKDIR ${APP_DIR}
# 安装依赖
RUN apt-get update && \
apt-get install -y --no-install-recommends \
openjdk-11-jdk \
wget \
fontconfig \
ttf-mscorefonts-installer && \
rm -rf /var/lib/apt/lists/*
# 配置字体
RUN echo "ttf-mscorefonts-installer msttcorefonts/accepted-mscorefonts-eula select true" | debconf-set-selections && \
apt-get update && \
apt-get install -y --no-install-recommends ttf-mscorefonts-installer && \
fc-cache -f -v
# 下载 Aspose.Slides 到 /tmp
RUN wget ${ASPOSE_URL} -O ${APP_DIR}/${ASPOSE_JAR}
# 复制源代码
COPY TestAspose.java ${APP_DIR}/
# 创建运行脚本
RUN echo '#!/bin/bash' > ${APP_DIR}/run.sh && \
echo 'java --add-opens=java.desktop/sun.java2d=ALL-UNNAMED \' >> ${APP_DIR}/run.sh && \
echo ' --add-opens=java.desktop/sun.awt.image=ALL-UNNAMED \' >> ${APP_DIR}/run.sh && \
echo ' --add-opens=java.desktop/sun.font=ALL-UNNAMED \' >> ${APP_DIR}/run.sh && \
echo ' -cp ".:'"${ASPOSE_JAR}"'" TestAspose' >> ${APP_DIR}/run.sh && \
chmod +x ${APP_DIR}/run.sh
# 明确授予脚本执行权限
RUN chmod 755 ${APP_DIR}/run.sh
# 编译 Java 代码
RUN javac -cp "${APP_DIR}/${ASPOSE_JAR}" ${APP_DIR}/TestAspose.java
# 设置工作目录
WORKDIR /tmp
CMD ["sh", "-c", "/tmp/run.sh && cp /tmp/output/output.pdf /output"]
Java 应用程序
创建 TestAspose.java,内容如下:
import com.aspose.slides.*;
public class TestAspose {
public static void main(String[] args) throws Exception {
System.out.println("Creating presentation...");
Presentation presentation = new Presentation();
try {
ISlide slide = presentation.getSlides().get_Item(0);
IAutoShape autoShape = slide.getShapes().addAutoShape(ShapeType.Rectangle, 50, 190, 300, 25);
autoShape.getTextFrame().setText("Greetings from Docker!");
presentation.save("/tmp/output/output.pdf", SaveFormat.Pdf);
} finally {
if (presentation != null) presentation.dispose();
}
System.out.println("Presentation saved as output.pdf");
}
}
4. 构建与运行
构建镜像
在 Dockerfile 所在目录运行以下命令以构建 Docker 镜像:
docker build -t aspose-test .
-t为镜像命名为 “aspose-test”.使用当前目录的 Dockerfile
运行容器
在 Dockerfile 所在目录运行以下命令以运行 Docker 容器:
docker run -v "$(pwd)/output:/output" aspose-test
-v挂载输出目录- 在本地
output文件夹中创建output.pdf