Docker实战之运行第一个容器

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 你好看官,里面请!今天笔者讲的是Docker实战之运行第一个容器。不懂或者觉得我写的有问题可以在评论区留言,我看到会及时回复。 注意:本文仅用于学习参考,不可用于商业用途,如需转载请跟我联系。

Docker实战之运行第一个容器

Docker常用命令

#info|version
docker info       #显示docker的系统信息,包括镜像和容器的数量
docker version    #显示docker的版本信息。
#帮助命令
docker 命令 --help #帮助命令
#镜像命令
docker images #查看所有本地主机上的镜像 可以使用docker image ls代替
docker search #搜索镜像
docker pull #下载镜像 docker image pull
docker rmi #删除镜像 docker image rm
#容器命令
docker run 镜像id #新建容器并启动
docker ps 列出所有运行的容器 docker container list
docker ps -a列出所有的容器
docker rm 容器id #删除指定容器
    #删除所有容器
    docker rm -f $(docker ps -aq)       #删除所有的容器
    docker ps -a -q|xargs docker rm  #删除所有的容器
#启动和停止容器
docker start 容器id    #启动容器
docker restart 容器id    #重启容器
docker stop 容器id    #停止当前正在运行的容器
docker kill 容器id    #强制停止当前容器
#退出容器
exit         #容器直接退出
ctrl +P +Q  #容器不停止退出     ---注意:这个很有用的操作
#其他常用命令
docker run -d 镜像名  #后台启动命令
docker logs         #查看日志
docker top 容器id     #查看容器中进程信息ps
docker inspect 容器id  #查看镜像的元数据
docker exec         #进入当前容器后开启一个新的终端,可以在里面操作。(常用)
docker attach         # 进入容器正在执行的终端
docker cp 容器id:容器内路径  主机目的路径    #从容器内拷贝到主机上
docker attach    #连接到正在运行中的容器
docker build    #使用 Dockerfile 创建镜像
docker builder    #管理builds
    docker builder prune    #清除build缓存
docker checkpoint    #管理checkpoints
    docker checkpoint create    #从正在运行的容器创建检查点
    docker checkpoint ls    #列出容器的检查点
    docker checkpoint rm    #删除指定的检查点
docker commit    #从容器创建一个新的镜像
docker config    #管理Docker配置
    docker config create    #创建配置文件
    docker config inspect    #查看配置文件信息
    docker config ls        #显示docker里已经保存得配置文件
    docker config rm        #删除配置文件
docker container    #管理容器
    docker container prune    #删除所有已停止的容器
docker context    #管理contexts
    docker context create    #创建一个上下文
    docker context export    #将上下文导出到tar或kubecconfig文件中
    docker context import    #从tar或zip文件导入上下文
    docker context inspect    #在一个或多个上下文上显示详细信息
    docker context ls        #列出上下文
    docker context rm        #删除一个或多个上下文
    docker context update    #更新
    docker context use        #设置当前docker的上下文
docker cp        #用于容器与主机之间的数据拷贝
docker create    #创建一个新的容器但不启动它
docker diff        #检查容器里文件结构的更改
docker events    #从服务器获取实时事件
docker exec        #在运行的容器中执行命令
docker export    #将文件系统作为一个tar归档文件导出到STDOUT
docker history    #查看指定镜像的创建历史
docker image    #管理镜像
    docker image inspect    #显示一个或多个镜像的元数据
    docker image ls            #列出本地镜像
    docker image prune        #删除没有使用的镜像
    docker image rm            #删除一个或多个镜像
docker images    #列出本地镜像
docker import    #从归档文件中创建镜像
docker info        #显示 Docker 系统信息,包括镜像和容器数
docker inspect    #获取容器/镜像的元数据
docker kill        #杀掉一个运行中的容器
docker load        #导入使用 docker save 命令导出的镜像
docker login    #登陆到一个Docker镜像仓库,如果未指定镜像仓库地址,默认为官方仓库 Docker Hub
docker logout    #登出一个Docker镜像仓库,如果未指定镜像仓库地址,默认为官方仓库 Docker Hub
docker logs        #获取容器的日志
docker manifest    #管理manifest(实验,不应用于生产环境)
    docker manifest annotate    #向本地镜像清单添加附加信息
    docker manifest create        #创建用于注释和推入注册表的本地清单列表
    docker manifest inspect        #显示镜像清单或清单列表
    docker manifest push        #将清单列表推入仓库
    docker manifest rm            #从本地存储中删除一个或多个清单列表
docker network    #管理网络
    docker network connect        #将容器连接到网络
    docker network create        #创建一个网络
    docker network disconnect    #断开容器的网络
    docker network inspect        #显示一个或多个网络的元数据
    docker network ls            #列出网络
    docker network prune        #删除所有没有使用的网络
    docker network rm            #删除一个或多个网络
docker node        #管理集群(swarm)节点
    docker node demote            #从群集(swarm)管理器中降级一个或多个节点
    docker node inspect            #显示一个或多个节点的元数据
    docker node ls                #列出群集(swarm)中的节点
    docker node promote            #将一个或多个节点推入到群集管理器中
    docker node ps                #列出在一个或多个节点上运行的任务,默认为当前节点
    docker node rm                #从群集(swarm)删除一个或多个节点
    docker node update            #更新一个节点
