软件测试必会 Docker 实战:掌握高频命令,夯实内功基础

本文涉及的产品
RDS MySQL DuckDB 分析主实例,基础系列 4核8GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: 软件测试必会 Docker 实战:掌握高频命令,夯实内功基础

本文为霍格沃兹测试学院学院学员 Docker 实战课程学习笔记,供各位同学参考。

在 Dokcer 横空出世之前,应用打包一直是大部分研发团队的痛点。在工作中,面对多种服务,多个服务器,以及多种环境,如果还继续用传统的方式打包部署,会浪费大量时间精力。

万物和鸣的 Docker

在 Docker 出现后,它以更高效的利用系统资源、更高效的利用系统资源、一致的运行环境、持续交付和部署、更轻松的迁移、更轻松的维护和拓展,6 大优点迅速火了起来。

Docker 的基础命令,堪称 Docker 的内功,只有把内功修炼好了,我们在 Docker 的学习路上才会更加顺畅,不会导致“走火入魔”。

接下来我将从与虚拟机的对比开始,以实战的方式,带大家更加了解,更会“玩” Docker。

Docker 和虚拟机

-- 左边为虚拟机,右边为docker环境 --

Server:物理机服务器

Host OS:构建的操作系统

Hypervisor:一种虚拟机软件,装了之后才能虚拟化操作系统

Guest OS:虚拟化的操作系统

Bins/Libs:执行命令、工具

App A:构建的软件

Docker Engine:跳过虚拟化内核的步骤,直接使用宿主机内核

从图片中我们可以清楚的了解到,相比于 Docker,虚拟机更加的臃肿。

虚拟机和容器都需要物理机以及操作系统,但是虚拟机有 Hypervisor 层以及 Guest OS 层。但是 Docker 是没有这两个部分的,只有一层 Docker Engine。

并且每个容器都和宿主机共享计算机的硬件资源以及操作系统。那么由Hypervisor带来的资源耗损,在容器这边是不存在的。所以Docker与虚拟机对比,是有很强大的优势的,当然,也会有一定的缺点。

优势(省去了虚拟化内核的步骤)

1. 节省资源(CPU、内存)

2. 秒级启动

3. 轻量级方案(同样一台服务器可以启动几百个docker,但是不能启动几百个虚拟机)

劣势

1. 隔离性、安全性相比虚拟机更弱(比如,如果其中一个容器将内核给"搞坏了",那所有的容器就都无法正常工作了)

2. 某些情况下服务器会挑内核(eg.编译c++)


Docker的作用

而对于测试人员,Docker又为我们带来了什么样的便利呢?

1. 搭建测试环境

2. 搭建各类基础服务

3. 搭建测试执行环境(自动化测试脚本执行环境)


加速器配置

在刚开始的时候,由于网络的原因,我们在下载的镜像的时候,常常速度是非常慢的。所以如果下载镜像很慢的同学,可以尝试配置国内的加速器加速镜像下载

1. 登录阿里开发者平台:


https://dev.aliyun.com/search.html

2. 点击“创建我的容器镜像”

3. 注册/登录后,进入Docker 镜像仓库,选中加速器 Tab


https://cr.console.aliyun.com/#/imageList

4. 根据个人需要, 选择运行Docker 的OS,按照要求修改Docker配置文件。

步骤如下:

修改配置文件 :

vim usr/lib/systemd/system/docker.service

添加红色部分到

"ExecStart" ExecStart=/usr/bin/dockerd --registry-mirror=<your accelerate address>

保存文件

#重新加载配制:$
systemctl daemon-reload
#重新启动服务:
service docker restart

Docker实战

好记性不如烂键盘,单单只背下来Docker的命令是不够的,还要自己多敲多去练习,才能更熟练、更深刻的掌握Docker。

用Docker搭建Jenkins服务

大家一起勤动小手,通过搭建一个Jenkins环境,去熟悉docker命令哦

(一定要仔细阅读官方镜像的文档)

下载镜像

