Eu tenho o Postgresql em um servidor em um contêiner de docker. Como posso me conectar a ele de fora, ou seja, do meu computador local? Que configuração devo aplicar para permitir isso?
197
Eu tenho o Postgresql em um servidor em um contêiner de docker. Como posso me conectar a ele de fora, ou seja, do meu computador local? Que configuração devo aplicar para permitir isso?
Respostas:
Você pode executar o Postgres desta maneira (mapeie uma porta):
Então agora você mapeou a porta 5432 do seu contêiner para a porta 5432 do seu servidor.
-p <host_port>:<container_port>
.Então, agora o seu postgres está acessível a partir do seupublic-server-ip:5432
Para testar: Execute o banco de dados postgres (comando acima)
Vá para dentro do seu contêiner e crie um banco de dados:
Vá para o seu host local (onde você tem alguma ferramenta ou o cliente psql).
(senha mysecretpassword)
Então, você está acessando o banco de dados (que está sendo executado na janela de encaixe em um servidor) a partir do seu host local.
Em este post é expained em detalhe.
fonte
ifconfig -u | grep 'inet ' | grep -v 127.0.0.1 | cut -d\ -f2 | head -1
docker run --net=host --name some-postgres -e POSTGRES_PASSWORD=mysecretpassword -d -p 5432:5432 postgres
Eu consegui rodar no linux
execute o docker postgres - verifique se a porta está publicada, eu uso o alpine porque é leve.
sudo docker run --rm -P -p 127.0.0.1:5432:5432 -e POSTGRES_PASSWORD="1234" --name pg postgres:alpine
usando outro terminal, acesse o banco de dados do host usando o postgres uri
psql postgresql://postgres:1234@localhost:5432/postgres
para usuários de mac, substitua psql por pgcli
fonte
sudo
para executar seu contêiner.Você também pode acessar através do comando docker exec:
Ou
fonte
su postgres
faz?Eu já estava executando o postgres na máquina host e não queria permitir conexões da rede, então executei a instância temporária do postgres no contêiner e criei o banco de dados em apenas duas linhas:
fonte
-e POSTGRES_DB=my-db
para criar my-db em vez de postgresEstou usando o django com postgres em contêineres do Docker. no arquivo docker-compose, adicione o seguinte:
que adicionará uma porta acessível pela sua máquina local. para mim, conectei o DBeaver a ele. isso evitará conflitos de porta entre sua solicitação de aplicativo e a máquina local. no início, recebi uma mensagem dizendo que a porta 5432 está em uso (que é pelo aplicativo django), então não pude acessar pelo pgAdmin ou DBeaver.
fonte
Para se conectar a partir do host local, você precisa adicionar '--net host':
Você pode acessar o servidor diretamente sem usar o exec do seu host local, usando:
fonte
Tentei conectar-me do localhost (mac) a um contêiner do postgres. Alterei a porta no arquivo docker-compose de 5432 para 3306 e iniciei o contêiner. Não faço ideia por que fiz isso: |
Tentei conectar-me ao postgres via PSequel e adminer e a conexão não pôde ser estabelecida.
Depois de voltar à porta 5432, tudo funciona bem.
Esta foi a minha experiência que eu queria compartilhar. Talvez alguém possa fazer uso disso.
fonte
/var/lib/mysql
:?Suponho que você queira visualizar os dados presentes no seu contêiner toda vez que se conectar a ele de fora. Para fazer isso, você terá que manter os dados na imagem do postgres.
Se você não possui dados persistentes, precisará repetir tudo o que fez na primeira vez.
Etapas 3, 5, 6, 7 e 8 respondem à sua pergunta diretamente.
Aqui está a visão geral detalhada de todo o processo que segui no PowerShell do Windows 10 (os comandos são os mesmos no Linux e no macOS):
Etapa 1 : iniciar o PowerShell no modo não administrador
Etapa 2 : faça o download da imagem do docker postgres:
docker pull postgres:latest
Etapa 3 : Inicie o contêiner do docker no modo desanexado e persista os dados na imagem do postgres criando um volume e vinculando-o a um destino
( Nota : por padrão 5432 é a porta padrão usada; mas declare-o explicitamente para evitar erros de conexão de clientes como pgadmin, dbeaver etc.)
docker run --name postgres-test -e POSTGRES_PASSWORD=password -p 5432:5432 -v postgres-data:/var/lib/postgresql/data -d postgres:latest
Etapa 4 : verificar o status dos contêineres em execução
docker ps -a
Etapa 5 : Entre no container_name no modo interativo
( Nota : comandos como ls, pwd etc. podem ser executados aqui se você tiver verificado os contêineres linux durante a instalação)
docker exec -it postgres-test psql -U postgres
Etapa 6 : Crie dados de amostra. Neste ponto, você pode jogar com
psql
comandos da seguinte maneira:Etapa 7 : Abra um aplicativo cliente de banco de dados como
pgadmin
oudbeaver
e digite o abaixo nos campos de conexão:Etapa 8 : insira a consulta
select * from test_table
no editor de consultas e você poderá ver a saída123
fonte
Por algum motivo, a porta 5432 parece protegida. Alterei minha configuração da porta de
5432:5432
para5416:5432
e o seguinte comando funcionou para conectar-se ao banco de dados do postgres de fora do contêiner do docker :fonte
postgres
serviço em sua máquina host, que já se ligará ao localhost: 5432, impedindo que você o utilize. Mapear uma porta de host diferente para a porta padrão 5432 dentro do contêiner é uma boa solução para isso; Como alternativa, você pode interromper o serviço postgres em seu host, mas talvez ele seja usado para algo que você precisa.primeiro abra a imagem do docker para o postgres
então você obterá a raiz -
root@868594e88b53:/#
ele precisa da conexão com o banco de dadosfonte
No caso, é uma aplicação back-end django, você pode fazer algo assim.
fonte
Há boas respostas aqui, mas Se você deseja ter alguma interface para o gerenciamento do banco de dados do postgres, pode instalar o pgAdmin no computador local e conectar-se à máquina remota usando seu IP e a porta exposta do postgres (por padrão 5432).
fonte
docker ps -a
para obter IDs de contêiner e, em seguida, docker exec -it psql -U -Wfonte
Sei que é tarde, se você usasse o docker-compose como @Martin
Estes são os trechos que me ajudaram a conectar ao psql dentro do contêiner
docker-compose run db bash
root@de96f9358b70:/# psql -h db -U root -d postgres_db
Não posso comentar porque não tenho 50 reputação. Então, espero que isso ajude.
fonte