目录:导读
- 前言
- 一、Python编程入门到精通
- 二、接口自动化项目实战
- 三、Web自动化项目实战
- 四、App自动化项目实战
- 五、一线大厂简历
- 六、测试开发DevOps体系
- 七、常用自动化测试工具
- 八、JMeter性能测试
- 九、总结(尾部小惊喜)
前言
问题1:创建 nginx 容器尝试挂载 nginx.conf 文件时报错: mounting “/root/nginx.conf” to rootfs at “/etc/nginx/nginx.conf” caused: mount through procfd: not a directory:
在自己的服务器上想通过 nginx 镜像创建容器,并挂载镜像自带的 nginx.conf 文件
docker run -it -d -v ~/nginx.conf:/etc/nginx/nginx.conf nginx
报错:
[root@poloyy ~]# docker run -it -d -v ~/nginx.conf:/etc/nginx/nginx.conf nginx
e0e4b40446a64927603b85854c3a6472b2dfa5681fcbfa0e170c16b15e5c8fdd
docker: Error response from daemon: OCI runtime create failed: container_linux.go:380: starting container process caused: process_linux.go:545: container init caused: rootfs_linux.go:76: mounting "/root/nginx.conf" to rootfs at "/etc/nginx/nginx.conf" caused: mount through procfd: not a directory: unknown: Are you trying to mount a directory onto a file (or vice-versa)? Check if the specified host path exists and is the expected type.
[root@poloyy ~]# client_loop: send disconnect: Broken pipe
提取关键错误信息:
mounting "/root/nginx.conf" to rootfs at "/etc/nginx/nginx.conf" caused: mount through procfd: not a directory: unknown: Are you trying to mount a directory onto a file (or vice-versa)?
将“/root/nginx.conf”挂载到“/etc/nginx/nginx.conf”的rootfs导致:通过procfd挂载:不是目录:未知:您是否试图将目录挂载到文件上(反之亦然)
根因:
不支持直接挂载文件,只能挂载文件夹
想要挂载文件,必须宿主机也要有对应的同名文件
解决方法:
可以先不挂载 nginx.conf
先从容器中复制 nginx.conf 出来
然后可以自行修改 nginx.conf,自定义配置项
创建正式使用的 nginx 容器
从 test 容器中复制 nginx.conf 出来
当然也可以去网上随便找个 nginx.conf,最重要的是宿主机要有个 nginx.conf
docker run --name test -d nginx
docker cp test:/etc/nginx/nginx.conf /data/
创建正式的 nginx 容器,挂载 nginx.conf 文件
可以赋予权限
docker run --privileged -it -p 80:80 \
-v /data/nginx/conf/nginx.conf:/etc/nginx/nginx.conf:ro \
-v /data/nginx/conf/conf.d:/etc/nginx/conf.d:ro \
-v /data/nginx/html:/usr/share/nginx/html:rw \
-v /data/nginx/logs:/var/log/nginx -d nginx
问题2:运行 Mysql 容器后报错:[ERROR] InnoDB: redo log file ‘./ib_logfile0’ exists
在本机 mac docker 运行启动 mysql 容器
docker run -d -p 3306:3306 --name mysql1 -v /Users/polo/data/conf:/etc/mysql/conf.d -v /Users/polo/data/mysql:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7
现象:
查看容器日志发现报错了,本地 navicat 也连不上
重点就是第一句,某某某文件已存在,通常就是环境被覆盖了
根因:
之前通过 brew install 了 mysql,虽然 uninstall 了,但是本地文件并没有被删除
解决方案:
brew uninstall mysql
rm -rf /usr/local/var/mysql
先卸载 mysql,再删掉本地的文件即可
正常启动 Mysql 容器的日志
没有 ERROR 日志
问题3:容器内获取的时间和主机的时间不一样的问题
分别在容器和主机下执行 date 命令
可以看到,时间是完全不一样的
解决方案:
方法1:
在运行容器时,挂载 /etc/localtime 目录
docker run -d -v /etc/localtime:/etc/localtime:ro --name git
重点就是: -v /etc/localtime:/etc/localtime:ro
方法2:
docker cp /etc/localtime [容器ID或名字]:/etc/localtime
下面是我整理的2023年最全的软件测试工程师学习知识架构体系图 |
一、Python编程入门到精通
二、接口自动化项目实战
三、Web自动化项目实战
四、App自动化项目实战
五、一线大厂简历
六、测试开发DevOps体系
七、常用自动化测试工具
八、JMeter性能测试
九、总结(尾部小惊喜)
只有拼尽全力,才能创造出无限可能;努力奋斗,才能迎接辉煌的未来;不论困难多大,坚持不懈,必将获得成功;只要心怀梦想,勇往直前,必能成就非凡。
只有坚持不懈的努力,才能创造属于自己的辉煌;只有奋发向前的勇气,才能战胜一切困难。无论前路如何曲折,只要心怀梦想,就能驶向成功的彼岸。相信自己,努力拼搏,未来将成为无限可能的舞台!
每一次的努力都将化作明日的成就,只要心怀信念、坚持奋斗,就能破茧成蝶,展翅高飞。相信自己的力量,绽放梦想的光芒,不断追逐,才能成就更美好的未来。