跳至页脚内容
使用 IRONSECUREDOC

从镜像启动 Docker 容器(开发者教程)

What is Docker?

Docker is an open-source platform that automatically deploys and manages applications within lightweight, portable containers. Containers package an application along with its dependencies, which include libraries and configuration files, so it can run consistently across different environments. This consistency makes development and testing more straightforward because applications can run identically on diverse systems—whether on a developer's laptop, a server, or a cloud environment. Scalability in application management means developing, shipping, and running containers efficiently, which Docker facilitates.

Docker Start Container From Image (Developer Tutorial): Figure 1 - Docker

Docker images make the specification of a consistent runtime environment much easier for developers. Most prebuilt images can be found in an open registry called Docker Hub, which developers can use directly or customize. For applications involving multiple containers, tools like Docker Compose orchestrate the container, whereas Kubernetes can manage even more complex scaling and automation. Docker has become an essential tool in software development and DevOps.

What is a Docker container?

A Docker container is essentially an application with all its dependencies—such as libraries, binaries, and configuration files—packed into a lightweight standalone executable entity. Containers designed in isolation run on top of a host operating system's kernel, avoiding interference from any other running software. Being easy to start, stop, or delete makes them ideal for testing, deployment, and scaling.

Docker container features

  • Isolation: Containers run in isolated environments; applications will not conflict with one another, even if they use different sets of dependencies or libraries.
  • Lightweight: Containers share the host operating system kernel, so they are small and have faster startup times than VMs.
  • Portability: Containers are deterministic and can run on any system using Docker, ensuring consistency across development, test, and production environments.
  • Scalability: Containers can be easily replicated and scaled, supporting fast deployment and management of microservices.
  • Resource Efficiency: Containers consume fewer resources than VMs, allowing for higher density and efficient utilization of computing resources.

What is a Docker image?

A Docker image is a blueprint for creating containers. It is read-only and layered, detailing the system files and dependencies needed to get an application running. Dockerfiles are used to create images, specifying how to build a Docker image, which might involve tasks such as installing software or copying files. Every change to a Dockerfile creates a new image layer, maintaining efficiency and modularity.

Features of a Docker Image

  • Multi-Level Stack: Images are built with layers using Dockerfiles. Each instruction in a Dockerfile adds a layer, so images should be optimized to rebuild only changed layers.
  • Reusability: Base images such as Ubuntu or Node.js can be reused across projects, saving development time and resources.
  • Versioning: Images can be tagged for versioning, making it easier to roll back to previous versions if needed.
  • Modularity: Changes to an image are incremental, enabling straightforward updates without rebuilding the entire image.
  • Available on Docker Hub: Public and private image registries facilitate easy sharing and deployment of images.

How to create a Docker container

The Dockerfile is a text file providing instructions to create your Docker image. In this file, you specify the base image, dependencies, application code, environment variables, and commands to run the application. Here is a simple example:

# Use an official Node.js runtime as a parent image
FROM node:18

# Set the working directory in the container
WORKDIR /app

# Copy package.json and install dependencies
COPY package.json /app
RUN npm install

# Copy the rest of the application code
COPY . /app

# Expose the application’s port
EXPOSE 3000

# Define the command to run the application
CMD ["node", "app.js"]

Build the Docker Image

Use the Dockerfile to create your Docker image. At the terminal command line, from the directory containing your Dockerfile, execute:

Make sure Docker Desktop is installed before executing the below command.

docker build -t my-app .
docker build -t my-app .
SHELL

This command creates an image named my-app. To confirm that it has been created, execute:

docker images
docker images
SHELL

Run the Docker Container

With an image, you can create a Docker container and then run it using the docker run command. The Docker daemon will start and monitor the process either in detached mode (background) or in the foreground.

docker run -d -p 3000:3000 --name my-running-app my-app
docker run -d -p 3000:3000 --name my-running-app my-app
SHELL
  • -d: Run the container in detached mode.
  • -p 3000:3000: Map the host's port 3000 to port 3000 in the container.
  • --name my-running-app: Assign a user-defined name to the container.

Verify Container

To check the running Docker containers, use:

docker ps
docker ps
SHELL

Docker Start Container From Image (Developer Tutorial): Figure 2 - Running Docker Containers

The above command shows the details of running containers, including container ID, name, image name, etc.

Stop and Remove Container

# Stop container
docker stop dazzling_snyder

# Remove container
docker rm dazzling_snyder
# Stop container
docker stop dazzling_snyder

# Remove container
docker rm dazzling_snyder
SHELL

Docker Start Container From Image (Developer Tutorial): Figure 3 - Stop Container

What is IronSecureDoc?

IronSecureDoc Docker is a containerized document processing solution by Iron Software that can automatically process documents in a Docker environment without human intervention. It offers complex document workflows and maximum data protection with encryption, digital signing, decryption, watermarking, and more for PDF and document files. It ensures consistent and scalable isolated deployments across platforms, making it suitable for DevOps and CI/CD pipeline integration.

Docker Start Container From Image (Developer Tutorial): Figure 4 - IronSecureDoc: The PDF Security and Compliance Server

This containerized approach enhances document handling in applications that require automation and high security, compatible with microservices and cloud-native environments. IronSecureDoc is especially useful for developers who create applications that require reliable automatic document processing in a controlled and portable Docker context.

Install and Run IronSecureDoc

Execute the following command from the Command Prompt or a terminal window to download the IronSecureDoc Docker image from the repository:

docker pull ironsoftwareofficial/ironsecuredoc
docker pull ironsoftwareofficial/ironsecuredoc
SHELL

Docker Start Container From Image (Developer Tutorial): Figure 5 - Download IronSecureDoc Image

After pulling the Docker image, initiate another command to start an IronSecureDoc container.

Creating a new Container for IronSecureDoc

docker container run --rm -p 8080:8080 -e ENVIRONMENT=Development -e HTTP_PORTS=8080 ironsoftwareofficial/ironsecuredoc:latest
docker container run --rm -p 8080:8080 -e ENVIRONMENT=Development -e HTTP_PORTS=8080 ironsoftwareofficial/ironsecuredoc:latest
SHELL

The above docker run command creates a container instance of IronSecureDoc.

Docker Start Container From Image (Developer Tutorial): Figure 6 - New Container

Using IronSecureDoc container

IronSecureDoc enables users to install and run Docker to redact, certify, or encrypt files through its REST API.

Docker Start Container From Image (Developer Tutorial): Figure 7 - SecureDoc Web API

For instance, to encrypt a document, you can make a POST request to the IronSecureDoc API:

curl -X 'POST' \
  'http://localhost:8080/v1/document-services/pdfs/encrypt?user_password=demo' \
  -H 'accept: */*' \
  -H 'Content-Type: multipart/form-data' \
  -F 'pdf_file=@test.pdf;type=application/pdf'
curl -X 'POST' \
  'http://localhost:8080/v1/document-services/pdfs/encrypt?user_password=demo' \
  -H 'accept: */*' \
  -H 'Content-Type: multipart/form-data' \
  -F 'pdf_file=@test.pdf;type=application/pdf'
SHELL

This forwards the document to IronSecureDoc, which processes and encrypts the data accordingly.

Conclusion

In simple terms, Docker simplifies application deployment because a developer can create a container from an image, ensuring uniformity in a portable and scalable environment. This results in the efficient running of applications across platforms and facilitates resource utilization, enhancing DevOps and CI/CD pipelines.

Similarly, IronSecureDoc Docker utilizes Docker's containerized architecture to offer secure, automated document processing solutions. Together, Docker and IronSecureDoc provide powerful tools for building secure, scalable applications in modern software development. For more information on licensing IronSecureDoc, click this licensing page, and for details about the many products of Iron Software, visit the library suite page.

常见问题解答

什么是Docker,为什么它对开发者重要?

Docker 是一个开源平台,可自动化应用程序在容器中的部署和管理。它将应用程序与其依赖项打包在一起,确保跨不同环境的一致操作,从而简化了开发、测试和扩展。

Docker 镜像如何促进应用程序部署?

Docker 镜像作为创建容器的只读蓝图。它们定义了运行应用程序所需的系统文件和依赖关系,使分享和部署变得简单。镜像可以存储及从 Docker Hub 等注册表访问。

创建和运行 Docker 容器的关键步骤是什么?

要创建和运行 Docker 容器,首先编写一个 Dockerfile,指定基础镜像和依赖关系。然后,从 Dockerfile 构建 Docker 镜像,并使用 docker run 命令来创建并启动容器。

IronSecureDoc 如何增强 Docker 中的文档处理?

IronSecureDoc 是一种基于 Docker 的解决方案,提供加密和数字签名等功能来自动化文档处理。它确保了 Docker 容器内的安全、可扩展的工作流程,使其非常适合集成到 DevOps 和 CI/CD 流程中。

Docker 容器为应用程序开发提供了哪些好处?

Docker 容器提供隔离、轻量级操作、可移植性和资源效率。它们确保跨环境的一致应用程序执行,支持快速部署,并简化微服务的管理。

开发人员如何确保使用 Docker 安全地处理文档?

开发人员可以使用 IronSecureDoc 在 Docker 容器内自动化安全文档处理。它提供加密、数字签名和其他安全功能,加强文档工作流程的保护性和完整性。

Docker Hub 在容器部署中扮演什么角色?

Docker Hub 作为一个开源的预构建 Docker 映像注册表,允许开发人员访问和共享镜像。这有利于应用程序的简单定制和部署,提速开发流程。

Docker 如何改善应用程序的可扩展性和效率?

Docker 通过轻松复制和管理容器来提高可扩展性。这使应用程序可以快速高效地扩展,优化资源利用并支持现代软件开发实践。

Dockerfile 在容器创建中的目的是什么?

Dockerfile 用于定义 Docker 容器的基础镜像、依赖关系、应用程序代码和执行命令。它作为构建 Docker 镜像的蓝图,之后可用于创建容器。

Curtis Chau
技术作家

Curtis Chau 拥有卡尔顿大学的计算机科学学士学位,专注于前端开发,精通 Node.js、TypeScript、JavaScript 和 React。他热衷于打造直观且美观的用户界面,喜欢使用现代框架并创建结构良好、视觉吸引力强的手册。

除了开发之外,Curtis 对物联网 (IoT) 有浓厚的兴趣,探索将硬件和软件集成的新方法。在空闲时间,他喜欢玩游戏和构建 Discord 机器人,将他对技术的热爱与创造力相结合。