comment exécuter Aspose.Cells.GridWeb pour construire une application d édition ou de visualisation de feuilles de calcul en ligne dans Docker
Guide Docker
Prérequis
Assurez-vous d’avoir Docker installé sur votre machine. Vous pouvez télécharger et installer Docker depuis le site officiel de Docker.
Étape 1: Créez un fichier Dockerfile
Créez un fichier nommé Dockerfile
dans votre répertoire. Le Dockerfile
doit contenir des instructions sur la façon de construire votre image Docker.
Étape 2: Écrire le Dockerfile pour GridWeb
Voici un exemple de Dockerfile
pour la démo de GridWeb avec une application Java :
#spring boot3.3 shall use jdk17 above
FROM openjdk:17-jdk-slim AS build
# set work dir
WORKDIR /usr/src/app
# copy with maven
COPY mvnw .
COPY .mvn .mvn
COPY pom.xml .
COPY src src
RUN chmod +x mvnw
# build with maven
RUN ./mvnw package -DskipTests
RUN ls -l target
# Stage 2: Create the final image
FROM openjdk:17-jdk-slim
# Set the working directory in the container
WORKDIR /app
# Copy the built JAR file from the build stage
COPY --from=build /usr/src/app/target/*.jar /app/app.jar
# web port
EXPOSE 8080
# Install Fonts because the SDK image contains very few fonts. The command copies font files from local to docker image. Make sure you have a local “fonts” directory that contains all the fonts you need to install. In this example, the local “fonts” directory is put in the same directory as the Dockerfile.
# COPY fonts/* /usr/share/fonts/
# Install necessary dependencies for font management,because we use jdk-slim ,we need to install it
RUN apt-get update && apt-get install -y fontconfig libfreetype6 && rm -rf /var/lib/apt/lists/*
# Set the environment variable for headless mode,no need to use display
ENV JAVA_OPTS="-Djava.awt.headless=true"
# create [log dir](https://github.com/aspose-cells/Aspose.Cells-for-Java/blob/master/Examples.GridWeb/springboot3.3demo/src/main/resources/application.properties)
RUN mkdir -p /app/log
# create [cache dir](https://github.com/aspose-cells/Aspose.Cells-for-Java/blob/master/Examples.GridWeb/springboot3.3demo/src/main/resources/application.properties)
RUN mkdir -p /app/grid_cache
# RUN ls -l /app/
# run java application
CMD ["sh", "-c", "java $JAVA_OPTS -jar /app/app.jar"]
Étape 3: Construction de l’image Docker
Construisez l’image Docker: Depuis le terminal, exécutez la commande suivante pour construire votre image Docker:
docker build -t gridweb-demo-java .
vous pouvez remplacer gridweb-demo-java par le nom que vous souhaitez donner à votre image Docker.
Étape 4: Exécution d’un conteneur Docker
Une fois l’image construite, vous pouvez exécuter un conteneur en utilisant la commande suivante:
docker run -d -p 8080:8080 --name gridweb-demo-container gridweb-demo-java
Explication des options de la commande Docker Run -d: Exécute le conteneur en mode détaché (en arrière-plan). -p 8080:8080: Mapper le port 8080 dans le conteneur sur le port 8080 de la machine hôte. –name gridweb-demo-container: Attribuer un nom au conteneur.
Étape 5: Vérifier que le Conteneur fonctionne
Pour vérifier si votre conteneur fonctionne, utilisez la commande suivante:
docker ps
Cela listera tous les conteneurs en cours d’exécution. Vous devriez voir votre conteneur répertorié avec son nom et son statut.
Étape 6: Accéder à l’application Web
Ouvrez un navigateur web et allez à http://localhost:8080/gridwebdemo/index
. Vous devriez voir votre application en cours d’exécution.
Commandes Additionnelles
Arrêter le Conteneur
Pour arrêter un conteneur en cours d’exécution, utilisez la commande suivante:
docker stop gridweb-demo-container
Suppression d’un conteneur
Pour supprimer un conteneur arrêté, utilisez la commande suivante :
docker rm gridweb-demo-container
Suppression d’une image
Pour supprimer une image, utilisez la commande suivante :
docker rmi gridweb-demo-java