Ich versuche eine Docker-Compose-Datei zu erstellen, die eine einzelne Docker-Container-Lösung ersetzen soll, die mehrere Prozesse (RQ-Worker, RQ-Dashboard und eine Flask-Anwendung) mit Supervisor ausführt.docker-compose: Redis Verbindung zwischen Containern abgelehnt
Das Host-System ein Debian 8 Linux ist und meine docker-compose.yml
sieht wie folgt aus (löschte ich alle anderen Einträge Fehlerquellen zu reduzieren):
version: '2'
services:
redis:
image: redis:latest
rq-worker1:
build: .
command: /usr/local/bin/rqworker boo-uploads
depends_on:
- redis
"rq-worker1" ist ein Python RQ worker zu verbinden versuchen, Redis über den Local Host und Port 6379 eingestellt, aber nicht um eine Verbindung herzustellen:
redis_1 | 1:M 23 Dec 13:06:26.285 * The server is now ready to accept connections on port 6379
rq-worker1_1 | [2016-12-23 13:06] DEBUG: worker: Registering birth of worker d5cb16062fc0.1
rq-worker1_1 | Error 111 connecting to localhost:6379. Connection refused.
galileoqueue_rq-worker1_1 exited with code 1
Die Ausgabe von docker ps
sieht wie folgt aus:
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
36cac91670d2 redis:latest "docker-entrypoint.sh" 14 minutes ago Up About a minute 6379/tcp galileoqueue_redis_1
Ich habe alles aus dem Ausführen der RQ-Worker gegen die lokalen IPs 0.0.0.0/127.0.0.1 und sogar localhost versucht. Andere Lösungen, die auf Stackoverflow gepostet wurden, funktionierten auch nicht für mich (z. B. docker-compose: connection refused between containers, but service accessible from host).
Und das ist mein docker info
Ausgabe:
Containers: 25
Running: 1
Paused: 0
Stopped: 24
Images: 485
Server Version: 1.12.5
Storage Driver: aufs
Root Dir: /var/lib/docker/aufs
Backing Filesystem: extfs
Dirs: 436
Dirperm1 Supported: true
Logging Driver: json-file
Cgroup Driver: cgroupfs
Plugins:
Volume: local
Network: null bridge host overlay
Swarm: inactive
Runtimes: runc
Default Runtime: runc
Security Options:
Kernel Version: 3.16.0-4-amd64
Operating System: Debian GNU/Linux 8 (jessie)
OSType: linux
Architecture: x86_64
CPUs: 8
Total Memory: 13.61 GiB
Name: gp-pc-201
ID: LBGV:K26G:UXXI:BWRH:OYVE:OQTA:N7LQ:I4DV:BTNH:FZEW:7XDD:WOCU
Hat jemand eine Idee, warum die zwischen den beiden Behältern verbinden funktioniert nicht?
Vielen Dank! Das hat den Verbindungsfehler gelöst. Ich habe den Host-Parameter für alle Python-Befehle verwendet, um eine Verbindung zu "redis" herzustellen, und es funktioniert einwandfrei. – henning82