docker pause    #暂停容器中所有的进程
docker plugin    #管理插件
    docker plugin create        #从rootfs和配置创建一个插件。插件数据目录必须包含config.json和rootfs目录。
    docker plugin disable        #禁用插件
    docker plugin enable        #启用插件
    docker plugin inspect        #显示一个或多个插件的元数据
    docker plugin install        #安装一个插件
    docker plugin ls            #列出所有插件
    docker plugin push            #将插件推送到注册表
    docker plugin rm            #删除一个或多个插件
    docker plugin set            #更改插件的设置
    docker plugin upgrade        #升级现有插件
docker port        #列出指定的容器的端口映射,或者查找将PRIVATE_PORT NAT到面向公众的端口
docker ps        #列出容器
docker pull        #从镜像仓库中拉取或者更新指定镜像
docker push        #将本地的镜像上传到镜像仓库,要先登陆到镜像仓库
docker rename    #重命名容器
docker restart    #重启容器
docker rm        #删除一个或多个容器
docker rmi        #删除一个或多个镜像
docker run        #创建一个新的容器并运行一个命令
docker save        #将指定镜像保存成 tar 归档文件
docker search    #从Docker Hub查找镜像
docker secret    #管理Docker secrets
    docker secret create    #从文件或STDIN创建一个秘密作为内容
    docker secret inspect    #显示有关一个或多个秘密的详细信息
    docker secret ls        #列出秘密
    docker secret rm        #删除一个或多个秘密
docker service    #管理服务
    docker service create    #创建一个服务
    docker service inspect    #查看服务的元数据
    docker service logs        #获取服务的日志
    docker service ls        #列出服务
    docker service ps        #列出一个或多个服务的任务
    docker service rm        #删除一个或多个服务
    docker service rollback    #将更改恢复到服务的配置
    docker service scale    #缩放一个或多个复制服务
    docker service update    #更新服务
docker stack    #管理堆栈
    docker stack deploy        #部署新的堆栈或更新现有堆栈
    docker stack ls            #列出现有堆栈
    docker stack ps            #列出堆栈中的任务
    docker stack rm            #删除堆栈    
    docker stack services    #列出堆栈中的服务
docker start    #启动一个或多个已经被停止的容器
docker stats    #显示容器的实时流资源使用统计信息
docker stop        #停止一个运行中的容器
docker swarm    #管理集群(Swarm)
    docker swarm ca            #查看或旋转当前群集CA证书。此命令必须针对管理器节点
    docker swarm init        #初始化一个群集(Swarm)
    docker swarm join        #加入群集作为节点和/或管理器
    docker swarm join-token    #管理加入令牌
    docker swarm leave        #离开群集(Swarm)
    docker swarm unlock        #解锁群集(Swarm)
    docker swarm unlock-key    #管理解锁钥匙
    docker swarm update        #更新群集(Swarm)
docker system    #管理Docker
    docker system df        #显示docker磁盘使用情况
    docker system events    #从服务器获取实时事件
    docker system info        #显示系统范围的信息
    docker system prune        #删除未使用的数据
docker tag        #标记本地镜像,将其归入某一仓库
docker top        #查看容器中运行的进程信息,支持 ps 命令参数
docker trust    #管理Docker镜像的信任
    docker trust inspect    #返回有关key和签名的低级信息
    docker trust key        #管理登入Docker镜像的keys
        docker trust key generate    #生成并加载签名密钥对
        docker trust key load        #加载私钥文件以进行签名
    docker trust revoke        #删除对镜像的认证
    docker trust sign        #镜像签名
    docker trust signer        #管理可以登录Docker镜像的实体
        docker trust signer add        #新增一个签名者
        docker trust signer remove    #删除一个签名者
docker unpause    #恢复容器中所有的进程
docker update    #更新一个或多个容器的配置
docker version    #显示 Docker 版本信息
docker volume    #管理volumes
    docker volume create    #创建一个卷
    docker volume inspect    #显示一个或多个卷的元数据
    docker volume ls        #列出卷
    docker volume prune        #删除所有未使用的卷
    docker volume rm        #删除一个或多个卷
docker wait        #阻塞运行直到容器停止,然后打印出它的退出代码

启动和关闭Docker服务,可以通过下面的命令完成。每次启动Linux系统,别忘了要运行Docker服务,切记!

service docker start service docker stop

help

查看对应的docker命令

docker --help

换源

指的是从官方仓库中把ubantux镜像拉取下载

docker pull ubuntu

但是官方仓库下载很慢,我们需要进行换源操作。

打开该文件

vim /etc/docker/daemon.json

添加以下JSON数据

"registry-mirrors": [ "http://hub-mirror.c163.com", "http://docker.mirrors.ustc.edu.cn" ]

最后重启docker容器就生效

运行

  • run表示运行容器
  • -it表示将本机终端映射到容器终端
  • ubuntu是镜像名字
  • /bin/bash是终端命令

