开端:
自己在docker里配置hadoop时候一开始忘记做映射端口了,重新配置过于麻烦所有有了这篇文章,记录一下自己学习
必须先停止运行自己要配置映射端口的容器!!!!,否则修改无效!
正文
1.解决方法就是修改容器的配置文件。首先查看自己要做映射端口的容器hash数值
docker inspect 容器名字
2.修改容器的配置文件hostconfig.json
vi /var/lib/docker/containers/你自己容器的hash数值/hostconfig.json
需要修改的地方:图中第一行的"PortBindings":{ }
如果没有做任何映射端口括号里面是空的,如图我添加了
"PortBindings":{"50070/tcp":[{"HostIp":"","HostPort":"50070"}],"8088/tcp":[{"HostIp":"","HostPort":"8088"}]}
里面包括了两个映射端口,这里 50070/tcp是容器端口, 50070是本地端口,8088同理
按照自己的需求添加
3.配置容器文件config.v2.json
vi /var/lib/docker/containers/你自己容器的hash数值/config.v2.json
如图
第六行的把Tty:false改成Tty:true
如果你容器端口在Tty前面的"ExposedPorts":{ }这个配置项里面没有的话就需要添加进去,如"ExposedPorts":{"50070/tcp":{}} 将容器内部端口暴露出来,如果不加这一句端口映射不会成功的,最后重启 docker(不可以先启动容器)。
service docker restart
把没有启动的容器启动起来就大功照成了!!
网上说用
docker ps -a
是无法查看映射的端口。
我自己的centos7虚拟机是没有这个问题。
这个文章主要记录自己的学习问题,第一次写,如有错误可以指出。