zoukankan      html  css  js  c++  java
  • 为正在运行的容器添加端口映射

    转自:https://www.cnblogs.com/shijf/p/10386193.html

      在docker run创建并运行容器的时候,可以通过-p指定端口映射规则,但是如果后期想要为正在运行的容器添加额外的端口映射该怎么做呢?

    方法一:删除原来容器,重新run一个容器。

      记得重新run容器的时候将需要映射的端口加上;这种方法只适合没有状态的容器或者没有持久化的容器,毕竟重建后的容器是一个全新的,之前配置的东西全还原了。也可以将之前容器中的数据通过docker cp命令拷贝出来,再拷贝进新的容器中。

      优缺点:优点是简单快捷,在测试环境使用较多。缺点是如果是数据库镜像,那重新建一个又要重新配置一次,就比较麻烦了。

    方法二:修改容器的配置文件,需要重启docker进程

    容器的配置文件:/var/lib/docker/containers/[hash_of_the_container]/hostconfig.json

    其中的hashofthecontainer是docker镜像的hash值,可以通过docker ps或者docker inspect containername查看。(CONTAINER ID就可以看出来)

    根据你的实际容器id去查找

        如上图,文件中其中有一项是PortBindings,其中50000/tcp对应的是容器内部的50000端口,HostPort对应的是映射到宿主机的端口50000。8080/tcp对应的是容器内部的8080端口,HostPort对应的是映射到宿主机的端口18080。

      停止docker服务,systemctl stop docker;按需修改端口,然后启动docker服务,再启动你的容器就可以了。

       优缺点:这个方法的优点是没有副作用,操作简单。缺点是需要重启整个docker服务,如果在同一个宿主机上运行着多个容器服务的话,就会影响其他容器服务。

    方法三:使用docker commit将当前容器创建为一个镜像,在启动这个镜像时映射新的端口号出来。

    docker commit:把一个容器的文件改动和配置信息commit到一个新的镜像。这个在测试的时候会非常有用,把容器所有的文件改动和配置信息导入成一个新的docker镜像,然后用这个新的镜像重起一个容器,这对之前的容器不会有任何影响。

    1、停止docker容器

    1. docker stop container01

    2、commit该docker容器

    1. docker commit container01 new_image:tag

    3、用前一步新生成的镜像重新起一个容器

    1. docker run --name container02 -p 80:80 new_image:tag

        优缺点:这种方式的优点是不会影响统一宿主机上的其他容器,缺点是管理起来显得比较乱,没有第二种方法那么直观。

  • 相关阅读:
    spring mvc拦截器和<mvc:annotation-driven />的详解
    SpringMVC的工作流程-005
    子线程循环10次,接着主线程循环100次,接着又回到子线程循环10次,接着再回到主线程循环100次,如此循环50次-004
    简单java死锁设计002
    uwsgi手动安装时报错ValueError: invalid literal for int() with base 10: '32_1'
    flask jinja的宏
    Flask Web 开发 错误页面自定义
    Flask权限管理
    python uwsgi报错epoll_ctl(): Bad file descriptor
    linux怎么上真正的国际互联网
  • 原文地址:https://www.cnblogs.com/tianleblog/p/12659808.html
Copyright © 2011-2022 走看看