Docker容器运行后,如何进入容器进行 *** 作呢看起初我是用SSH。如果只启动一个容器,用SSH还能应付,只需要将容器的22端口映射到本机的一个端口即可。当我启动了五个容器后,每个容器默认是没有配置SSH Server的,安装配置SSHD,映射容器SSH端口,实在是麻烦。 我发现很多Docker镜像都是没有安装SSHD服务的,难道有其他方法进入Docker容器看有很多种方法,包括使用 docker attach 命令或 nsenter 工具等。
使用 attach 命令有时候并不方便。当多个窗口同时 attach 到同一个容器的时候,所有窗口都会同步显示。
nsenter 可以访问另一个进程的名字空间。
为了连接到容器,你还需要找到容器的第一个进程的 PID,可以通过下面的命令获取。
PID=$(docker inspect –format 逗{{ StatePid }}地 <container>) //将<container>换成你的容器id
通过这个 PID,就可以连接到这个容器:
$ nsenter –target $PID –mount –uts –ipc –net –pid
更简单的,建议大家下载 bashrc_docker,并将内容放到 bashrc 中。
1 安装 Docker
在开始前,我们首先得确保在Linux主机中已经安装了Docker。这里,我运行的是CentOS 7 主机,我们将运行yum管理器和下面的命令来安装Docker。
# yum install docker
# systemctl restart dockerservice
2 创建 Dockerfile
现在,Docker守护进程已经在运行中了,我们现在准备创建自己的Firefox Docker容器。我们要创建一个Dockerfile,在其中我们要输入需要的配置来创建一个可以工作的Firefox容器。为了运行 Docker 镜像我们需要使用最新版本的CentOS。要创建 Docker 镜像,我们需要用文本编辑器创建一个名为Dockerfile的文件。
# nano Dockerfile
接着,在Dockerfile中添加下面的行并保存。
#!/bin/bashFROM centos:7RUN yum install -y firefox# 用你自己的 uid /gid 替换下面的0RUN export uid=0 gid=0RUN mkdir -p /home/developerRUN echo "developer:x:${uid}:${gid}:Developer,,,:/home/developer:/bin/bash" >> /etc/passwdRUN echo "developer:x:${uid}:" >> /etc/groupRUN echo "developer ALL=(ALL) NOPASSWD: ALL" >> /etc/sudoersRUN chmod 0440 /etc/sudoersRUN chown ${uid}:${gid} -R /home/developerUSER developerENV HOME /home/developerCMD /usr/bin/firefox
注意:在第四行的配置中,用你自己的用户和组id来替换0。 我们可以用下面的命令在shell或者终端中得到uid和gid。
java。图形用户界面是由组件和容器构成。组件又称控制组件,是图形用户界面中不可再分的最小元素,起功能是与用户完成一次交互 *** 作。容器是若干个组件容器的集合。容器又分为顶层容器和中间容器所以Java是图形用户的容器。
因为Docker技术的火热,因此在工作中我们经常会以容器的方式来运行一个应用。每当容器无法成功运行或者想要对容器中的应用参数、应用配置以及应用启动进行深入研究时,当然希望能够像在宿主机上调试程序一样在容器中调试应用。容器的本质包括应用与应用运行所依赖的环境, 因此首先需要创建一个空壳容器(没有运行应用的应用容器),然后进入容器中调试应用。此处的空壳容器提供了应用运行所需的环境,进而可方便的在其中调试应用。实践环境:Centos72+Docker1126。
比较规范的镜像的Dockerfile中通常会有ENTRYPOINT与CMD的定义(Docker官方推荐这样做)。因此容器的启动命令则为ENTRYPOINT所对应的脚本或可执行程序加上CMD中定义的内容。比如elasticsearch的Dockerfile定义的ENTRYPOINT与CMD分别为:ENTRYPOINT ["/docker-entrypointsh"] CMD ["elasticsearch"],则创建的容器的启动命令为: /docker-entrypointsh elasticsearch ;mysql的Dockerfile:ENTRYPOINT ["docker-entrypointsh"] CMD ["mysqld"],则创建的容器的启动命令为: /docker-entrypointsh mysqld 。所以想要知道一个容器的启动命令需要首先了解其镜像的Dockerfile中ENTRYPOINT与CMD的定义。如何查看一个镜像的ENTRYPONT与CMD的值呢?一般采用如下两种方式:
上述第一种方式适用于比较规范的镜像,这类镜像通常会提供清晰、具体的Dockerfile。第二种方式适用于各种镜像,尽管是不规范的镜像。通过history、inspect两个命令的任一个均可快速、方便的查看镜像的ENTRYPOINT与CMD的值。
若要调试容器中的应用程序,则需额外的设置实现。docker run命令提供的--entrypoint参数能够覆盖Dockerfile中默认定义的ENTRYPOINT;docker run [OPTIONS] IMAGE [COMMAND] [ARG]的COMMAND能够替换Dockerfile中定义的CMD。通过上面的示例可以发现,有的镜像的Dockerfile中ENTRYPOINT值为:/docker-entrypointsh,CMD为应用的可执行程序;有的镜像的Dockerfile中ENTRYPOINT值为应用的可执行程序,CMD为可执行程序的参数。因此针对不同的镜像想要创建空壳容器其方式是不同的。
容器其实是应用与应用运行所依赖的环境,创建空壳容器即提供了应用所需要的环境,进入此环境中可以调试应用,可以验证应用的各个参数,同样更可以像在宿主机中运行程序一样在此环境中运行应用,区别仅是容器与宿主机的两个环境。上面是对如何在容器中调试应用程序做的一些记录,希望与大家一起讨论、交流,一起学习。
Docker 提供了一个可以运行你的应用程序的封套(envelope),或者说容器。它原本是 dotCloud 启动的一个业余项目,并在前些时候开源了。它吸引了大量的关注和讨论,导致 dotCloud 把它重命名到 Docker Inc。它最初是用 Go 语言编写的,它就相当于是加在 LXC(LinuX Containers,linux 容器)上的管道,允许开发者在更高层次的概念上工作。
Docker 扩展了 Linux 容器(Linux Containers),或着说 LXC,通过一个高层次的 API 为进程单独提供了一个轻量级的虚拟环境。Docker 利用了 LXC, cgroups 和 Linux 自己的内核。和传统的虚拟机不同的是,一个 Docker 容器并不包含一个单独的 *** 作系统,而是基于已有的基础设施中 *** 作系统提供的功能来运行的。这里有一个 Stackoverflow 的答案,里面非常详细清晰地描述了所有 Docker 不同于纯粹的 LXC 的功能特性
Docker 会像一个可移植的容器引擎那样工作。它把应用程序及所有程序的依赖环境打包到一个虚拟容器中,这个虚拟容器可以运行在任何一种 Linux 服务器上。这大大地提高了程序运行的灵活性和可移植性,无论需不需要许可、是在公共云还是私密云、是不是裸机环境等等。
Docker 由下面这些组成:
1 Docker 服务器守护程序(server daemon),用于管理所有的容器。
2 Docker 命令行客户端,用于控制服务器守护程序。
3 Docker 镜像:查找和浏览 docker 容器镜像。
基于 Docker 构建和发布 Python 应用程序通常需要以下步骤:
编写 Python 应用程序代码。可以使用任何你熟悉的 Python 框架,如 Flask、Django 等。
创建一个 Dockerfile,用于定义 Docker 镜像的构建过程。在 Dockerfile 中,需要指定基础镜像、安装 Python 库、将应用程序代码复制到镜像中等 *** 作。以下是一个示例 Dockerfile:
# 使用 Python 39 作为基础镜像
FROM python:39
# 设置工作目录
WORKDIR /app
# 复制应用程序代码到镜像中
COPY /app
# 安装依赖库
RUN pip install --no-cache-dir -r requirementstxt
# 暴露端口号
EXPOSE 8000
# 设置启动命令
CMD ["python", "apppy"]
构建 Docker 镜像。在 Dockerfile 所在的目录下,运行以下命令:
docker build -t my-python-app
其中,my-python-app 是镜像的名称, 表示使用当前目录中的 Dockerfile 进行构建。构建完成后,你可以使用以下命令查看镜像列表:
docker images
运行容器。在运行容器时,你需要指定容器名称、端口映射等参数。以下是一个示例命令:
docker run -d --name my-app -p 8000:8000 my-python-app
其中,my-app 是容器的名称,8000:8000 表示将容器的 8000 端口映射到宿主机的 8000 端口,my-python-app 是镜像的名称。
访问应用程序。运行容器后,你可以在浏览器中访问应用程序。如果应用程序使用了 Flask 等框架,你需要在应用程序代码中指定监听的端口号为 0000。
以上就是基于 Docker 构建和发布 Python 应用程序的一般步骤。需要注意的是,在实际应用中,可能还需要进行日志管理、数据备份等 *** 作,以确保应用程序的可靠性和安全性。
以上就是关于什么是多个windows实用程序的一个容器全部的内容,包括:什么是多个windows实用程序的一个容器、如何在docker容器中运行一个程序、什么是图形用户界面中程序和文件的容器等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)