Mam Postgresql na serwerze w kontenerze dokowanym. Jak mogę się z nim połączyć z zewnątrz, to znaczy z mojego komputera lokalnego? Jakie ustawienie powinienem zastosować, aby na to pozwolić?
Mam Postgresql na serwerze w kontenerze dokowanym. Jak mogę się z nim połączyć z zewnątrz, to znaczy z mojego komputera lokalnego? Jakie ustawienie powinienem zastosować, aby na to pozwolić?
Odpowiedzi:
Możesz uruchomić Postgres w ten sposób (zamapuj port):
docker run --name some-postgres -e POSTGRES_PASSWORD=mysecretpassword -d -p 5432:5432 postgres
Teraz zmapowałeś port 5432 swojego kontenera na port 5432 twojego serwera. -p <host_port>:<container_port>
. Więc teraz twoje postgres są dostępne z twojegopublic-server-ip:5432
Aby przetestować: Uruchom bazę danych Postgres (powyższe polecenie)
docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
05b3a3471f6f postgres "/docker-entrypoint.s" 1 seconds ago Up 1 seconds 0.0.0.0:5432->5432/tcp some-postgres
Wejdź do swojego kontenera i utwórz bazę danych:
docker exec -it 05b3a3471f6f bash
root@05b3a3471f6f:/# psql -U postgres
postgres-# CREATE DATABASE mytest;
postgres-# \q
Przejdź do lokalnego hosta (gdzie masz jakieś narzędzie lub klienta psql).
psql -h public-ip-server -p 5432 -U postgres
(hasło mysecretpassword)
postgres=# \l
List of databases
Name | Owner | Encoding | Collate | Ctype | Access privileges
-----------+----------+----------+------------+------------+-----------------------
mytest | postgres | UTF8 | en_US.utf8 | en_US.utf8 |
postgres | postgres | UTF8 | en_US.utf8 | en_US.utf8 |
template0 | postgres | UTF8 | en_US.utf8 | en_US.utf8 | =c/postgres
Uzyskujesz dostęp do bazy danych (która działa w oknie dokowanym na serwerze) z lokalnego hosta.
W tym poście jest szczegółowo opisane.
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
Udało mi się uruchomić go na Linuksie
uruchom postgres dokera - upewnij się, że port jest opublikowany, używam alpine, ponieważ jest lekki.
sudo docker run --rm -P -p 127.0.0.1:5432:5432 -e POSTGRES_PASSWORD="1234" --name pg postgres:alpine
za pomocą innego terminala uzyskaj dostęp do bazy danych z hosta za pomocą URI Postgres
psql postgresql://postgres:1234@localhost:5432/postgres
dla użytkowników komputerów Mac zamień psql na pgcli
sudo
do uruchamiania swojego kontenera.
Możesz również uzyskać dostęp za pomocą polecenia docker exec poprzez:
$ docker exec -it postgres-container bash
# su postgres
$ psql
Lub
$ docker exec -it postgres-container psql -U postgres
su postgres
zrobić?
Miałem już uruchomiony postgres na maszynie hosta i nie chciałem zezwalać na połączenia z sieci, więc uruchomiłem tymczasową instancję postgres w kontenerze i utworzyłem bazę danych tylko w dwóch wierszach:
# Run PostgreSQL
docker run --name postgres-container -e POSTGRES_PASSWORD=password -it -p 5433:5432 postgres
# Create database
docker exec -it postgres-container createdb -U postgres my-db
-e POSTGRES_DB=my-db
aby utworzyć my-db zamiast postgres
Używam django z Postgres w kontenerach Docker. w pliku komponowania dokera dodaj:
db:
image: postgres:10-alpine
environment:
- POSTGRES_DB=app
- POSTGRES_USER=postgres
- POSTGRES_PASSWORD=supersecretpassword
**ports:
- "6543:5432"**
który doda dostępny port przez komputer lokalny. dla siebie podłączyłem do niego DBeaver. Zapobiegnie to konfliktom portów między żądaniem aplikacji a żądaniem komputera lokalnego. na początku dostałem komunikat, że port 5432 jest w użyciu (czyli przez aplikację django), więc nie mogłem uzyskać dostępu przez pgAdmin lub DBeaver.
Aby połączyć się z hosta lokalnego, musisz dodać „--net host”:
docker run --name some-postgres --net host -e POSTGRES_PASSWORD=mysecretpassword -d -p 5432:5432 postgres
Możesz uzyskać bezpośredni dostęp do serwera bez użycia exec z lokalnego hosta, używając:
psql -h localhost -p 5432 -U postgres
Próbowałem połączyć się z localhost (mac) z kontenerem Postgres. Zmieniłem port w pliku skompilowania dokera z 5432 na 3306 i uruchomiłem kontener. Nie mam pojęcia, dlaczego to zrobiłem: |
Następnie próbowałem połączyć się z Postgres za pośrednictwem PSequel i administratora i nie udało się nawiązać połączenia.
Po przełączeniu z powrotem na port 5432 wszystko działa dobrze.
db:
image: postgres
ports:
- 5432:5432
restart: always
volumes:
- "db_sql:/var/lib/mysql"
environment:
POSTGRES_USER: root
POSTGRES_PASSWORD: password
POSTGRES_DB: postgres_db
To było moje doświadczenie, którym chciałem się podzielić. Być może ktoś może z niego skorzystać.
/var/lib/mysql
?
Zakładam, że chcesz mieć możliwość przeglądania danych w kontenerze za każdym razem , gdy łączysz się z nim z zewnątrz. Aby to zrobić, będziesz musiał utrwalić dane na obrazie postgres.
Jeśli nie masz trwałych danych, będziesz musiał powtórzyć wszystko, co zrobiłeś za pierwszym razem.
Kroki 3, 5, 6, 7 i 8 odpowiadają bezpośrednio na twoje pytanie.
Oto szczegółowy przegląd całego procesu, który przeprowadziłem w PowerShellie systemu Windows 10 (polecenia są takie same w systemie Linux i macOS):
Krok 1 : Uruchom program PowerShell w trybie innym niż administrator
Krok 2 : Pobierz obraz dokera Postgres:
docker pull postgres:latest
Krok 3 : Uruchom kontener dokowany w trybie odłączonym i utrwal dane na obrazie postgres, tworząc wolumin i wiążąc go z miejscem docelowym
( Uwaga : domyślnie używany jest domyślny port 5432; ale należy podać go jawnie, aby zapobiec błędom połączenia od klientów takich jak pgadmin, dbeaver itp.)
docker run --name postgres-test -e POSTGRES_PASSWORD=password -p 5432:5432 -v postgres-data:/var/lib/postgresql/data -d postgres:latest
Krok 4 : Sprawdź status uruchomionych kontenerów
docker ps -a
Krok 5 : Wejdź do nazwa_kontenera w trybie interaktywnym
( Uwaga : polecenia takie jak ls, pwd itp. Można tutaj wykonać, jeśli sprawdziłeś kontenery linux podczas instalacji)
docker exec -it postgres-test psql -U postgres
Krok 6 : Utwórz przykładowe dane. W tym momencie możesz graćpsql
poleceniami w następujący sposób:
# CREATE DATABASE test;
# \c test
# CREATE TABLE test_table(something int);
# INSERT INTO test_table VALUES (123);
# SELECT * FROM test_table;
# \q
Krok 7 : Otwórz aplikację kliencką bazy danych, taką jakpgadmin
lubdbeaver
i wprowadź poniższe pola w polach połączenia:
Host: localhost
Database: test
User: postgres
Password: password
Krok 8 : Wpisz zapytanieselect * from test_table
w edytorze zapytań i powinieneś zobaczyć wynik123
Z jakiegoś powodu port 5432 wydaje się chroniony. Zmieniłem konfigurację portu z 5432:5432
na 5416:5432
i następujące polecenie zadziałało, aby połączyć się z bazą danych postgres spoza kontenera dokera :
psql -h localhost -p 5416 -U <my-user> -d <my-database>
postgres
usługę na komputerze hosta, który będzie już wiązał się z localhost: 5432, uniemożliwiając ci korzystanie z niego. Dobrym rozwiązaniem jest odwzorowanie innego portu hosta na domyślny port 5432 wewnątrz kontenera; alternatywnie możesz zatrzymać usługę postgres na swoim hoście, ale być może jest ona używana do czegoś, czego potrzebujesz.
najpierw otwórz obraz dokera dla postgres
docker exec -it <container_name>
wtedy dostaniesz root - root@868594e88b53:/#
potrzebuje połączenia z bazą danych
psql postgresql://<username>:<databasepassword>@postgres:5432/<database>
docker ps -a
aby uzyskać identyfikatory kontenera, wykonaj polecenie docker -it psql -U -W
Wiem, że jest późno, jeśli używałeś Docker-Compose jak @Martin
Są to fragmenty, które pomogły mi połączyć się z psql wewnątrz kontenera
docker-compose run db bash
root@de96f9358b70:/# psql -h db -U root -d postgres_db
Nie mogę komentować, ponieważ nie mam 50 reputacji. Mam nadzieję, że to pomoże.