docker run -i -t ubuntu /bin/bash

image.png

exit表示退出该容器(如果有后台运作的软件依旧在运作),不表示删除该容器

search

查找和redis相关的镜像

docker search redis

查看Docker中的镜像列表

docker images

删除某个镜像

docker rmi 镜像名字

Redis后台服务实战

如果没有redis镜像就会对redis镜像进行下载

docker run -i-t redis /bin/bash

进入容器内部启动redis

redis-server

此时为了去连接上redis,我们需要新开一个窗口

查找正在运行的容器

image.png

运行该容器 并redis-cli连接服务端

image.png

当把之前的服务端窗口关掉,这边就连接不上了。

如果加-d表示后台运行。(不需要开着终端也能运行)

image.png

kill指令表示强制关闭容器。

image.png

后台运行容器redis并端口映射(对外开放8888端口)

[docker run就表示又新建了一个容器并启动 docker start表示启动容器]

image.png

相关实践学习
通过容器镜像仓库与容器服务快速部署spring-hello应用
本教程主要讲述如何将本地Java代码程序上传并在云端以容器化的构建、传输和运行。
Kubernetes极速入门
Kubernetes(K8S)是Google在2014年发布的一个开源项目,用于自动化容器化应用程序的部署、扩展和管理。Kubernetes通常结合docker容器工作,并且整合多个运行着docker容器的主机集群。 本课程从Kubernetes的简介、功能、架构,集群的概念、工具及部署等各个方面进行了详细的讲解及展示,通过对本课程的学习,可以对Kubernetes有一个较为全面的认识,并初步掌握Kubernetes相关的安装部署及使用技巧。本课程由黑马程序员提供。   相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
30天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
213 77
|
11天前
|
搜索推荐 安全 数据安全/隐私保护
7 个最能提高生产力的 Docker 容器
7 个最能提高生产力的 Docker 容器
84 35
|
10天前
|
Ubuntu Linux 开发工具
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
Docker 是一个开源的容器化平台,允许开发者将应用程序及其依赖项打包成标准化单元(容器),确保在任何支持 Docker 的操作系统上一致运行。容器共享主机内核,提供轻量级、高效的执行环境。本文介绍如何在 Ubuntu 上安装 Docker,并通过简单步骤验证安装成功。后续文章将探讨使用 Docker 部署开源项目。优雅草央千澈 源、安装 Docker 包、验证安装 - 适用场景:开发、测试、生产环境 通过以上步骤,您可以在 Ubuntu 系统上成功安装并运行 Docker,为后续的应用部署打下基础。
docker 是什么?docker初认识之如何部署docker-优雅草后续将会把产品发布部署至docker容器中-因此会出相关系列文章-优雅草央千澈
|
16天前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
88 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
22天前
|
关系型数据库 应用服务中间件 PHP
实战~如何组织一个多容器项目docker-compose
本文介绍了如何使用Docker搭建Nginx、PHP和MySQL的环境。首先启动Nginx容器并查看IP地址,接着启动Alpine容器并安装curl测试连通性。通过`--link`方式或`docker-compose`配置文件实现服务间的通信。最后展示了Nginx配置文件和PHP代码示例,验证了各服务的正常运行。
48 3
实战~如何组织一个多容器项目docker-compose
|
16天前
|
Unix Linux Docker
CentOS停更沉寂,RHEL巨变限制源代:Docker容器化技术的兴起助力操作系统新格局
操作系统是计算机系统的核心软件,管理和控制硬件与软件资源,为用户和应用程序提供高效、安全的运行环境。Linux作为开源、跨平台的操作系统,具有高度可定制性、稳定性和安全性,广泛应用于服务器、云计算、物联网等领域。其发展得益于庞大的社区支持,多种发行版如Ubuntu、Debian、Fedora等满足不同需求。
43 4
|
1月前
|
数据建模 应用服务中间件 nginx
docker替换宿主与容器的映射端口和文件路径
通过正确配置 Docker 的端口和文件路径映射,可以有效地管理容器化应用程序,确保其高效运行和数据持久性。在生产环境中,动态替换映射配置有助于灵活应对各种需求变化。以上方法和步骤提供了一种可靠且易于操作的方案,帮助您轻松管理 Docker 容器的端口和路径映射。
107 3
|
8月前
|
安全 Linux 数据安全/隐私保护
docker运行报错docker: Error response from daemon: AppArmor enabled on system but the docker-default prof
docker运行报错docker: Error response from daemon: AppArmor enabled on system but the docker-default prof
482 0
|
3月前
|
安全 Docker 容器
Docker中运行容器时Operation not permitted报错问题解决
【10月更文挑战第2天】Docker中运行容器时Operation not permitted报错问题解决
835 3
|
关系型数据库 MySQL Devops
docker容器刚启动就停止 — 运行mysql 报错 mysqld: [ERROR] Fatal error in defaults handling. Program aborted!
docker容器刚启动就停止 — 运行mysql 报错 mysqld: [ERROR] Fatal error in defaults handling. Program aborted!
1165 0
下一篇
开通oss服务