docker pull jenkins/jenkins


查看已下载的镜像

docker images

我们可以看到刚刚下载的Jenkins镜像

那么,其中的每个字段又是什么意思呢?

删除镜像

docker rmi jenkins/IMAGE ID

我们可以看到,Jenkins镜像已经被成功删除了

下载指定版本的镜像

docker pull jenkins:3.1.x

此时我们可以发现,镜像的TAG不再是latest而是我们所指定的版本号

将镜像打包成一个tar包

docker save jenkins:2.60.3 > myjenkins.tar


将打包的镜像加载出来

docker load < myjenkins.tar


给镜像加tag号

docker tag jenkins:latest jenkins:3.6.0

打了tag之后,会发现多了一个3.6.0 tag版本的镜像,但是image ID和原本的保持一致

然后我们删掉这个镜像,发现提示untagged,且这个镜像被成功删除

给镜像改名称

docker tag jenkins:latest testjenkins

然后我们就可以看到,多了一个叫做testjenkins的镜像,但是image ID和原本的保持一致

push镜像到镜像仓库

docker tag jenkins gaofei_com/jenkins
docker push

容器命令

容器运行命令参数

1. --name 指定容器名称
2. -d 后台运行
3. -port 指定端口映射规则
4. --network 指定容器运行的网路模式
5. -v 指定需要挂载的数据卷
6. -env  指定需要传递给容器的环境变量

容器管理命令参数

1. docker run --name={your_name} --d {image_name}  (运行容器)
2. docker ps -s -a  {查看当前所有容器}
3. docker stop {container_name}  (停止容器)
4. docker kill (container_name) {杀死容器}
5. docker rm -f {container_name/id}  (删除容器)
6. docker ps -s (-s表明size)

接下来我们继续使用Jenkins进行一个实战的演练

#启动运行容器
docker run -d --name=myjenkins jenkins/jenkins
#查看当前运行中的容器
docker ps

docker ps也是我们常用的一个命令,下面是docker ps后显示的启动容器信息,其中每个字段都有自己的含义

CONTAINER ID:容器ID(和image ID无关)

如何删除这个启动的容器呢?是否可以和镜像一样,直接rm呢?

docker rm myjenkins

从图中我们可以看到,如果直接删除运行中的容器会报错,需要先stop然后删除

docker stop myjenkins
docker rm myjenkins


或者直接

docker rm -f myjenkins

我们从图片中可以看出,虽然这个容器是启动的状态,但是使用docker rm -f依然可以直接删除

在docker ps 的时候我们可以看到,PORTS字段下面显示了两个端口号,这两个端口号是做什么的呢?

其实呀,这两个端口号,是容器故意对外暴露的端口号,我们可以通过端口映射的方式,使容器内部的端口号与宿主机的某个端口号产生链接。这样我们就可以通过端口号,去访问或者操作容器啦

如何指定端口号呢?就是使用 -p 参数

docker run -d --name=myjenkins -p 8080:8080 jenkins/jenkins

将宿主机的8080端口指向容器的8080端口,这样我们在宿主机的8080端口就可以访问到Jenkins啦

在启动的过程中,我们可能会碰到各种各样的问题,我们如何定位问题呢?

当然是使用查看log大法

docker log -f myjenkins


Docker的数据持久化

学到这里,可能有同学会有疑虑啦,如果docker挂掉,在docker内产生的数据应该怎么办呢,这些数据应该如何保存呢

接下来,我们要了解的,docker是如何进行数据持久化的呢?

当我们启动容器时,添加了数据挂载的参数-v 宿主机_path:container_path,docker就可以通过数据挂载的方式,使容器和宿主机的数据进行同步保存,

接下来我们通过实战的方式,就可以看到docker是如何实现这一功能的

  1. 启动Jenkins,要增加-v挂载卷参数
docker run --name myjenkins -itd -p 8001:8080 -v /home/gaofei/test/jenkins_home:/var/jenkins_home

