За да ограничите достъпа на PostgreSQL до конкретни таблици и колони, можете да използвате схема и селективни изрази GRANT.
Вижте следващите инструкции как да ограничите достъпа до определени таблици.
Въпреки това, ако трябва да ограничите достъпа до конкретни колони, може да се наложи да използвате комбинация от схеми и изгледи, за да ограничите достъпа. Можете също да направите това, ако вашата база данни има над 1000 таблици и се опитвате да се свържете с Chartio.
-
Свържете се с вашата PostgreSQL база данни с помощта на psql или pgadmin. Изпълнете следното, за да върнете списък с таблици във вашата база данни.
sudo -u postgres psql c име на база данни;
-
Създайте схема, специфична за потребителя само за четене на Chartio, изпълнете следното:
CREATE SCHEMA chartio_read_only; CREATE ROLE chartio_schema_user ПАРОЛА ЗА ВХОД ‘secure_password’; ПРЕДОСТАВЯ ВРЪЗКА ВЪРХУ БАЗА ДАННИ име на база данни НА chartio_schema_user; ПРЕДОСТАВЯТЕ ИЗПОЛЗВАНЕ НА СХЕМА chartio_read_only НА chartio_schema_user;
-
Разгледайте връзките на базата данни с помощта на командата d.
г
Схема | Име | Въведете | Собственик ———-+—————————+———-+————— публичен | Сметки | таблица | postgres public | Посетители | таблица | postgres public | Потребители | таблица | postgres public | Абонаменти | таблица | postgres
-
Вашата таблица с акаунти съдържа чувствителна информация и искате Chartio да има достъп само до колоните Account_ID и Date__Created ._ Изпълнете следното, за да добавите изглед към схемата chartio_read_only и да предоставите достъп до този изглед на chartio_schema_user.
CREATE VIEW chartio_read_only.”Accounts” КАТО SELECT Account_ID, Date_Created FROM Accounts; GRANT SELECT ON chartio_read_only.”Accounts” НА chartio_schema_user;
-
Предоставете разрешения за избор на всички данни от таблицата с посетителите.
CREATE VIEW chartio_read_only.”Visitors” КАТО ИЗБЕРЕТЕ * ОТ Посетители; ПРЕДОСТАВЯ ИЗБОР НА chartio_read_only.”Visitors” НА chartio_schema_user;
Сега, ако свържете chartio_schema_user към вашата база данни, той ще има достъп само до двата ограничени изгледа, които сте предоставили на схемата.
За повече информация вижте документацията на PostgreSQL.