Настройка разрешения для разделяемой памяти, созданной путем повышения
Мы открываем общую память, которая была создана другим процессом, подобным этому
boost::interprocess::managed_shared_memory segment(boost::interprocess::open_only, "SharedMem");
Но если процесс, создавший разделяемую память, был пользователем root, тогда процесс его чтения, если он был обычным пользователем, потерпит неудачу с причиной:
terminate called after throwing an instance of 'boost::interprocess::interprocess_exception'
what(): Permission denied
Что мне делать, чтобы этого избежать? то есть предоставить разрешению общей памяти всем?
Ответы
Ответ 1
Если вы посмотрите на конструктор shared_memory , он примет permissions объект. boost::interprocess::permissions::set_unrestricted
, вероятно, то, что вы ищете
void set_unrestricted();
//Sets permissions to unrestricted access:
// A null DACL for windows or 0666 for UNIX.
В соответствии с этим он был добавлен в версии 1.45