注意:挂载权限:sudo chown -R 1000:1000 /home/docker/jenkins

2. 使用docker exec -it myjenkins bash进入刚启动的jenkins容器,并cat
/var/jenkins_home/secrets/initialAdminPassword这一步是为了找到jenkins的启动密码

3.输入密码,进入Jenkins页面创建一个job。

4.删掉容器,重新执行之前的命令,重启Jenkins,进入页面,发现job没有因为容器被删而丢失

注意:如果容器无法成功启动,且log提示权限问题,则在启动命令中添加-u 0

Docker 容器交互

docker exec -it {容器名称} bash

进入容器,exec的意思是在容器中运行一个命令。如果使用bash 并且指定了-it 就会打开容器的shell 交互

docker exec myjenkins echo "test"
docker exec myjenkins ping www.baidu.com
docker exec -it myjenkins bash


docker cp {container:name}:{container_path} {host_path}把宿主机上的一个文件copy到容器中

docker cp 1.sh myjenkins:/var/jenkins_home


Docker的环境变量

有一些容器启动时,我们需要给他添加一些初始的参数,比如mysql,我们需要给他添加一些初始的账号和密码,docker如何操作这种情况呢?让我们动动小手,演练一下吧

1. 启动mysql容器,注意要加-e传递参数

docker run --name some-mysql -v /home/gaofei/test/mysql:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=1qaz9ol. -p 8888:3306  -d mysql:5.5

2. 通过数据库连接工具连接数据库

host要填写宿主机的ip地址,Password是我们一开始设定的

端口号填写映射的宿主机的端口号

3. 在数据库中创建一个表

4. 删掉容器,然后重启

5. 进入刚刚创建的容器内的mysql路径下,发现有刚刚添加的表,这个就是容器的数据持久化的功能啦

我们接下来再思考一个问题,因为容器是有隔离性的。

如果容器之间互相链接可以用什么方式?

这里就要引入另外一个参数啦 --link,这个参数的作用就是把一台容器的网络信息,注入到另外一台容器中

老方法,我们还是通过testlink实战,体验一下这个功能吧

  1. 启动mariadb
docker run -d --name mariadb -e ALLOW_EMPTY_PASSWORD=yes -e MARIADB_USER=bn_testlink -e MARIADB_DATABASE=bitnami_testlink -v /home/gaofei/test/mysql:/var/lib/mysql -p 8088:3306 bitnami/mariadb:latest
  1. 启动tesklink,mariadb的信息注入到testlink容器中
docker run -d --name testlink -p 8099:80 -p 444:443 -e ALLOW_EMPTY_PASSWORD=yes -e TESTLINK_DATABASE_USER=bn_testlink -e TESTLINK_DATABASE_NAME=bitnami_testlink --link mariadb bitnami/testlink:latest
  1. 查看日志,可以看到成功连接到mariadb
docker logs -f testlink


一个思考题,如果是三个容器需要连接呢,使用什么样的方式?

答案是:--env因为在docker中,--link就是通过环境变量的方式配置的。


Docker 前后端启动

现在很多网站的架构都是前后端分离,在这种情况下,我们应该如何使用docker分别启动前端和后端,且能互相通信呢?我们可以使用下面的命令

docker run --name=conan -itd -p 8999:4200 conan
docker run --name=holmes -itd --net=container:conan holmes

--net=container:conan:这样创建的容器不会创建自己的网卡,配置自己的IP,而是和一个指定的容器共享IP、端口范围。

其他命令

查看docker 的信息

docker info

获取容器/镜像的元数据

docker inspect myjenkins

以上,我们通过实战的方式了解了docker的概念,熟悉了docker的一部分基础命令,看完文章后,就要熟悉练习了哦。下一次,将带大家通过3个实战练习selenium、prometheus+grafana、mysql的监控,带大家了解docker的招式法门,学会之后,我们就可以真正的带入工作,进行实战了。更多技术文章



