2014-12-13 1 views
2

Так вот команду для запуска БД ПриНе удается подключиться pgbouncer и Postgres работает с грузчиком

sudo docker run --name mydb -e "POSTGRES_USER=user" -e "POSTGRES_PASSWORD=password" -t -d postgres 

Вот dockerfile для pgbouncer

from ubuntu 
RUN apt-get update && apt-get -y install pgbouncer 
COPY /pgbouncer.ini /etc/pgbouncer/ 
COPY /userlist.txt /etc/pgbouncer/ 
EXPOSE 6543 

А вот настройки для pgbouncer

[databases] 
host = mydb 

[pgbouncer] 
pool_mode = session 
listen_addr = localhost 
listen_port = 6543 
auth_type = plain 
auth_file = userlist.txt 
user = postgres 

userlist.txt

«пользователь» пароль «

Таким образом, изображение хорошо строится.

sudo docker run -P -p 6543:6543 --name pgbouncer --link mydb:mydb -t leos/pgbouncer pgbouncer /etc/pgbouncer/pgbouncer.ini 

Я начинаю его с этой командой, и я знаю, что pgbouncer работает, потому что pgadmin пытается подключиться к базе данных.

И pgbouncer дает мне этот вывод (который почему-то ничего не говорит о том, подключен ли pgbouncer к базе данных или нет).

2014-12-13 12:28:28.937 1 ERROR host: syntax error in connstring 
2014-12-13 12:28:28.937 1 LOG File descriptor limit: 524288 (H:1048576), max_client_conn: 100, max fds possible: 110 
2014-12-13 12:28:28.937 1 LOG listening on ::1/6543 
2014-12-13 12:28:28.937 1 LOG listening on 127.0.0.1:6543 
2014-12-13 12:28:28.937 1 LOG listening on unix:/tmp/.s.PGSQL.6543 
2014-12-13 12:28:28.937 1 LOG process up: pgbouncer 1.5.4, libevent 2.0.21-stable (epoll), adns: evdns2 
2014-12-13 12:29:28.938 1 LOG Stats: 0 req/s, in 0 b/s, out 0 b/s,query 0 us 
2014-12-13 12:30:28.939 1 LOG Stats: 0 req/s, in 0 b/s, out 0 b/s,query 0 us 
2014-12-13 12:31:28.940 1 LOG Stats: 0 req/s, in 0 b/s, out 0 b/s,query 0 us 
2014-12-13 12:32:28.941 1 LOG Stats: 0 req/s, in 0 b/s, out 0 b/s,query 0 us 
2014-12-13 12:33:28.941 1 LOG Stats: 0 req/s, in 0 b/s, out 0 b/s,query 0 us 

И вот что я могу видеть в pgadmin

Error: Error connecting to the server: server closed the connection unexpectedly 
    This probably means the server terminated abnormally 
    before or while processing the request. 

ответ

0

Эта строка в конфигурации и докеров ОПТС не corelated.

host = mydb 
--link mydb:mydb 

Вы должны прочитать об использовании -link внутри контейнера. Вам необходимо обновить конфигурацию pgbouncer с реальным хостом/портом из ENV, предоставленным --link