当前位置:   article > 正文

docker容器命令_docker 执行容器内命令

docker 执行容器内命令

1.新建并启动容器

docker run [OPTIONS] IMAGE [COMMAND] [ARG...]

①OPTIONS说明

有些是一个减号,有些是两个减号

--name="容器新名字" 为容器指定一个名称

-d: 后台运行容器并返回容器ID,也启动守护式容器(后台运行);

--i:以交互模式运行容器,通常与-t同时使用;

-t:为容器重新分配一个伪输入终端,通常与-i同时使用;也即启动交互式容器(前台有伪终端,等待交互);

-P:随机端口映射,大写P

-p:指定端口映射,小写p

②启动交互式容器

i interactive 交互 t tyy 伪终端 shell 交互命令的接口

#使用镜像centos:latest以交互模式启动一个容器,在容器内执行/bin/bash命令。

docker run -it ubuntu /bin/bash

docker run -it centos /bin/bash

参考说明:

-i:交互式操作。

-t:终端。

centos/ubuntu :centos/ubuntu镜像

/bin/bash:放在镜像名后的是命令,这里我们希望有个交互式Shell,因此用的是/bin/bash。

要退出终端,直接输入exit

2.列出当前所有正在运行的容器

docker ps [OPTIONS]

只要能返回出容器id的编号,说明这个镜像又生成了第二个容器实例,docker这条鲸鱼背上就有两个集装箱,这两个集装箱都是来自于同一份镜像,我运行着两个ubuntu实例

我们再开一个终端

OPTIONS说明(常用):

-a:列出当前所有正在运行的容器+历史上运行过的。

-l:显示最近创建的容器。

-n:显示最近n个创建的容器。

-q:静默模式,只显示容器编号。

3.退出容器

有两种退出方式:

①exit

run进去容器,exit退出,容器停止

②ctrl+p+q

run进去容器,ctrl+p+q退出,容器不停止

为什么只有73M,因为它只加载Linux内核,其他一些用不到的统统去掉,要用到的话,自己再去装。

第二个容器用快捷键ctrl+p+q退出,容器不停止

4.启动已停止运行的容器

docker start 容器ID或者容器名

5.重启容器

docker restart 容器ID或者容器名

6.停止容器

docker stop 容器ID或者容器名

7.强制停止容器

docker kill 容器ID或者容器名

8.删除已停止的容器

docker rm 容器ID

无法删除正在运行的容器

如果非要删除正在运行的容器加上-f

一次性删除多个容器实例

docker rm -f $(docker ps -a -q)

docker ps -a -q | xargs docker rm

假设一个容器实例stop停止容器了,然后我又给它start启动了,又想重新回去,也就是反复进出容器进行干活

也就是说可退可进,不要把容器停止

我们如何重新进入活动状态下的容器?

9.重要

(1)有镜像才能创建容器,这是根本前提(下载一个Redis6.0.8镜像演示)

(2)什么叫启动守护式容器(后台服务器)?

在大部分的场景下,我们希望docker的服务是在后台运行的,我们可以通过-d指定容器的后台运行模式。

docker run -d 容器名

#使用镜像centos:latest以后台模式启动一个容器

docker run -d centos

问题:然后docker ps -a 进行查看,会发现容器已经退出

很重要的要说明一点:Docker容器后台运行,就必须有一个前台进程。

容器运行的命令如果不是那些一直挂起的命令(比如运行top,tail),就是会自动退出的。

这个是docker的机制问题,比如你的web容器,我们nginx为例,正常情况下,我们配置启动服务只需启动响应的service即可。例如service nginx start

但是,这样做,nginx为后台进程模式运行,就导致docker前台没有运行的应用,这样的容器后台启动后,会立即自杀因为他觉得他没事可做了。

所以,最佳的解决方案是,将你要运行的程序以前台进程的形式运行,常见就是命令行模式,表示我还有交互操作,别中断

所以,有些镜像-d是不可以的,你就得用-it

我们接下来用redis演示前台和后台的区别

redis前后台启动演示case

①前台交互式模式

docker run -it redis:6.0.8

一不小心我按个Ctrl+C马上就退出,我们这个docker ps这个服务就没了,你想想你的redis经常被别人这样关了,缓存没了,啥也没了,所以像redis这样的-it前台交互就找死,一般而言mysql、redis这样的后台默默地做个服务器启动着就行了

②后台守护式启动

docker run -d redis:6.0.8

回到刚刚的定义,-d:后台运行容器并返回容器ID,也即启动守护式容器(后台运行)

