pem server postgresql что это
17.9. Secure TCP/IP Connections with SSL
OpenSSL supports a wide range of ciphers and authentication algorithms, of varying strength. While a list of ciphers can be specified in the OpenSSL configuration file, you can specify ciphers specifically for use by the database server by modifying ssl_ciphers in postgresql.conf.
Note: It is possible to have authentication without encryption overhead by using NULL-SHA or NULL-MD5 ciphers. However, a man-in-the-middle could read and pass communications between client and server. Also, encryption overhead is minimal compared to the overhead of authentication. For these reasons NULL ciphers are not recommended.
In some cases, the server certificate might be signed by an «intermediate» certificate authority, rather than one that is directly trusted by clients. To use such a certificate, append the certificate of the signing authority to the server.crt file, then its parent authority’s certificate, and so on up to a «root» authority that is trusted by the clients. The root certificate should be included in every case where server.crt contains more than one certificate.
17.9.1. Using Client Certificates
To require the client to supply a trusted certificate, place certificates of the certificate authorities (CA s) you trust in the file root.crt in the data directory, and set the clientcert parameter to 1 on the appropriate hostssl line(s) in pg_hba.conf. A certificate will then be requested from the client during SSL connection startup. (See Section 31.17 for a description of how to set up certificates on the client.) The server will verify that the client’s certificate is signed by one of the trusted certificate authorities. Certificate Revocation List (CRL) entries are also checked if the file root.crl exists. (See http://h71000.www7.hp.com/doc/83final/ba554_90007/ch04s02.html for diagrams showing SSL certificate usage.)
The clientcert option in pg_hba.conf is available for all authentication methods, but only for rows specified as hostssl. When clientcert is not specified or is set to 0, the server will still verify presented client certificates against root.crt if that file exists — but it will not insist that a client certificate be presented.
Note that root.crt lists the top-level CAs that are considered trusted for signing client certificates. In principle it need not list the CA that signed the server’s certificate, though in most cases that CA would also be trusted for client certificates.
If you are setting up client certificates, you may wish to use the cert authentication method, so that the certificates control user authentication as well as providing connection security. See Section 19.3.10 for details.
17.9.2. SSL Server File Usage
Table 17-3 summarizes the files that are relevant to the SSL setup on the server.
Table 17-3. SSL Server File Usage
File | Contents | Effect |
---|---|---|
$PGDATA/server.crt | server certificate | sent to client to indicate server’s identity |
$PGDATA/server.key | server private key | proves server certificate was sent by the owner; does not indicate certificate owner is trustworthy |
$PGDATA/root.crt | trusted certificate authorities | checks that client certificate is signed by a trusted certificate authority |
$PGDATA/root.crl | certificates revoked by certificate authorities | client certificate must not be on this list |
The files server.key, server.crt, root.crt, and root.crl are only examined during server start; so you must restart the server for changes in them to take effect.
17.9.3. Creating a Self-signed Certificate
To create a quick self-signed certificate for the server, use the following OpenSSL command:
Fill out the information that openssl asks for. Make sure you enter the local host name as «Common Name» ; the challenge password can be left blank. The program will generate a key that is passphrase protected; it will not accept a passphrase that is less than four characters long. To remove the passphrase (as you must if you want automatic start-up of the server), run the commands:
Enter the old passphrase to unlock the existing key. Now do:
to turn the certificate into a self-signed certificate and to copy the key and certificate to where the server will look for them. Finally do:
because the server will reject the file if its permissions are more liberal than this. For more details on how to create your server private key and certificate, refer to the OpenSSL documentation.
Pem server postgresql что это
Примечание
Добавлять корневой сертификат в server.crt нет необходимости. Вместо этого клиенты должны иметь этот сертификат в цепочке сертификатов сервера.
17.9.1. Использование клиентских сертификатов
17.9.2. Файлы, используемые SSL-сервером
В Таблице 17.2 кратко описаны все файлы, имеющие отношение к настройке SSL на сервере. (Здесь приведены стандартные или типичные имена файлов. В конкретной системе они могут быть другими.)
Таблица 17.2. Файлы, используемые SSL-сервером
17.9.3. Создание сертификатов
Хотя самоподписанный сертификат может успешно применяться при тестировании, в производственной среде следует использовать сертификат, подписанный центром сертификации (ЦС ) (обычно это корневой ЦС предприятия).
Чтобы создать сертификат сервера, подлинность которого смогут проверять клиенты, сначала создайте запрос на получение сертификата (CSR ) и файлы открытого/закрытого ключа:
Наконец, создайте сертификат сервера, подписанный новым корневым центром сертификации:
server.crt и server.key должны быть сохранены на сервере, а root.crt — на клиенте, чтобы клиент мог убедиться в том, что конечный сертификат сервера подписан центром сертификации, которому он доверяет. Файл root.key следует хранить в изолированном месте для создания сертификатов в будущем.
Также возможно создать цепочку доверия, включающую промежуточные сертификаты:
Pem server postgresql что это
Примечание
Добавлять корневой сертификат в server.crt нет необходимости. Вместо этого клиенты должны иметь этот сертификат в цепочке сертификатов сервера.
17.9.1. Использование клиентских сертификатов
17.9.2. Файлы, используемые SSL-сервером
В Таблице 17.2 кратко описаны все файлы, имеющие отношение к настройке SSL на сервере. (Здесь приведены стандартные или типичные имена файлов. В конкретной системе они могут быть другими.)
Таблица 17.2. Файлы, используемые SSL-сервером
17.9.3. Создание сертификатов
Хотя самоподписанный сертификат может успешно применяться при тестировании, в производственной среде следует использовать сертификат, подписанный центром сертификации (ЦС ) (обычно это корневой ЦС предприятия).
Чтобы создать сертификат сервера, подлинность которого смогут проверять клиенты, сначала создайте запрос на получение сертификата (CSR ) и файлы открытого/закрытого ключа:
Наконец, создайте сертификат сервера, подписанный новым корневым центром сертификации:
server.crt и server.key должны быть сохранены на сервере, а root.crt — на клиенте, чтобы клиент мог убедиться в том, что конечный сертификат сервера подписан центром сертификации, которому он доверяет. Файл root.key следует хранить в изолированном месте для создания сертификатов в будущем.
Также возможно создать цепочку доверия, включающую промежуточные сертификаты:
Pem server postgresql что это
31.18.1. Проверка сертификатов сервера на стороне клиента
По умолчанию Postgres Pro не выполняет никакие проверки сертификата сервера. Это означает, что клиента можно ввести в заблуждение, подменив сервер (например, изменив запись в DNS или заняв его IP-адрес). Чтобы защититься от такой подмены, клиент должен иметь возможность проверять подлинность сервера по цепочке доверия. Для создания цепочки доверия нужно установить корневой (самоподписанный) сертификат центра сертификации (ЦС ) на одном компьютере, а конечный сертификат, подписанный корневым, на другом. В цепочке может использоваться и « промежуточный » сертификат, который подписывается корневым сертификатом и подписывает подчинённые сертификаты.
Чтобы клиент мог проверить подлинность сервера, установите на клиенте корневой сертификат, а на сервере установите конечный сертификат, подписанный этим корневым. Чтобы сервер мог проверить подлинность клиента, установите на сервере корневой сертификат, а на клиенте конечный сертификат, подписанный данным корневым. Конечный сертификат также может связываться с корневым через один или несколько промежуточных сертификатов (они обычно хранятся вместе с конечным сертификатом).
Чтобы настроить проверку сертификата сервера, необходимо поместить один или несколько корневых сертификатов в файл
Если существует файл
/.postgresql/root.crl (или %APPDATA%\postgresql\root.crl в Microsoft Windows), при проверке также учитывается содержащийся в нём список отозванных сертификатов (CRL, Certificate Revocation List).
Примечание
31.18.2. Клиентские сертификаты
Если сервер попытается проверить подлинность клиента, запрашивая конечный сертификат клиента, libpq будет передавать сертификаты, сохранённые в файле
/.postgresql/postgresql.crt в домашнем каталоге пользователя. Эти сертификаты должны связываться по цепочке с корневым сертификатом, которому доверяет сервер. Также должен присутствовать соответствующий закрытый ключ
Первым сертификатом в postgresql.crt должен быть сертификат клиента, так как он должен соответствовать закрытому ключу клиента. Дополнительно в этот файл могут быть добавлены « промежуточные » сертификаты — это позволит избежать хранения всех промежуточных сертификатов в файле root.crt на сервере.
За инструкциями по созданию сертификатов обратитесь к Подразделу 17.9.3.
31.18.3. Защита, обеспечиваемая в различных режимах
Разные значения параметра sslmode обеспечивают разные уровни защиты. SSL позволяет защититься от следующих типов атак:
Если третья сторона может прослушивать сетевой трафик между клиентом и сервером, она может получить как информацию соединения (включая имя пользователя и пароль), так и передаваемые данные. Чтобы защититься от этого, SSL шифрует трафик. Посредник (MITM )
Если третья сторона может представляться авторизованным клиентом, она может просто обращаться к данным, к которым не должна иметь доступа. Обычно это происходит вследствие небезопасного управления паролями. В SSL для предотвращения этой угрозы используются клиентские сертификаты, гарантирующие, что к серверу могут обращаться только владельцы действительных сертификатов.
Когда подлинность сервера подтверждена, клиент может передавать конфиденциальные данные. Это значит, что до этого момента клиенту не нужно знать, применяются ли сертификаты для аутентификации, так что настройка использования сертификатов только на стороне сервера не угрожает безопасности.
Таблица 31.1. Описания режимов SSL
31.18.4. Файлы, используемые клиентом SSL
В Таблице 31.2 перечислены файлы, имеющие отношение к настройке SSL на стороне клиента.
Таблица 31.2. Файлы, используемые клиентом SSL/libpq
/.postgresql/postgresql.crt
/.postgresql/postgresql.key
/.postgresql/root.crt
/.postgresql/root.crl
31.18.5. Инициализация библиотеки SSL
Позволяет приложениям выбрать, какие библиотеки безопасности нужно инициализировать.
Позволяет приложениям выбрать, какие библиотеки безопасности нужно инициализировать.
Pem server postgresql что это
Примечание
Если закрытый ключ защищён паролем, сервер запросит пароль и не запустится, пока этот пароль не будет введён.
Добавлять корневой сертификат в server.crt нет необходимости. Вместо этого клиенты должны иметь этот сертификат в цепочке сертификатов сервера.
18.9.1. Использование клиентских сертификатов
18.9.2. Файлы, используемые SSL-сервером
В Таблице 18.2 кратко описаны все файлы, имеющие отношение к настройке SSL на сервере. (Здесь приведены стандартные или типичные имена файлов. В конкретной системе они могут быть другими.)
Таблица 18.2. Файлы, используемые SSL-сервером
18.9.3. Создание сертификатов
Хотя самоподписанный сертификат может успешно применяться при тестировании, в производственной среде следует использовать сертификат, подписанный центром сертификации (ЦС ) (обычно это корневой ЦС предприятия).
Чтобы создать сертификат сервера, подлинность которого смогут проверять клиенты, сначала создайте запрос на получение сертификата (CSR ) и файлы открытого/закрытого ключа:
Наконец, создайте сертификат сервера, подписанный новым корневым центром сертификации:
server.crt и server.key должны быть сохранены на сервере, а root.crt — на клиенте, чтобы клиент мог убедиться в том, что конечный сертификат сервера подписан центром сертификации, которому он доверяет. Файл root.key следует хранить в изолированном месте для создания сертификатов в будущем.
Также возможно создать цепочку доверия, включающую промежуточные сертификаты: