快速修改运行中的docker容器端口映射的三种方式
目录
- 前言
- 方法一: 删除原有容器,重新建新容器
- 方法三:利用docker commit新构镜像
前言
在docker run创建并运行容器的时候,可以通过-p指定端口映射规则。但是,我们经常会遇到刚开始忘记设置端口映射或者设置错了需要修改。当docker start运行容器后并没有提供一个-p选项或设置,让你修改指定端口映射规则。那么这种情况我们该怎么处理呢?今天阿俏同学教你如何修改运行中的docker容器的端口映射?
方法一: 删除原有容器,重新建新容器
这个解决方案最为简单,把原来的容器删掉,重新建一个。当然这次不要忘记加上端口映射。
1|docker run -d -uroot -p 8989:8080 --name jenkins1 -v /home/wcy/jenkins_node:/var/jenkins_home jenkins/jenkins:2.289.3-cen 2|tos
优缺点:优点是简单快捷,在测试环境使用较多。缺点是如果是数据库镜像,那重新建一个又要重新配置一次,就会比较麻烦。
方法二:修改容器配置文件,重启docker服务
我们需要新增一个端口,就是通过这个方式处理的,亲测有效。
首先关闭docker服务
1|systemctl stop docker
关闭之后,找到容器的配置文件路径,通常都是安装在这个路径下方
1|cd /var/lib/docker/containers
然后我们在ls查看一下容器,找我们想要修改的容器ID

修改容器中的 hostconfig.json 文件

如上图所示,文件中其中有一项是PortBindings:
- 8080/tcp对应的是容器内部的8080端口,
- HostPort对应的是映射到宿主机的端口9190。
- 8361/tcp对应的是容器内部的8361端口,
- HostPort对应的是映射到宿主机的端口9191。
按需修改端口,然后重启docker服务,再启动容器服务就可以了
1|systemctl restart docker
优缺点:这个方法的优点是没有副作用,操作简单。缺点是需要重启整个docker服务,如果在同一个宿主机上运行着多个容器服务的话,就会影响其他容器服务。
方法三:利用docker commit新构镜像
docker commit:把一个容器的文件改动和配置信息commit到一个新的镜像。这个在测试的时候会非常有用,把容器所有的文件改动和配置信息导入成一个新的docker镜像,然后用这个新的镜像重起一个容器,这对之前的容器不会有任何影响。
停止docker容器
1|docker commit container01 new_image:tag
commit该docker容器
1|docker commit container01 new_image:tag
用前一步新生成的镜像重新起一个容器
1|docker run --name container02 -p 80:80 new_image:tag
优缺点:这种方式的优点是不会影响统一宿主机上的其他容器,缺点是管理起来显得比较乱,没有第二种方法那么直观
上一篇:手把手教你docker部署(使用docker-compose)教程
栏 目:其它服务器
本文标题:快速修改运行中的docker容器端口映射的三种方式
本文地址:https://zz.feitang.co/server/30880.html
您可能感兴趣的文章
- 02-02hadoop动态增加和删除节点方法介绍
- 02-02干货 | Linux新手入门好书推荐
- 02-02linux系统下MongoDB单节点安装教程
- 02-02Linux下nginx生成日志自动切割的实现方法
- 02-02Centos 6中编译配置httpd2.4的多种方法详解
- 02-02CentOS7 下安装telnet服务的实现方法
- 02-02分布式Hibernate search详解
- 02-02Hadoop对文本文件的快速全局排序实现方法及分析
- 02-02CentOS6.3添加nginx系统服务的实例详解
- 02-02Hadoop编程基于MR程序实现倒排索引示例


阅读排行
推荐教程
- 12-07一文教你怎么选择Tomcat对应的JDK版本
- 12-07tomcat启动报错jar not loaded的问题
- 12-10docker start启动容器后仍然exit状态的解决
- 12-23linux中ftp无法访问怎么办
- 12-19Zabbix SAML SSO 登录绕过漏洞的操作流程
- 12-13k8s编排之Deployment知识点详解
- 12-10Linux下如何安装Logstash
- 12-15Docker-Compose搭建Spark集群的实现方法
- 12-11docker存储目录迁移示例教程
- 01-07windows server 2008安装配置DNS服务器




