Как проксировать подключение к postgresql, с помощью nginx?

Пользователь

от gussie.jones , в категории: SQL , 6 месяцев назад

Как проксировать подключение к postgresql, с помощью nginx?

Facebook Vk Ok Twitter LinkedIn Telegram Whatsapp

1 ответ

Пользователь

от aubree , 6 месяцев назад

@gussie.jones 

Для проксирования подключения к PostgreSQL через Nginx вам потребуется установить и настроить модуль ngx_postgres для Nginx.


Вот инструкция по установке и настройке:

  1. Установите необходимые зависимости:
1
2
sudo apt-get update
sudo apt-get install build-essential libpq-dev


  1. Загрузите и распакуйте исходные коды Nginx:
1
2
3
wget https://nginx.org/download/nginx-x.x.x.tar.gz
tar -zxvf nginx-x.x.x.tar.gz
cd nginx-x.x.x


Замените x.x.x на актуальную версию Nginx.

  1. Загрузите и распакуйте исходные коды модуля ngx_postgres:
1
2
wget https://github.com/FRiCKLE/ngx_postgres/archive/master.zip
unzip master.zip


  1. Соберите Nginx с модулем ngx_postgres:
1
2
3
./configure --add-module=/path/to/ngx_postgres-master
make
sudo make install


Замените /path/to/ngx_postgres-master на путь к распакованному модулю ngx_postgres.

  1. Создайте файл конфигурации Nginx для проксирования подключения к PostgreSQL. Например, создайте файл /etc/nginx/conf.d/postgres.conf и добавьте следующий конфиг:
 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
http {
    server {
        listen 8080;
        server_name localhost;

        location / {
            postgres_pass 127.0.0.1:5432;
            postgres_query $uri;
            postgres_type text/html;
            postgres_output off;
        }
    }
}


В этом примере Nginx будет слушать порт 8080 и проксировать запросы к локальному экземпляру PostgreSQL на порт 5432.

  1. Перезапустите Nginx для применения изменений в конфигурации:
1
sudo nginx -s reload


Теперь вы можете подключаться к PostgreSQL, используя URL-адрес http://localhost:8080/, где localhost может быть заменено на IP-адрес сервера, если вы подключаетесь к удаленному экземпляру PostgreSQL.