Docker容器常用命令笔记分享

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: Docker容器常用命令笔记分享

在这里插入图片描述

Docker简介

Docker是一个开源的应用容器引擎,可以让开发者将应用程序及其依赖打包成一个可移植的容器,然后发布到任何支持Docker的机器上,实现应用程序在不同环境中的一致性运行。相比传统的虚拟化技术,Docker具有更轻量级、更快速、更高效的特点。使用Docker可以方便地创建、部署和运行应用程序,提高开发效率和应用程序的可移植性。

以下是一些常用的Docker命令:

docker version:查看Docker版本信息
docker run:运行一个容器
docker start:启动一个或多个已停止的容器
docker stop:停止一个运行中的容器
docker restart:重启一个容器
docker pause:暂停一个运行中的容器
docker unpause:取消暂停一个容器
docker rm:删除一个或多个容器
docker ps:列出当前运行的容器
docker exec -it:在容器内执行命令
docker images:列出本地的镜像
docker pull:从镜像仓库中拉取镜像
docker push:将本地的镜像推送到镜像仓库
docker build:根据Dockerfile构建镜像
docker commit:创建一个新的镜像并提交更改
docker tag:为镜像添加一个标签
docker network ls:列出当前存在的网络
docker network create:创建一个新的网络
docker network rm:删除一个网络
docker volume ls:列出当前存在的卷
docker volume create:创建一个新的卷
docker volume rm:删除一个卷
docker-compose up:根据docker-compose.yml文件启动容器
docker-compose down:停止并删除由docker-compose.yml文件启动的容器
docker inspect:查看容器、镜像、网络等的详细信息
docker logs:查看容器的日志
docker cp:将文件从容器复制到主机或从主机复制到容器
docker attach:连接到一个正在运行的容器
docker login:登录到Docker Hub或其他镜像仓库
docker logout:退出Docker Hub或其他镜像仓库的登录状态

Docker常用用法:

后台运行一个测试nginx容器

docker run -d --name web01    -p 8412:80    --restart always \
  -v /data/nginx/html/:/usr/share/nginx/html/   nginx:1.21

进入到一个运行容器中

  • 进入到正在运行的web01容器中
docker exec -it web01 /bin/bash

清空宿主机所有容器

 docker rm -f $(docker ps -aq)

构建容器镜像

(根据Dockerfile文件构建容器镜像)

docker build -t my_image:1.0 .

容器的导入和导出

  • 容器导出:将容器654f8008e7a4导出为nginx.bak.tar容器包。
docker export 654f8008e7a4 > nginx.bak.tar
  • 容器包导入:将nginx.bak.tar容器包文件导入到宿主机
cat nginx.bak.tar |docker import - nginx:3.0

查看容器占用资源

docker stats my_container --no-stream

镜像的导入和导出

  • 镜像导出:将镜像 centos:latest打包为cnetos_7.4.tar文件。
 docker save -o centos_7.4.tar centos:latest
  • 镜像包导入:将cnetos_7.4.tar文件导入到宿主机
docker load --input centos_7.4.tar

生成新镜像

  • 将容器名为web01-container的容器提交一个名为 mynginx:1.21本地镜像
docker commit -a "jeven" -m "Added new file"  web01-container   mynginx:1.21

删除容器与镜像

  • 删除一个本地镜像
docker rmi nginx:1.21
  • 删除一个正在运行的容器web01
docker rm -f web01

暂停和恢复容器

  • 暂停容器web01
docker pause web01
  • 恢复容器web01
docker unpause web01

docker compose常用命令

Docker Compose是一个用于定义和运行多个Docker容器的工具。它允许您使用YAML文件来配置多个容器的各种属性,包括映像、环境变量、卷和端口映射等。 Docker Compose还提供了一组命令,用于轻松管理这些容器,例如启动、停止和重新构建等操作。

  • 构建并后台启动所有的容器
    docker compose up -d
    
  • 停止并删除所有的容器
docker compose down
  • 指定docker-compose.yaml文件启动容器
docker compose -f /path/to/docker-compose.yaml up -d
  • 重启所有容器
docker compose restart
  • 启动所有容器
    docker compose start
    
  • 停止所有容器

    docker compose stop
    
  • 查看所有容器的日志

docker compose logs
  • 显示正在运行的Docker Compose项目中的所有服务的状态
docker compose ps
  • 构建所有容器
    docker compose build
    

Docker相关管理工具