相关文章
|
5月前
|
存储 Java Linux
【Docker】(2)还在浏览网页寻找Docker命令?本文全面列举与使用Docker里的各个命令!想要什么命令直接从本文拿!
docker有着比VM更少的抽象层 由于Docker不需要Hypervisor实现硬件资源虚拟化,运行在Docker容器上的程序直接使用的都是实际物理机的硬件资源 因此在CPU、内存利用率上Docker将会在效率上有明显优势 docker利用的时宿主机的内核,而不需要加载操作系统OS内核 当新建一个容器时,Docker不需要和虚拟机一样重新加载一个操作系统内核 进而避免引寻、加载操作系统内核返回等比较费时费资源的过程,当新建一个虚拟机时,虚拟机软件需要加载OS,返回新建过程时分钟级别的。 而Docker由于直接利用宿主机的操作系统,则省略了返回过程,因此新建一个Docker容器只需
509 124
|
5月前
|
监控 Kubernetes 安全
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
蒋星熠Jaxonic,技术探索者,以代码为笔,在二进制星河中书写极客诗篇。专注Docker与容器化实践,分享从入门到企业级应用的深度经验,助力开发者乘风破浪,驶向云原生新世界。
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
|
9月前
|
运维 监控 数据可视化
容器化部署革命:Docker实战指南
容器化部署革命:Docker实战指南
|
8月前
|
安全 Unix Linux
Docker中授权普通用户使用docker命令以及解决无权限访问/var/run/docker.sock错误。
通过上述步骤,可以有效解决普通用户无法使用Docker命令的问题,同时处理 `/var/run/docker.sock`权限错误。这样的设置不仅方便用户使用Docker提供的各项服务,同时还能保护系统的安全性。在进行此类配置更改时,请确保理解每一步骤的作用及潜在的安全风险,尤其是在修改文件权限时。在实际的操作中,始终应该努力保持系统的最低必要权限,避免过度放宽权限,这是保障系统安全的一个重要方针。
2495 75
|
8月前
|
供应链 测试技术 开发者
用 Docker 轻松部署 ERPNext 15:多场景实战指南
ERPNext 15 是一款功能全面的开源企业资源规划系统,结合 Docker 容器化部署,具备高效、灵活、低成本等优势。适用于小微企业数字化起步、多分支机构协同办公、开发者测试环境搭建、短期项目管理及企业内部培训等多种场景。模块化设计支持按需扩展,满足不同规模企业需求,是实现高效企业管理的理想选择。
用 Docker 轻松部署 ERPNext 15:多场景实战指南
|
9月前
|
测试技术 程序员 Go
Go语言测试简明指南:深度解读go test命令
总的来说,go test是 Go 语言中一个强而有力的工具,每个 Go 程序员都应该掌握并把它融入到日常的开发和调试过程中。就像是一个眼镜过滤出的太阳,让我们在宽阔的代码海洋中游泳,而不是淹没。用好它,让我们的代码更健壮,让我们的生产力更强效。
648 23
|
9月前
|
安全 Java Docker
Docker 部署 Java 应用实战指南与长尾优化方案
本文详细介绍了Docker容器化部署Java应用的最佳实践。首先阐述了采用多阶段构建和精简JRE的镜像优化技术,可将镜像体积减少60%。其次讲解了资源配置、健康检查、启动优化等容器化关键配置,并演示了Spring Boot微服务的多模块构建与Docker Compose编排方案。最后深入探讨了Kubernetes生产部署、监控日志集成、灰度发布策略以及性能调优和安全加固措施,为Java应用的容器化部署提供了完整的解决方案指南。文章还包含大量可落地的代码示例,涵盖从基础到高级的生产环境实践。
503 4
|
8月前
|
Docker 容器
熟悉Docker容器管理命令:start、stop与restart详细使用指南
掌握这些Docker容器管理命令对于维护应用程序的正常运行至关重要。在实际操作中,应注意容器配置、关联资源以及日志等信息,确保各项操作都能够顺畅并且安全地执行。
1341 0