如何解决在 RedHat Centos 7 上运行的 amd64/centos:7 docker 容器中缺少 /proc/sys/net/ipv4/ip_local_reserved_ports
我在尝试对一些相当旧的软件进行 dockerize 时遇到了 Docker 和 RedHat CentOs 7 的问题。重现的步骤是:
docker pull amd64/centos:7
docker run -it --privileged amd64/centos:7 bash
[root@64e504118679 /]# echo "net.ipv4.ip_local_reserved_ports = 49001-49053" > /etc/sysctl.conf
[root@64e504118679 /]# sysctl -q -p
sysctl: cannot stat /proc/sys/net/ipv4/ip_local_reserved_ports: No such file or directory
我已经验证,在 RedHat CentOS 7 (3.10.0-1127.19.1.el7.x86_64) 上运行 Docker 时,该文件不存在于容器中,即使在主机上存在。据我所知,/proc
是从主机文件系统挂载的,并且特定于其内核,因此问题可能是 Docker 和 RedHat 内核的不兼容问题或错误。在 Ubuntu 19.04 和 MacOS Catalina 上,这都按预期工作。
请注意,我知道我正在做的事情可能并不完全符合 Docker 最佳实践,但这确实是一些相当老的软件,我目前还不想改变。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。