Docker容器操作

1.Docker容器操作

  1.1查看容器

      查看正在运行容器:

docker ps

         查看所有的容器(启动过的历史容器):

docker ps –a

    

 

 

       看最后一次运行的容器:

docker ps –l

       查看停止的容器

docker ps -f status=exited

  1.2创建与启动容器

      创建容器常用的参数说明:

      创建容器命令:docker run

      -i:表示运行容器

      -t:表示容器启动后会进入其命令行。加入这两个参数后,容器创建就能登录进去。即分配一个伪终端。

     --name :为创建的容器命名。

      -v:表示目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录),可以使用多个-v做多个目录或文件映射。注意:最好做目录映射,在宿主机上做修改,然后共享到容器上。

      -d:在run后面加上-d参数,则会创建一个守护式容器在后台运行(这样创建容器后不会自动登录容器,如果只加-i -t两个参数,创建后就会自动进去容器)。

      -p:表示端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p做多个端口映射

    1.2.1交互式容器

      创建一个交互式容器并取名为mycentos

docker run -it --name=mycentos centos:7 /bin/bash

      

 

    这时我们通过ps命令查看,发现可以看到启动的容器,状态为启动状态

 

    使用exit命令 退出当前容器

 

 

   然后用ps -a 命令查看发现该容器也随之停止:

 

  1.2.2守护式容器

    创建一个守护式容器:如果对于一个需要长期运行的容器来说,我们可以创建一个守护式容器。命令如下(容器名称不能重复):

docker run -di --name=mycentos2 centos:7

     

 

 

       登录守护式容器方式:

       docker exec -it container_name (或者 container_id)  /bin/bash(exit退出时,容器不会停止)

docker exec -it  mycentos2 /bin/bash

 

  1.3停止与启动容器

    停止正在运行的容器:docker stop $CONTAINER_NAME/ID

 

       

 

 

     启动已运行过的容器:docker start $CONTAINER_NAME/ID

    

 

  1.4文件拷贝

     如果我们需要将文件拷贝到容器内可以使用cp命令

docker cp 需要拷贝的文件或目录 容器名称:容器目录

    创建一个aa复制到容器中    

  

 

 

     

 

  进入容器中查看:

  

 

 

     也可以将文件从容器内拷贝出来

docker cp 容器名称:容器目录 需要拷贝的文件或目录

  1.5目录挂载

    我们可以在创建容器的时候,将宿主机的目录与容器内的目录进行映射,这样我们就可以通过修改宿主机某个目录的文件从而去影响容器。

    创建容器 添加-v参数 后边为   宿主机目录:容器目录

docker run -di -v /usr/local/myhtml:/usr/local/myhtml --name=mycentos2 centos:7

    如果你共享的是多级的目录,可能会出现权限不足的提示:

 

 

     这是因为CentOS7中的安全模块selinux把权限禁掉了,我们需要添加参数  --privileged=true  来解决挂载的目录没有权限的问题

  1.6查看容器IP地址

    我们可以通过以下命令查看容器运行的各种数据

docker inspect mycentos2

    也可以直接执行下面的命令直接输出IP地址

docker inspect --format='{{.NetworkSettings.IPAddress}}' mycentos2  

  1.7删除容器

     删除指定的容器(注意,只能删除停止的容器):docker rm $CONTAINER_ID/NAME

    

 

      删除所有容器:docker rm `docker ps -a -q`

 

       1.8 自行使用的

docker run -d -p 3000:8080 --gpus all -e WEBUI_AUTH=False -v D:/docker/open-webui:/app/backend/data --name open-webui ghcr.io/open-webui/open-webui:cuda

1. docker run:

启动一个新的 Docker 容器。

2. -d:

表示以“分离模式”运行容器,也就是在后台运行容器,而不是在前台输出日志。

3. -p 3000:8080:

表示将容器的 8080 端口映射到宿主机的 3000 端口。也就是说,容器内的应用会在 8080 端口运行,而宿主机访问 3000 端口即可访问容器的服务。

4. --gpus all:

这个选项表示 Docker 容器将会访问宿主机上的所有 GPU(如果宿主机支持 CUDA)。在需要 GPU 加速的应用(如深度学习)中非常有用。

 

5. -e WEBUI_AUTH=False:

这是一个环境变量设置。WEBUI_AUTH=False 表示禁用 Web UI 的身份验证。这意味着容器内部的应用不需要身份验证即可访问 Web UI。

6. -v open-webui:/app/backend/data:

这是一个卷挂载选项。-v open-webui:/app/backend/data 表示将宿主机上的 open-webui 卷挂载到容器的 /app/backend/data 目录。容器内的数据会保存在宿主机上的卷中,可以在容器停止或删除后保留数据。

7. --name open-webui:

为这个容器指定一个名字 open-webui,可以通过这个名字来引用和管理容器。

8. ghcr.io/open-webui/open-webui:cuda:

这是要运行的 Docker 镜像及其标签。ghcr.io/open-webui/open-webui 是镜像的名称,cuda 是标签,通常意味着这个镜像是基于 CUDA 构建的,适用于需要 GPU 加速的应用。

posted @ 2019-10-05 15:46  亮sir  阅读(242)  评论(0)    收藏  举报