Dwa programy setuid /usr/bin/bari /usr/bin/bazwspółdzielą jeden plik konfiguracyjny foo. Trybem pliku konfiguracyjnego jest 0640przechowywanie poufnych informacji. Biegnie jeden program, jak bar:bar(to jest, jak dla pręta, grupa bar ); drugi jak baz:baz. Zmiana użytkowników nie jest opcją, a nawet zmiana grup nie byłaby lepsza.
Chcę na stałe połączyć pojedynczy plik konfiguracyjny jako /etc/bar/fooi /etc/baz/foo. Nie udaje się to jednak, ponieważ plik, o ile wiem, musi należeć do root:barlub do root:baz.
Potencjalne rozwiązanie: Utwórz nową grupę, barbazktórej członkami są bari baz. Niech foonależy do root:barbaz.
To dla mnie wygląda na ciężkie rozwiązanie. Czy nie ma prostszego, prostszego sposobu udostępniania pliku konfiguracyjnego foomiędzy dwoma programami?
Na razie utrzymuję dwie identyczne kopie pliku. To działa, ale jest oczywiście błędne. Co by było właściwe?
Dla informacji: Mam niewielkie doświadczenie z grupami Unixowymi i żadną z setgid (2).
ssl-certgrupa, która jest właściwie twoją barbazgrupą. Standardem jest ustawienie wszystkich kluczy prywatnych, które mają być własnością ssl-certgrupy, i umieszczenie identyfikatorów UID powiązanych z programami, które muszą uzyskać do nich dostęp, w tej grupie.
ssl-certktórego skrypt postinst podczas instalacji tworzy grupę, o której mówisz. Nie byłem tego świadomy ssl-cert. Apache2 (zainstalowany na moim hoście) zaleca ssl-cert . Różne pakiety Exim i Dovecot nie, ale Postfix (nie zainstalowany na moim hoście) zależy od ssl-cert. Ze względu na Apache mój host ma grupę ssl-cert , ale ta grupa nie ma jeszcze członków. Dzięki za radę.