常见Docker可视化web管理工具,有Portainer CE、Rancher、SimpleDocker、shipyard等。

  • Portainer CE是一个开源的容器管理界面,用于管理和监控Docker容器。它提供了一个用户友好的界面,使用户能够轻松地创建、启动、停止和删除容器,查看容器的日志和监控信息,以及管理容器网络和存储卷等功能。

在这里插入图片描述

Docker优点

Docker容器具有轻量、快速、灵活、可移植、隔离和可伸缩的特性,使得应用的开发、部署和管理变得更加简单和高效。它正在成为云计算和容器化技术的主要标准之一。

Docker容器具有以下优点:

  • 轻量级:Docker容器是基于操作系统层面的虚拟化技术,相比于传统的虚拟机,它更加轻量级。每个容器都共享宿主机的操作系统内核,避免了运行多个完整的操作系统副本所造成的资源浪费。

  • 快速启动:Docker容器相比传统虚拟机的启动速度更快。容器的启动时间通常只需要几秒钟,而传统虚拟机的启动时间可能需要几分钟。

  • 灵活性:Docker容器具有很高的灵活性,可以很容易地创建、部署和销毁容器。容器可以从一个镜像快速创建,而且容器的配置和环境可以通过镜像来定义,使整个应用的部署过程变得非常简单和可重复。

  • 可移植性:Docker容器可以在不同的操作系统和环境中运行,提供了很高的可移植性。容器可以在开发环境、测试环境和生产环境中无缝切换,避免了由于应用在不同环境中的不兼容问题。

  • 隔离性:Docker容器可以提供良好的隔离性,每个容器都运行在独立的命名空间中,相互之间不会相互干扰。容器之间共享主机的操作系统内核,但是各自拥有独立的文件系统、进程空间和网络接口。

  • 可伸缩性:Docker容器可以很容易地进行横向扩展,通过创建多个相同的容器来处理更多的负载。同时,Docker容器也支持自动化部署和管理,可以通过编排工具来管理大规模的容器集群。

相关实践学习
通过workbench远程登录ECS,快速搭建Docker环境
本教程指导用户体验通过workbench远程登录ECS,完成搭建Docker环境的快速搭建,并使用Docker部署一个Nginx服务。
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
18小时前
|
Linux Docker 容器
蓝易云 - 【Linux】如何在linux系统重启或启动时执行命令或脚本(也支持docker容器内部)
以上就是在Linux系统和Docker容器中设置启动时运行命令或脚本的方法。希望对你有所帮助。
9 0
|
1天前
|
流计算 Docker 容器
在docker中玩flink时候记录一些组合命令
在docker中玩flink时候记录一些组合命令
8 0
|
1天前
|
大数据 Linux Docker
mac docker 宿主机和容器间网络打通
mac docker 宿主机和容器间网络打通
6 0
|
3天前
|
监控 安全 云计算
云端防御战线:云计算环境下的网络安全策略构建高效稳定的Docker容器监控体系
【5月更文挑战第27天】 在数字化时代的浪潮中,云计算已成为企业与个人存储和处理数据的重要平台。然而,随着云服务使用率的飙升,网络威胁也愈发狡猾且复杂。本文将深入探讨在云计算环境中维护网络安全的挑战及策略,重点分析信息安全的关键组成部分,并提出多层次防御模型以增强云环境的数据保护能力。通过剖析最新的安全技术与实践,我们旨在为读者提供一套全面的网络安全解决方案蓝图。
|
3天前
|
Docker 容器
【开发问题记录】启动某个服务时请求失败(docker-componse创建容器时IP参数不正确)
【开发问题记录】启动某个服务时请求失败(docker-componse创建容器时IP参数不正确)
8 1
|
6天前
|
C++ 索引 容器
黑马c++ STL部分 笔记(9) map/multimap容器
黑马c++ STL部分 笔记(9) map/multimap容器
|
6天前
|
C++ 容器
黑马c++ STL部分 笔记(8) set/ multiset 容器
黑马c++ STL部分 笔记(8) set/ multiset 容器
|
6天前
|
存储 C++ 容器
黑马c++ STL部分 笔记(7) list容器
黑马c++ STL部分 笔记(7) list容器
|
6天前
|
C++ 容器
黑马c++ STL部分 笔记(6) queue 容器
黑马c++ STL部分 笔记(6) queue 容器
|
6天前
|
C++ 容器
黑马c++ STL部分 笔记(5) stack容器
黑马c++ STL部分 笔记(5) stack容器