当前位置: 首页 > news >正文

ip做网站域名短链接制作

ip做网站域名,短链接制作,wordpress登录地址怎么修改,商丘微网站docker网络模式能干嘛#xff1f; 容器间的互联和通信以及端口映射 容器IP变动时候可以通过服务名直接网络通信而不受到影响 docker 网络模式采用的是桥接模式#xff0c;当我们创建了一个容器后docker网络就会帮我们创建一个虚拟网卡#xff0c;这个虚拟网卡和我们的容器网…docker网络模式能干嘛 容器间的互联和通信以及端口映射 容器IP变动时候可以通过服务名直接网络通信而不受到影响 docker 网络模式采用的是桥接模式当我们创建了一个容器后docker网络就会帮我们创建一个虚拟网卡这个虚拟网卡和我们的容器网络是一一对应成对出现。默认创建的容器都是docker0网卡。 安装 Docker 以后会默认创建三种网络可以通过 docker network ls 查看 [roottest ~]# docker network ls NETWORK ID NAME DRIVER SCOPE 6f24f7cbfa10 bridge bridge local 2dc34a1c0f04 host host local 80147a6b6933 none null localDocker提供了几种网络模式用于管理容器之间的通信和与外部网络的连接。下面是几种常见的网络模式及其原理 桥接模式Bridge桥接模式是Docker默认的网络模式。在桥接模式下Docker会为每个容器创建一个虚拟网络接口并通过一个虚拟交换机连接这些接口。容器可以相互通信也可以通过主机的网络接口连接到外部网络。 主机模式Host主机模式下容器与主机共享网络栈即容器使用主机的网络接口和IP地址。这意味着容器可以直接使用主机的网络功能但也可能导致端口冲突和安全风险。 无网络模式None无网络模式下容器没有网络接口和连接只能与其他容器进行通信。这种模式适用于一些特殊需求如只需要容器之间的通信而不需要与外部网络连接的情况。 覆盖网络模式Overlay覆盖网络模式用于在多个Docker主机之间创建一个虚拟网络容器可以跨主机进行通信。这种模式通常用于构建分布式应用程序或容器集群。 这些网络模式可以根据实际需求进行选择和配置以满足容器之间和容器与外部网络的通信需求。 - bridge模式使用--network bridge指定默认使用docker0 - host模式使用--network host指定 - none模式使用--network none指定 - container模式使用--network container:NAME或者容器ID指定容器实例内默认网络IP生产规则 先启动两个ubuntu容器实例 [roottest ~]# docker run -it --name u1 ubuntu bash Unable to find image ubuntu:latest locally latest: Pulling from library/ubuntu 3153aa388d02: Pull complete Digest: sha256:0bced47fffa3361afa981854fcabcd4577cd43cebbb808cea2b1f33a3dd7f508 Status: Downloaded newer image for ubuntu:latest rootab3aff38e17c:/# ^C rootab3aff38e17c:/# exit exit [roottest ~]# docker run -it --name u2 ubuntu bash root53685573c8cd:/# exit exit $ docker inspect 容器ID or 容器名字[roottest ~]# docker start u1 u1 [roottest ~]# docker inspect u1| tail -n 20Networks: {bridge: {IPAMConfig: null,Links: null,Aliases: null,NetworkID: 6f24f7cbfa10048e76b574ec90900abadf9fefbe49a2df57f356d43cecdaf33a,EndpointID: 60b9e3c0386bdbc7779b66a27b3d2f0e06136081cb9eae7a99801ae9d0a8707b,Gateway: 172.17.0.1,IPAddress: 172.17.0.2,IPPrefixLen: 16,IPv6Gateway: ,GlobalIPv6Address: ,GlobalIPv6PrefixLen: 0,MacAddress: 02:42:ac:11:00:02,DriverOpts: null}}}} ] [roottest ~]# docker start u2 u2 [roottest ~]# docker inspect u2| tail -n 20Networks: {bridge: {IPAMConfig: null,Links: null,Aliases: null,NetworkID: 6f24f7cbfa10048e76b574ec90900abadf9fefbe49a2df57f356d43cecdaf33a,EndpointID: 4ac287832bd590e3758c60f5beef97e294d16fcc6cded9b2c3ffbc30a0a02429,Gateway: 172.17.0.1,IPAddress: 172.17.0.3,IPPrefixLen: 16,IPv6Gateway: ,GlobalIPv6Address: ,GlobalIPv6PrefixLen: 0,MacAddress: 02:42:ac:11:00:03,DriverOpts: null}}}} ] 关闭u2实例新建u3查看ip变化 [roottest ~]# docker run -it --name u3 ubuntu bash rootdb76ae3a6f5d:/# exit exit [roottest ~]# docker start u3 u3 [roottest ~]# docker inspect u3| tail -n 20Networks: {bridge: {IPAMConfig: null,Links: null,Aliases: null,NetworkID: 6f24f7cbfa10048e76b574ec90900abadf9fefbe49a2df57f356d43cecdaf33a,EndpointID: c67f166e2c399d62ada2d58a7a274f161378aa0a9c9c352e7907c3f2a7f8df45,Gateway: 172.17.0.1,IPAddress: 172.17.0.3,IPPrefixLen: 16,IPv6Gateway: ,GlobalIPv6Address: ,GlobalIPv6PrefixLen: 0,MacAddress: 02:42:ac:11:00:03,DriverOpts: null}}}} ] docker容器内部的ip是有可能会发生改变的 Bridge 网络模式 Docker 服务默认会创建一个 docker0 网桥其上有一个 docker0 内部接口该桥接网络的名称为docker0它在内核层连通了其他的物理或虚拟网卡这就将所有容器和本地主机都放到同一个物理网络。Docker 默认指定了 docker0 接口 的 IP 地址和子网掩码让主机和容器之间可以通过网桥相互通信。 在该模式中Docker 守护进程创建了一个虚拟以太网桥 docker0新建的容器会自动桥接到这个接口附加在其上的任何网卡之间都能自动转发数据包。 默认情况下守护进程会创建一对对等虚拟设备接口 veth pair将其中一个接口设置为容器的 eth0 接口容器的网卡另一个接口放置在宿主机的命名空间中以类似 vethxxx 这样的名字命名从而将宿主机上的所有容器都连接到这个内部网络上 运行一个基于 busybox 镜像构建的容器 bbox01查看 ip addr [roottest ~]# docker run -it --name bbox01 busybox Unable to find image busybox:latest locally latest: Pulling from library/busybox 809d8e20e203: Pull complete Digest: sha256:2376a0c12759aa1214ba83e771ff252c7b1663216b192fbe5e0fb364e952f85c Status: Downloaded newer image for busybox:latest / # ip addr 1: lo: LOOPBACK,UP,LOWER_UP mtu 65536 qdisc noqueue qlen 1000link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00inet 127.0.0.1/8 scope host lovalid_lft forever preferred_lft forever 26: eth0if27: BROADCAST,MULTICAST,UP,LOWER_UP,M-DOWN mtu 1500 qdisc noqueue link/ether 02:42:ac:11:00:06 brd ff:ff:ff:ff:ff:ffinet 172.17.0.6/16 brd 172.17.255.255 scope global eth0valid_lft forever preferred_lft forever / # 守护进程还会从网桥 docker0 的私有地址空间中分配一个 IP 地址和子网给该容器并设置 docker0 的 IP 地址为容器的默认网关。也可以安装 yum install -y bridge-utils 以后通过 brctl show 命令查看网桥信息 [roottest ~]# yum install -y bridge-utils [roottest ~]# brctl show bridge name bridge id STP enabled interfaces docker0 8000.02428fef6e06 no veth155aaecvethad8699evethc94dda7vethda06ae9vethded9001 对于每个容器的 IP 地址和 Gateway 信息我们可以通过 docker inspect 容器名称|ID 进行查看在 NetworkSettings 节点中可以看到详细信息 [roottest ~]# docker network inspect bridge [{Name: bridge,Id: 6f24f7cbfa10048e76b574ec90900abadf9fefbe49a2df57f356d43cecdaf33a,Created: 2023-07-11T07:22:15.715138449Z,Scope: local,Driver: bridge,EnableIPv6: false,IPAM: {Driver: default,Options: null,Config: [{Subnet: 172.17.0.0/16,Gateway: 172.17.0.1}]},Internal: false,Attachable: false,Ingress: false,ConfigFrom: {Network: },ConfigOnly: false,Containers: {19d14c2fdb62b0b30e33e9fa5f95813ae949cdba450f3b942a152cbf03ad9b45: {Name: db1,EndpointID: c230a062220ca20aca60fbe4d5f987eb4c6909f6967b918f51ac31cd1620f613,MacAddress: 02:42:ac:11:00:03,IPv4Address: 172.17.0.3/16,IPv6Address: },2715db54f63af6991cf200dd25ec8bb035ad367c98994abd054727b831e61edb: {Name: bbox01,EndpointID: 5801b8ff13e9adabb55a39fd5cb3d6d8124af807311f10bf05f842c621952637,MacAddress: 02:42:ac:11:00:06,IPv4Address: 172.17.0.6/16,IPv6Address: },3f2d71eecb6cd747ce694ecaa4bab58a22360886002837ea65f2659cd61119d6: {Name: db3,EndpointID: a2630ab3ef3836884fe855cbd99af08fabab7424134bfa67e886329db4a45430,MacAddress: 02:42:ac:11:00:05,IPv4Address: 172.17.0.5/16,IPv6Address: },6fad6aa97b03adf3a613e5109792c0c1d35f0d076ea9a097d3f645d54139eec9: {Name: db2,EndpointID: a74cc32c585de49e1799311dd74791070b4fce3a1c8ad06c57a27de6363593fd,MacAddress: 02:42:ac:11:00:04,IPv4Address: 172.17.0.4/16,IPv6Address: },9b45a8a658434d43a73857ab3d3f98bfaaeb8b9bc4b15a20bcfbba74ff6b3439: {Name: dbdata,EndpointID: fb6974276d93659c2bbaaf9cb74e51a4a120970ff842f0d52295a272ccd7129e,MacAddress: 02:42:ac:11:00:02,IPv4Address: 172.17.0.2/16,IPv6Address: }},Options: {com.docker.network.bridge.default_bridge: true,com.docker.network.bridge.enable_icc: true,com.docker.network.bridge.enable_ip_masquerade: true,com.docker.network.bridge.host_binding_ipv4: 0.0.0.0,com.docker.network.bridge.name: docker0,com.docker.network.driver.mtu: 1500},Labels: {}} ] Bridge说明 Docker使用Linux桥接在宿主机虚拟一个Docker容器网桥(docker0)Docker启动一个容器时会根据Docker网桥的网段分配给容器一个IP地址称为Container-IP同时Docker网桥是每个容器的默认网关。因为在同一宿主机内的容器都接入同一个网桥这样容器之间就能够通过容器的Container-IP直接通信。 docker run 的时候没有指定network的话默认使用的网桥模式就是bridge使用的就是docker0。在宿主机ifconfig,就可以看到docker0和自己create的network(后面讲)eth0eth1eth2……代表网卡一网卡二网卡三……lo代表127.0.0.1即localhostinet addr用来表示网卡的IP地址 网桥docker0创建一对对等虚拟设备接口一个叫veth另一个叫eth0成对匹配。 整个宿主机的网桥模式都是docker0类似一个交换机有一堆接口每个接口叫veth在本地主机和容器内分别创建一个虚拟接口并让他们彼此联通这样一对接口叫veth pair 每个容器实例内部也有一块网卡每个接口叫eth0 docker0上面的每个veth匹配某个容器实例内部的eth0两两配对一一匹配。 通过上述将宿主机上的所有容器都连接到这个内部网络上两个容器在同一个网络下,会从这个网关下各自拿到分配的ip此时两个容器的网络是互通的。 查看所有 bridge 网络模式下的容器在 Containers 节点中可以看到容器名称 关于 bridge 网络模式的使用只需要在创建容器时通过参数 --net bridge 或者 --network bridge 指定即可当然这也是创建容器默认使用的网络模式也就是说这个参数是可以省略的 Bridge 桥接模式的实现步骤主要如下 Docker Daemon 利用 veth pair 技术在宿主机上创建一对对等虚拟网络接口设备假设为 veth0 和 veth1。而 veth pair 技术的特性可以保证无论哪一个 veth 接收到网络报文都会将报文传输给另一方。 Docker Daemon 将 veth0 附加到 Docker Daemon 创建的 docker0 网桥上。保证宿主机的网络报文可以发往 veth0 Docker Daemon 将 veth1 添加到 Docker Container 所属的 namespace 下并被改名为 eth0。如此一来宿主机的网络报文若发往 veth0则立即会被 Container 的 eth0 接收实现宿主机到 Docker Container 网络的联通性同时也保证 Docker Container 单独使用 eth0实现容器网络环境的隔离性。 Host 网络模式 容器不会获得一个独立的Network Namespace而是和宿主机共用一个Network Namespace。容器将不会虚拟出自己的网卡而使用宿主机的IP和端口。 docker run -d --network host --name tomcat83 billygoo/tomcat8-jdk8# 查看容器实例内部 [roottest ~]# docker inspect tomcat83 | tail -n 20Networks: {host: {IPAMConfig: null,Links: null,Aliases: null,NetworkID: 2dc34a1c0f045de9d4f92334e27325912f47f228de3c9ed680385bf1247a4b48,EndpointID: bc0c47dab8947cb1d0667b30dc4cecaa836c1a8f4ce4e429cb0fea9a86b48d9a,Gateway: ,IPAddress: ,IPPrefixLen: 0,IPv6Gateway: ,GlobalIPv6Address: ,GlobalIPv6PrefixLen: 0,MacAddress: ,DriverOpts: null}}}} ] 没有设置-p的端口映射了如何访问启动的tomcat83 http://宿主机IP:8080/ [roottest ~]# curl http://127.0.0.1:8080!DOCTYPE html html langenheadmeta charsetUTF-8 /titleApache Tomcat/8.0.53/titlelink hreffavicon.ico relicon typeimage/x-icon /link hreffavicon.ico relshortcut icon typeimage/x-icon /link hreftomcat.css relstylesheet typetext/css //head... 所以容器共享宿主机网络IP这样的好处是外部主机与容器可以直接通信。 None 网络模式 在none模式下并不为Docker容器进行任何网络配置。 也就是说这个Docker容器没有网卡、IP、路由等信息只有一个lo。需要我们自己为Docker容器添加网卡、配置IP等。 禁用网络功能只有lo标识(就是127.0.0.1表示本地回环) [roottest ~]# docker run -d -p 8084:8080 --network none --name tomcat84 billygoo/tomcat8-jdk8 bca3fd1c4a6502e30154c4de69d3ce2cfba3fe39480fd99c4e266f0072a56fe6 [roottest ~]# docker inspect tomcat84 | tail -n 20Networks: {none: {IPAMConfig: null,Links: null,Aliases: null,NetworkID: 80147a6b6933fe9d3a6b15fb75e671f1c011b9fc3e06dc8622e49e5ed28e8df5,EndpointID: 005a23aae4e1a74128f4dd1fbf97af1b80cae21f0ffc1d715fee8e049602fe1f,Gateway: ,IPAddress: ,IPPrefixLen: 0,IPv6Gateway: ,GlobalIPv6Address: ,GlobalIPv6PrefixLen: 0,MacAddress: ,DriverOpts: null}}}} ] Container ⽹络模式 新建的容器和已经存在的一个容器共享一个网络ip配置而不是和宿主机共享。新创建的容器不会创建自己的网卡配置自己的IP而是和一个指定的容器共享IP、端口范围等。同样两个容器除了网络方面其他的如文件系统、进程列表等还是隔离的。 自定义网络模式 自定义桥接网络,自定义网络默认使用的是桥接网络bridge 管理员可以使用Docker网络驱动bridge、overlay、macvlan或第三方网络驱动插件创建一个自定义的网络然后将多个容器连接到同一个自定义网络。 特点 连接到用户自定义网络的容器可以使用IP地址或名称相互通信。 可以根据需要创建任意数量的自定义网络。 可以在任何时间将容器连接到这些网络。 对运行中的容器可连接、断开自定义网络无须重启容器。 用户自定义桥接网络自定义网络使用bridge网络驱动单机环境常用。生产环境推荐使用。 生产环境不推荐使用默认桥接网络推荐使用用户自定义桥接网络原因在以下区别 用户自定义桥接网络能提供容器化应用程序之间更好的隔离和互操作性。如果在默认桥接网络上运行应用栈则Docker主机需要通过其他方式来限制对端口的访问。 用户自定义桥接网络提供容器之间自动DNS解析功能可以通过名称或别名互相访问。而默认桥接网络上的容器只能通过IP地址互相访问。 容器可以在运行时与用户自定义网络连接和断开。要断开与默认桥接网络的连接需要停止容器并使用不同的网络选项重新创建该容器。 每个用户可通过自定义网络创建一个可配置的网桥。而默认桥接网络会自动穿件一个名为docker0的虚拟网桥。 用户自定义网络中所连接容器不能共享环境变量不过有更好的方式实现共享环境变量docker卷挂载、compose文件定义、集群。默认桥接网络中所连接的容器共享环境变量。 按照IP地址ping是OK的按照服务名ping不通解决办法自定义网络 步骤 自定义桥接网络,自定义网络默认使用的是桥接网络bridge 新建自定义网络 docker network create xigua_network 新建容器加入上一步新建的自定义网络 docker run -d -p 8081:8080 --xigua_network --name tomcat81 billygoo/tomcat8-jdk8 docker run -d -p 8082:8080 --xigua_network --name tomcat82 billygoo/tomcat8-jdk8自定义网络本身就维护好了主机名和ip的对应关系ip和域名都能通 从其架构和运行流程来看Docker 是一个 C/S 模式的架构后端是一个松耦合架构众多模块各司其职。 Docker 运行的基本流程为 1 用户是使用 Docker Client 与 Docker Daemon 建立通信并发送请求给后者。 2 Docker Daemon 作为 Docker 架构中的主体部分首先提供 Docker Server 的功能使其可以接受 Docker Client 的请求。 3 Docker Engine 执行 Docker 内部的一系列工作每一项工作都是以一个 Job 的形式的存在。 4 Job 的运行过程中当需要容器镜像时则从 Docker Registry 中下载镜像并通过镜像管理驱动 Graph driver将下载镜像以Graph的形式存储。…
http://www.hkea.cn/news/14400687/

相关文章:

  • 做网站外包需要提供什么保险网站建设
  • 网站微信认证江苏建设电子证书查询
  • 做网站的文案怎么写青岛教育平台网站建设
  • php网站模块网站开发如何做下载支付
  • 南京seo排名收费专业排名优化网站
  • 高端制作网站公司网站设计工具
  • 全国建设造价信息网站怎么做淘客网站
  • 福州建网站 做网页佛山提供网站设计报价
  • 福州模板建站定制网站支持 wordpress
  • 亚马逊官方网站怎么做wordpress怎么查看数据库
  • 西安SEO网站建设WordPress添加QQ咨询
  • 网站做apk制作工具手机网站静态模板下载
  • 苏州吴江做网站镇江关键字优化公司
  • 安徽省建设厅网站首页北京环保网站建设
  • 定制网站和模板建站宁波妇科最有名的医院
  • 网站做程序员西安网站制作顶尖公
  • 网站建设专家做番号类网站违法吗
  • 提高审美的网站推荐东莞网络做推广公司
  • 织梦网站地图调用全站文章网站建设课本
  • python建设网站网站建设 需求分析报告
  • 怎样做电子商务网站潍坊专业制氮机活性炭多少钱
  • 可以免费做中考题的网站被传媒公司骗了钱怎么办
  • 自己如何建设网站首页网站建设与维护 实训
  • 最牛的设计网站建设直播平台推广
  • dns解析失败登录不了网站网站建设实训报告作业
  • 好的网站建设网上海交通网站建设
  • 做外快的网站山西省城乡建设厅网站
  • 建设网站公司兴田德润免费可商用图片素材网站
  • 湖州公司网站建设wordpress模板如何安装
  • 安卓开发简单网站开发代码下载中国品牌策划网