(3)查看容器的日志

docker logs 容器ID

现在的工作基本是:1.编码开发微服务 2.上线部署容器化 3.时时刻刻要监控 4.devops

(4)查看容器内运行的进程

docker top 容器ID

(5)查看容器内部细节

docker inspect 容器ID

(6)进入正在运行中的容器并以命令行交互

①docker exec -it 容器ID bashShell

②重新进入:docker attach 容器ID

上述两个区别:1. attach直接进入容器启动命令的终端,不会启动新的进程,用exit退出,会导致容器的停止

  1. exec 是在容器中打开新的终端,并且可以启动新的进程,用exit退出,不会导致容器的停止。

推荐大家使用docker exec命令,因为退出容器终端,不会导致容器的停止。

用之前的redis容器实例进入试试

docker exec -it 容器ID /bin/bash

docker exec -it 容器ID redis-cli

一般用-d后台启动的程序,再用exec进入对应容器实例

(7)从容器内拷贝文件到主机上

假设启动了一个ubuntu容器,我当前是在ubuntu的根目录下面,进行一系列的操作

但是架不住发生意外,比如说:有个人,强制把这个容器给删了,那么在9a66容器实例里面,做的工作a.txt是不是就消失了,因为我的容器都被人删了,但是里面的数据资料很重要,以防万一,需要提前备份。需要把容器中的重要数据,重要内容拷贝到主机上,也就是说删了这个容器也不怕。输入下列命令:

docker cp 容器ID:容器内路径 目的的主机路径

实例:

(8)导入和导出容器

export导出容器的内容流作为一个tar归档文件[对应import命令]

import从tar包中的内容创建一个新的文件系统再导入为镜像[对应export]

案例:

docker export 容器ID > 文件名.tar

cat 文件名.tar | docker import - 镜像用户/镜像名:镜像版本号

把ubuntu容器实例删了

现在,我们要按照公式,看看我们能不能恢复过来呢?

文件依然还在,这种是镜像级的备份

(9)小总结

attach Attach to a running container #当前shell下attach连接指定运行镜像

build Build an image from a Dockerfile #通过Dockerfile定制镜像

commit Create a new image from a container changes #提交当前容器为新镜像

cp Copy files/folders from the containers filesystem to the host path #从容器中拷贝指定文件或者目录到宿主机中

create Create a new container #创建一个新的容器,同run,但是不启动容器

diff Inspect changes on a container's filesystem #查看docker容器变化

events Get real time events from the server #从docker服务获取容器实时事件

exec Run a command in an existing container #在已存在的容器上运行命令

export Stream the contents of a container as a tar archive #导出容器的内容流作为一个tar归档文件[对应import]

import Create a new filesystem image from the contents of a tarball #从tar包中的内容创建一个新的文件系统映像[对应export]

info Display system-wide information #显示系统相关信息

inspect Return low-level information on a container #查看容器详细信息

kill Kill a running container #kill指定docker容器

load Load an image from a tar archive #从一个tar包中加载一个镜像[对应save]

login Register or Login to the docker registry server #注册或者登录一个docker源服务器

logout Log out from a Docker registry server #从当前Docker registry退出

logs Fetch the logs of a container #输入当前容器日志信息

port lookup the public-facing port which is NAT-ed to PRIVATE_PORT #查看映射端口对应的容器内部源端口

pause Pause all processes within a container #暂停容器

ps List containers #列出容器列表

pull Pull an image or a repository to the docker registry server #从docker镜像源服务器拉取指定镜像或者库镜像

push Push an image or a repository to the docker registry server #推送指定镜像或者库镜像至docker源服务器

restart Restart a running container #重启运行的容器

rm Remove one or more containers #移除一个或者多个容器

rmi Remove one or more images #移除一个或者多个镜像[无容器使用该镜像才可删除,否则需要删除相关容器才可继续或-f强制删除]

run Run a command in a new container #创建一个新的容器并运行一个命令

save Save an image to a tar archive #保存一个镜像为一个tar包[对应load]

search Search for an image on the Docker Hub #在docker hub中搜索镜像

start Start a stopped containers #启动容器

stop Stop a running containers #停止容器

tag Tag an image into a repository #给源中镜像大标签

top Lookup the running processes of a container #查看容器中运行的进程信息

unpause Unpause a paused container #取消暂停容器

version Show the docker version information #查看docker版本号

wait Block untill a container stops, then print its exit code #截取容器停止时的退出状态值

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/我家小花儿/article/detail/537853
推荐阅读
相关标签
  

闽ICP备14008679号