docker从零开始入门(三)Docker容器和操作

147 阅读4分钟

开启掘金成长之旅!这是我参与「掘金日新计划 · 12 月更文挑战」的第4天,点击查看活动详情

Docker 容器

简单的说,容器是独立运行的一个或一组应用,以及它们的运行环境。 对应的,虚拟机可以理解为模拟运行的一整套操作系统(提供了运行态环境和其他系统环境)和运行在上面的 应用。

容器镜像的关系类似于面向对象编程中的对象与类。

查看容器状态

 docker ps //查看运行的容器 docker ps –a //查看所有的容器(包含运行和退出) docker container ls docker container ls–a 2 Docker 

启动容器

启动容器有二种方式,一种是基于镜像新建一个容器并启动,一种是将在终止状态( stopped )的容器重新启动 docker run 参数

镜像名称:

-i 保持和 docker 容器内的交互,启动容器时,运⾏的命令结束后,容器依然存活,没有退出(默认是会退出,即停⽌的)
-t 为容器的标准输⼊虚拟⼀个tty
-d 后台运⾏容器
--rm 容器在启动后,执⾏完成命令或程序后就销毁
--name 给容器起⼀个⾃定义名称
-p 宿主机:内部端口

运行一个tomcat镜像容器, docker run -i-t --name tomcat1 tomcat

docker run -d --name tomcat8081 -p  8081:8080 tomcat

查看所有容器

docker ps -a

停止容器

通过docker ps 找到容器id

docker stop 9be696a0c283 //停止正在运行容器(或Ctrl+c)
docker container stop tomcat1//停止正运行容器(ID或Names)
停止所有的容器
docker stop $(docker ps -a -q)
​

删除容器

docker rm 容器ID
例如
docker rm 8

Docker 守护态运行

更多的时候,需要让 Docker 在后台运行而不是直接把执行命令的结果输出在当前宿主机下

比如运行tomcat结果页面全是tomcat运行的日志,所以需要我们设置,取消命令行显示

image.png

此时,可以通过添 加-d 参数来实现 如果不使用 -d 参数运行容器:将会在当前宿主机运行。 如果使用了 -d 参数运行容器。此时容器会在后台运行并不会把输出的结果 (STDOUT) 打印到宿主机上面(输出结果可 以用 docker logs查看)。

查看控制台结果:

 docker logs tomcat1//(ID或Names)

运行tomcat访问查看结果

安装镜像
docker pull tomcat
运行docker
docker run -d --name tomcat808 -p  8080:8080 tomcat

防火墙要开放8080端口

查看已经开放的端口:

 firewall-cmd --list-ports 

开启端口:

firewall-cmd --zone=public --add-port=8080/tcp --permanent 

关闭端口:

 firewall-cmd --permanent --zone=public --remove-port=8080/tcp 

开启防火墙:

 systemctl start firewalld 

重启防火墙:

 firewall-cmd --reload   #重启 
 firewall systemctl stop firewalld.service #停止 
 firewall systemctl disable firewalld.service #禁止firewall开机启

image.png 学过tomcat的都知道,tomcat默认界面不是这个样子,但是这是为啥呢,我们需要进入到docker内部

image.png

Docker 进入容器

某些时候需要进入容器进行操作,使用 docker exec 命令-i -t参数 docker exec 后边可以跟多个参数,这里主要说明-i -t 参数。 只用-i参数时,由于没有分配伪终端,界 面没有我们熟悉的 Linux 命令提示符,但命令执行结果仍然可以返回。 当 -i -t 参数一起使用时,则可以看到我 们熟悉的 Linux 命令提示符。

docker exec -it 容器ID(Names)bash

举例

进入容器,对默认的tomcat进行页面修改,然后再访问查看效果。

注意默认容器内linux包是最小安装。只拥有最基本的命令 exit,不会导致容器的停止

进入目录以后很多基本linux命令无法使用

image.png 进入tomcat我们可以看到cd webapps 里面是空的,所以我们看到的页面是404

docker觉得这些占用了资源和空间,所以删除了

docker exec -it tomcat1 bash //进入容器名称叫tomcat1
要模仿tomcat的目录结构
mkdir ROOT
cd ROOT/
echo 'demo'>>index.jsp //对容器内的index.jsp进行字符串追加
然后访问我们的页面

image.png 就可以看到已经不是404了

exit,退出不会导致容器的停止

在宿主机和容器之间交换文件

在宿主机和容器之间相互COPY⽂件 cp的⽤法如下

docker cp [OPTIONS] CONTAINER:PATH LOCALPATH //容器中 复制到 宿主机
docker cp [OPTIONS] LOCALPATH|- CONTAINER:PATH //宿主机 复制到 容器中
宿主机复制一个图片到容器中:将png图片复制到了容器指定目录下
docker cp 1.png tomcat2:/usr/local/tomcat/webapps/ROOT
将容器内的index.jsp 复制出来,修改再复制回去
docker cp tomcat2:/usr/local/tomcat/webapps/ROOT/index.jsp /root

Docker 查看日志

docker logs 容器名称/ID
docker logs -f -t --since="2018-12-1" --tail=10 exam

--since : 此参数指定了输出日志开始日期,即只输出指定日期之后的日志。

-f : 查看实时日志

-t : 查看日志产生 的日期

-tail=10 : 查看最后的10条日志

qfjy_exam : 容器名称

image.png