CoreOS(Docker가 사전 설치되어 있음)를 사용하면 두 개의 컨테이너가 함께 통신할 수 없습니다.
Gogs 컨테이너(Git 서버)에서 호출되는 MySql 컨테이너를 설정하려고 합니다.
그래서 이것이 내가 한 일입니다:
포트는 127.0.0.1로 설정되어 있어 외부에서는 접근이 불가능합니다.
docker run --name mysql1 -v /volumedata/mysql/mysql1:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=PWDHERE -p 127.0.0.1:33061:3306 -d mysql/mysql-server:latest --character-set- 서버=utf8 --collation-server=utf8_general_ci
그런 다음 설치했습니다.
docker run --name=go-git-server1 -p 10022:22 -p 10080:3000 -v /data/go-git-server1:/data gogs/gogs
내가 확인했을 때 둘 다 실행 중이었습니다.도커 ps -a문제 없이 "go-git-server1" 설치 페이지에 액세스할 수 있지만 호스트 주소를 지정하면 다음과 같습니다.
127.0.0.1:33061
Gogs 설정 페이지에서 확인 후 다음 오류가 발생합니다.
잘못된 데이터베이스 설정: tcp 127.0.0.1:33061 다이얼: getsockopt: 연결이 거부됨
나는 "go-git-server1" 컨테이너가 "docker ps -a"에 의해 제공된 IP와 포트를 사용하여 MySql 데이터베이스에 액세스하기에 충분하다고 생각합니다(그리고 초기 "docker run"을 사용하여 이미 수동으로 설정했습니다).
내가 한 걸음도 놓쳤나요? 다른 컨테이너에서 MySql 컨테이너에 액세스하기 위해 수행해야 할 다른 작업이 있습니까?
이것은 docker Inspection mysql1이 제공하는 것입니다:
docker inspect mysql1
[
{
"Id": "c811d29d866ef977eb0cb93a9697bc4afd2a51e828b7757a5ea8962d784f0166",
"Created": "2016-07-03T21:55:29.693884299Z",
"Path": "/entrypoint.sh",
"Args": [
"-p",
"127.0.0.1:33061:3306"
],
"State": {
"Status": "exited",
"Running": false,
"Paused": false,
"Restarting": false,
"OOMKilled": false,
"Dead": false,
"Pid": 0,
"ExitCode": 1,
"Error": "",
"StartedAt": "2016-07-26T18:23:36.144915853Z",
"FinishedAt": "2016-07-26T18:23:38.281589339Z"
},
"Image": "4e66d61404cc06e3c40c46f5e83bda5a14dda2838b84210c7eb5a3d6e1f7752b",
"ResolvConfPath": "/var/lib/docker/containers/c811d29d866ef977eb0cb93a9697bc4afd2a51e828b7757a5ea8962d784f0166/resolv.conf",
"HostnamePath": "/var/lib/docker/containers/c811d29d866ef977eb0cb93a9697bc4afd2a51e828b7757a5ea8962d784f0166/hostname",
"HostsPath": "/var/lib/docker/containers/c811d29d866ef977eb0cb93a9697bc4afd2a51e828b7757a5ea8962d784f0166/hosts",
"LogPath": "/var/lib/docker/containers/c811d29d866ef977eb0cb93a9697bc4afd2a51e828b7757a5ea8962d784f0166/c811d29d866ef977eb0cb93a9697bc4afd2a51e828b7757a5ea8962d784f0166-json.log",
"Name": "/mysql1",
"RestartCount": 0,
"Driver": "overlay",
"ExecDriver": "native-0.2",
"MountLabel": "system_u:object_r:svirt_lxc_file_t:s0:c724,c935",
"ProcessLabel": "system_u:system_r:svirt_lxc_net_t:s0:c724,c935",
"AppArmorProfile": "",
"ExecIDs": null,
"HostConfig": {
"Binds": [
"/donnees/mysql/mysql1:/var/lib/mysql"
],
"ContainerIDFile": "",
"LxcConf": [],
"Memory": 0,
"MemoryReservation": 0,
"MemorySwap": 0,
"KernelMemory": 0,
"CpuShares": 0,
"CpuPeriod": 0,
"CpusetCpus": "",
"CpusetMems": "",
"CpuQuota": 0,
"BlkioWeight": 0,
"OomKillDisable": false,
"MemorySwappiness": -1,
"Privileged": false,
"PortBindings": {},
"Links": null,
"PublishAllPorts": false,
"Dns": [],
"DnsOptions": [],
"DnsSearch": [],
"ExtraHosts": null,
"VolumesFrom": null,
"Devices": [],
"NetworkMode": "default",
"IpcMode": "",
"PidMode": "",
"UTSMode": "",
"CapAdd": null,
"CapDrop": null,
"GroupAdd": null,
"RestartPolicy": {
"Name": "no",
"MaximumRetryCount": 0
},
"SecurityOpt": null,
"ReadonlyRootfs": false,
"Ulimits": null,
"LogConfig": {
"Type": "json-file",
"Config": {}
},
"CgroupParent": "",
"ConsoleSize": [
0,
0
],
"VolumeDriver": ""
},
"GraphDriver": {
"Name": "overlay",
"Data": {
"LowerDir": "/var/lib/docker/overlay/4e66d61404cc06e3c40c46f5e83bda5a14dda2838b84210c7eb5a3d6e1f7752b/root",
"MergedDir": "/var/lib/docker/overlay/c811d29d866ef977eb0cb93a9697bc4afd2a51e828b7757a5ea8962d784f0166/merged",
"UpperDir": "/var/lib/docker/overlay/c811d29d866ef977eb0cb93a9697bc4afd2a51e828b7757a5ea8962d784f0166/upper",
"WorkDir": "/var/lib/docker/overlay/c811d29d866ef977eb0cb93a9697bc4afd2a51e828b7757a5ea8962d784f0166/work"
}
},
"Mounts": [
{
"Source": "/donnees/mysql/mysql1",
"Destination": "/var/lib/mysql",
"Mode": "",
"RW": true
}
],
"Config": {
"Hostname": "c811d29d866e",
"Domainname": "",
"User": "",
"AttachStdin": false,
"AttachStdout": false,
"AttachStderr": false,
"ExposedPorts": {
"3306/tcp": {},
"33060/tcp": {}
},
"Tty": false,
"OpenStdin": false,
"StdinOnce": false,
"Env": [
"MYSQL_ROOT_PASSWORD=mypwd",
"PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin",
"PACKAGE_URL=https://repo.mysql.com/yum/mysql-5.7-community/docker/x86_64/mysql-community-server-minimal-5.7.13-1.el7.x86_64.rpm"
],
"Cmd": [
"-p",
"127.0.0.1:33061:3306"
],
"Image": "mysql/mysql-server:latest",
"Volumes": {
"/var/lib/mysql": {}
},
"WorkingDir": "",
"Entrypoint": [
"/entrypoint.sh"
],
"OnBuild": null,
"Labels": {},
"StopSignal": "SIGTERM"
},
"NetworkSettings": {
"Bridge": "",
"SandboxID": "",
"HairpinMode": false,
"LinkLocalIPv6Address": "",
"LinkLocalIPv6PrefixLen": 0,
"Ports": null,
"SandboxKey": "",
"SecondaryIPAddresses": null,
"SecondaryIPv6Addresses": null,
"EndpointID": "",
"Gateway": "",
"GlobalIPv6Address": "",
"GlobalIPv6PrefixLen": 0,
"IPAddress": "",
"IPPrefixLen": 0,
"IPv6Gateway": "",
"MacAddress": "",
"Networks": {
"bridge": {
"EndpointID": "",
"Gateway": "",
"IPAddress": "",
"IPPrefixLen": 0,
"IPv6Gateway": "",
"GlobalIPv6Address": "",
"GlobalIPv6PrefixLen": 0,
"MacAddress": ""
}
}
}
}
]
나는 주어진 IP를 시도했다
ip -4 addr show docker0 | grep -Po 'inet \K[\d.]+'
...하지만 127.0.0.1에서는 실패하지만 아니요, 작동하지 않습니다.
도커 컨테이너 통신의 첫 번째 단계에서 약간 정체된 것 같습니다.
답변1
글쎄, 이것은 Linux/Docker/PuTTy 초보자 질문이므로 컨테이너의 실제 IP 주소가 어디에 있는지 알아내는 데 시간이 좀 걸렸습니다. 사실 조금 더 살펴봐야 했습니다.도커 검사결과.
바로가기는 다음과 같습니다.
docker inspect --format '{{ .NetworkSettings.IPAddress }}' mysql1
이는 다른 사람이 액세스할 수 있는 컨테이너의 IP 주소를 제공합니다. 도커 검사에서도 볼 수 있습니다.
그런 다음 gogs를 설정하려면 다음을 통해 mysql 컨테이너에 연결하고 상호 작용하면 됩니다.
docker exec -i mysql1 bash
그런 다음 데이터베이스를 생성하는 데 필요한 SQL 명령을 제공하십시오.
mysql -e 'CREATE DATABASE IF NOT EXISTS gogs CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;' -p 'passwordofdb'
이제 모든 것이 정상입니다. gogs가 설정되었으며 두 컨테이너가 통신하고 있습니다.