docker-compose yaml指定具体容器网桥ip网段subnet;docker创建即指定subnet;docker取消自启动

1、docker-compose yaml指定具体容器网桥ip网段subnet

docker-compose 启动yaml有时可能的容器网段与宿主机的ip冲突导致宿主机上不了网,这时候可以更改yaml指定subnet

宿主机内网一般是192**,这时候容器可以指定172*

cpp 复制代码
version: '3.9'
services:

  coredns:
    image: coredns/coredns:1.10.0
    container_name: coredns
    ports:
      - 53:53/udp
    networks:
      mynetwork:
        ipv4_address: 172.28.0.4
    volumes:
      - ./coredns/hostsfile:/etc/coredns/hostsfile
      - ./coredns/Corefile:/Corefile

networks:
  mynetwork1:
    driver: bridge
    ipam:
      driver: default
      config:
        - subnet: 172.28.0.0/16
          gateway: 172.28.0.1

案例:

subnet 关键字设置了容器的网桥 IP 网段为 192.168.0.0/16,其中 ipv4_address 指定了容器的 IP 地址为 192.168.0.2。

cpp 复制代码
version: '3'
services:
  myservice:
    image: <image>
    networks:
      mynetwork:
        ipv4_address: 192.168.0.2

networks:
  mynetwork:
    driver: bridge
    ipam:
      config:
        - subnet: 192.168.0.0/16

2、docker指定subnet

1)先创建自定义网络

cpp 复制代码
docker network create --subnet=172.18.0.0/16 shadownet

2)运行docker指定具体net

cpp 复制代码
docker run --net shadownet  -p 6008:6008 registry.cn-hangzhou.aliyuncs.com/fastgpt_docker/m3e-large-api

3)查看容器ip

可以看到分到的ip是指定的172.18网段下面ip **0.2

cpp 复制代码
docker inspect 0418bea8c6aecd3af266eb1

3、上面2把转出docker compose yml文件运行

1)首先相同网段名会冲突可以先删除前面的docker network rm shadownet;也可以换个名称和网段

2)运行指定yml:docker-compose -f C:\Users\loong\Downloads\subnet.yml up

subnet.yml

cpp 复制代码
version: '3'
services:
  myservice:
    image: registry.cn-hangzhou.aliyuncs.com/fastgpt_docker/m3e-large-api
    ports:
      - 6008:6008
    networks:
      - shadownet

networks:
  shadownet:
    driver: bridge
    ipam:
      config:
        - subnet: 172.18.0.0/16

3、docker取消自启动

https://stackoverflow.com/questions/37599128/docker-how-do-you-disable-auto-restart-on-a-container

--restart=always 下面更改

cpp 复制代码
docker update --restart=no <container_name_or_id>

查看是否取消成功

cpp 复制代码
docker inspect -f '{{.HostConfig.RestartPolicy.Name}}' <container_name_or_id>
相关推荐
Elastic 中国社区官方博客3 小时前
在 Kubernetes 上的依赖管理
大数据·elasticsearch·搜索引擎·云原生·容器·kubernetes·全文检索
星星乘坐的船4 小时前
Centos7.9系统下docker安装
运维·docker·容器
Elastic 中国社区官方博客6 小时前
Agentic CI/CD:使用 Kubernetes 部署门控,结合 Elastic MCP Server
大数据·人工智能·elasticsearch·搜索引擎·ci/cd·容器·kubernetes
切糕师学AI6 小时前
Kubernetes 中的 StatefulSet
云原生·容器·kubernetes
阿乐艾官6 小时前
【K8s思维导图及单节点容器启动流程】
java·容器·kubernetes
礼拜天没时间.7 小时前
企业级Docker镜像仓库Harbor部署实战
linux·运维·docker·云原生·容器·sre
阿寻寻7 小时前
【云原生技术】Pod 列表新增时间字段:取值口径与获取方式
docker·云原生·kubernetes
白太岁7 小时前
Muduo:(2) EPollPoller 实现 epoll 封装、 fd 事件监听与事件通知
网络·c++·网络协议·tcp/ip
DeeplyMind8 小时前
第27章 常见问题与解决方案
运维·docker·容器
!chen8 小时前
Ubuntu 上 Docker 的配置及代理
ubuntu·docker·eureka