170 похожих чатов

Привет ребят. Есть один сайт на котором хочу дать пользователям

загружать свои плагины на Python, они будут выполняться и возвращать ответ. Но как защитить от всяких вредных действий вроде запуска команд на сервере, или ещё чего из скрипта? Может есть какой то ключ для «безопасного» выполнения питоновского скрипта?

В изолированных контейнерах это наверно не получится выполнять в силу потенциально большого количества скриптов и частого их использования.

Но как вариант можно синтаксически анализировать загруженный скрипт предварительно, на подключение запрещённых библиотек например, можете тогда подсказать какие стоит запретить?
😀спасибо тем кто дочитал.

10 ответов

19 просмотров

Почему не получится в контейнерах?

Михаил- Автор вопроса
Tishka17
Почему не получится в контейнерах?

Мне кажется при частоте выполнения этих скриптов хотя бы 10 раз в секунду, каждый раз инициировать контейнер накладно по ресурсам будет

Михаил
Мне кажется при частоте выполнения этих скриптов х...

Заведи юзерам по контейнеру и пусть он долго у каждого работает

Михаил- Автор вопроса
Tishka17
Заведи юзерам по контейнеру и пусть он долго у каж...

Ну как вариант если конкретно под каждый скрипт контейнер запускать, поскольку как раз одним скриптом может много юзеров пользоваться, но опять же пока хочется ресурсы экономней использовать попробовать ибо их не так много)

Михаил
Ну как вариант если конкретно под каждый скрипт ко...

А юзеры ещё и друг с другом будут делиться?

Михаил- Автор вопроса
Tishka17
А юзеры ещё и друг с другом будут делиться?

Решил в общем все таки в контейнере запускать выполнение каждого скрипта, а то много уязвимостей) потестил в принципе с запуском и уничтожением контейнера быстро все происходит. А потом если скрипт пользователя востребован будет, то после код ревью, для эффективности выносить в рабочее пространство

Похожие вопросы

Обсуждают сегодня

Какой-то там пердун в 90-х решил, что есть какая-то разная типизация. Кого вообще это волнует?
КТ315
49
void terminal_scroll() { memmove(terminal_buffer, terminal_buffer + VGA_WIDTH, buffer_size - VGA_WIDTH); memset(terminal_buffer + buffer_size - VGA_WIDTH, 0, VGA_WIDTH); ...
Егор
47
Всем привет! Подскажите, пожалуйста, в чем ошибка? Настраиваю подключение к MySQL. Либы лежат рядом с exe. Все как по "учебнику"
Евгений
16
А можете как-то проверить меня по знаниям по ассемблеру?
A A
132
Здравствуйте! У меня появилась возможность купить книгу "Изучай Haskell во имя добра!". Но я где-то слышал, что эта книга устарела. Насколько это правда??
E
22
Здравствуйте! Я вот на stepic решаю задачи на хаскеле https://stepik.org/lesson/8443/step/8?unit=1578 мой код import Data.List (isInfixOf) removing :: String -> [String] ->...
E
10
Камрады, кто тесно работал с vtv, хотел уточнить. Ширина column задаётся жёстко на этапе создания дерева или можно в рантайме ее менять программно (не мышкой)?
Ed Doc
10
да ладно ... что там неочевидного ? глянуть в исх-ки датасета и/или кверика чтобы понять в каком месте и как выполняется обращения к св-вам blablaSQL - минутное дело, даже е...
Сергей
7
Здесь для arm кто-нибудь кодит ?
Nothing
52
Всем привет, у меня есть сервер принимающий входящие HTTP подключения, как проверить, что подключение было через прокси или нет, есть какие то поля в заголовках по которым мо...
DS
8
Карта сайта