簡體   English   中英

Docker如何將請求(curl - get,post)發送到另一個容器

[英]Docker how to send request(curl - get, post) one container to another container

GET(和POST PUT ....)請求在一個容器中使用curl到另一個容器。

$ docker ps

CONTAINER ID    IMAGE      COMMAND       PORTS                                           NAMES
b184219cd8f6    otp_totp  "./run.sh"    0.0.0.0:3000->3000/tcp                           totp_api
c381c276593f    service   "/bin/sh -c"  0.0.0.0:8000->8000/tcp, 0.0.0.0:9000->9000/tcp   service
d0add6b1c72e    mysql     "/tmp/run.sh" 0.0.0.0:3306->3306/tcp                           mysql

當我發送請求curl -X GET http://localhost.3000到本地的totp_api container

totp_api返回{'status':200}

但我想在service容器中發送請求

比如// curl -X GET http://localhost:3000service totp_api容器( totp_api exec totp_api / bin / bash), totp_api會將{'status':200}server容器

project_folder
             ㄴ- docker-compose.yml # service, mysql container
api_folder
         ㄴ- docker-compose.yml # totp_api container

請一些人告訴我一些建議


API /文件夾/搬運工-compose.yml

version: '3'
services:
    totp:
        build: .
        container_name: totp_api
        volumes:
            - $PWD:/home
        ports:
            - "3000:3000"
        tty: true
        restart: always
        networks:
            - bridge

networks:
    bridge:
        driver: bridge

-

$ docker-compose up -d
$ docker network ls

NETWORK ID          NAME                DRIVER              SCOPE
4a05be5e600f        bridge              bridge              local
503d0586c7ec        host                host                local
########            ####
727bfc6cc21f        otp_bridge          bridge              local
########            ####
3c19d98d9ca5        otp_default         bridge              local

-

$ docker network inspect otp_bridge

[
    {
        "Name": "otp_bridge",
        "Id": "727bfc6cc21fd74f19eb7fe164582637cbad4c2d7e36620c1c0a1c51c0490d31",
        "Created": "2017-12-13T06:12:40.5070258Z",
        "Scope": "local",
        "Driver": "bridge",
        "EnableIPv6": false,
        "IPAM": {
                "Driver": "default",
                "Options": null,
                "Config": [
                    {
                        "Subnet": "172.19.0.0/16",
                        "Gateway": "172.19.0.1"
                    }
                ]
            },
            "Internal": false,
            "Attachable": true,
            "Ingress": false,
            "ConfigFrom": {
                "Network": ""
            },
            "ConfigOnly": false,
            "Containers": {
        "02fa407062cdd5f6f368f2d17c5e68d2f9155d1d9b30c9edcbb2386a9ded648a": {
                "Name": "totp_api",
                "EndpointID": "860c47da1e70d304399b42917b927a8cc6717b86c6d1ee6f065229e33f496c2f",
                "MacAddress": "02:42:ac:13:00:02",
                "IPv4Address": "172.19.0.2/16",
                "IPv6Address": ""
            }
        },
        "Options": {},
        "Labels": {
            "com.docker.compose.network": "bridge",
            "com.docker.compose.project": "otp"
        }
    }
]

使用docker網絡網絡命令 ,您可以確保這些容器屬於同一網絡。

該唯一網絡的副作用是容器A將知道容器B名稱:從totp_api ,您可以使用其名稱ping或卷曲service容器:

ping service

您可以:

  • 在docker compose文件中靜態執行(並重新啟動新容器), - 在運行時測試它,將現有的運行容器添加到新網絡

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM