abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 18:55 | IT novinky

    Dnešním dnem lze již také v Česku nakupovat na Google Store (telefony a sluchátka Google Pixel).

    Ladislav Hagara | Komentářů: 7
    včera 18:33 | IT novinky

    Apple představil (keynote) iPad Pro s čipem Apple M4, předělaný iPad Air ve dvou velikostech a nový Apple Pencil Pro.

    Ladislav Hagara | Komentářů: 1
    včera 17:11 | Nová verze

    Richard Biener oznámil vydání verze 14.1 (14.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 14. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.

    Ladislav Hagara | Komentářů: 0
    včera 13:44 | Komunita

    Free Software Foundation zveřejnila ocenění Free Software Awards za rok 2023. Vybráni byli Bruno Haible za dlouhodobé příspěvky a správu knihovny Gnulib, nováček Nick Logozzo za front-end Parabolic pro yt-dlp a tým Mission logiciels libres francouzského státu za nasazování svobodného softwaru do praxe.

    Fluttershy, yay! | Komentářů: 0
    včera 13:11 | IT novinky

    Před 10 lety Microsoft dokončil akvizici divize mobilních telefonů společnosti Nokia a pod značkou Microsoft Mobile ji zanedlouho pohřbil.

    Ladislav Hagara | Komentářů: 2
    6.5. 21:33 | Komunita

    Fedora 40 release party v Praze proběhne v pátek 17. května od 18:30 v prostorách společnosti Etnetera Core na adrese Jankovcova 1037/49, Praha 7. Součástí bude program kratších přednášek o novinkách ve Fedoře.

    Ladislav Hagara | Komentářů: 5
    6.5. 21:11 | IT novinky

    Stack Overflow se dohodl s OpenAI o zpřístupnění obsahu Stack Overflow pro vylepšení OpenAI AI modelů.

    Ladislav Hagara | Komentářů: 1
    6.5. 17:55 | Nová verze

    AlmaLinux byl vydán v nové stabilní verzi 9.4 (Mastodon, 𝕏). S kódovým názvem Seafoam Ocelot. Přehled novinek v příspěvku na blogu a v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    6.5. 17:11 | IT novinky

    Před 50 lety, 5. května 1974 v žurnálu IEEE Transactions on Communications, Vint Cerf a Bob Kahn popsali protokol TCP (pdf).

    Ladislav Hagara | Komentářů: 0
    6.5. 13:44 | Zajímavý článek

    Bylo vydáno do češtiny přeložené číslo 717 týdeníku WeeklyOSM přinášející zprávy ze světa OpenStreetMap.

    Ladislav Hagara | Komentářů: 0
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (64%)
     (7%)
     (13%)
     (16%)
    Celkem 138 hlasů
     Komentářů: 9, poslední včera 22:07
    Rozcestník

    Dotaz: Základy sdílení souborů

    6.1.2018 18:24 Milan | skóre: 1
    Základy sdílení souborů
    Přečteno: 1266×
    Zdravím. Mám dotaz ohledně sdílení souborů mezi dvěma uživateli v systému Debian. V podstatě mi to sdílení funguje, ale když jeden uživatel ve sdílené složce založí nový soubor, tak mu musí ještě ručně nastavit přístupová práva a skupinu, jinak druhý uživatel ten soubor nemůže otevřít.

    Chci se zeptat, jestli je možné, aby se při vytváření souborů ty práva a skupiny nastavovaly automaticky?

    Tady je kompletní postup sdílení, jak jsem ho dal dohromady:

    ========================

    Vytvořím 2 obyčejné uživatele "pepa" a "lojza":

    adduser pepa

    adduser lojza

    Vytvořím skupinu "sdileni":

    groupadd sdileni

    a oba uživatele do té skupiny přiřadím:

    usermod -G sdileni pepa

    usermod -G sdileni lojza

    Pro informaci si ověřím, že tu skupinu mají oba nastavenou:

    id pepa

    uid=1001(pepa) gid=1002(pepa) groups=1002(pepa),1004(sdileni)
    id lojza

    uid=1002(lojza) gid=1005(lojza) groups=1005(lojza),1004(sdileni)
    V Pepově adresáři vytvořím složku a v ní první pokusný soubor:

    mkdir /home/pepa/sdilenaslozka

    nano /home/pepa/sdilenaslozka/soubor.txt

    Protože všechno dělám jako root, nastavím téhle složce vlastnictví pro Pepu a skupinu na "sdileni"

    chown -R pepa /home/pepa/sdilenaslozka/

    chgrp -R sdileni /home/pepa/sdilenaslozka/

    A ještě nastavím celé složce maximální přístupová práva pro skupinu a vlastníka (ostatní uživatelé jsou bez práva)

    chmod -R 770 /home/pepa/sdilenaslozka

    Pro informaci detailní výpis:

    cd /home/pepa/

    ls -hasl1
    4.0K drwxrwx--- 2 pepa sdileni 4.0K Jan 6 16:29 sdilenaslozka
    A teď chci, aby i Lojza měl přístup k té sdílené složce a všemu co se v ní nachází. Proto mu do jeho home adresáře tu sdílenou složku přilinkuji:

    ln -s /home/pepa/sdilenaslozka/ /home/lojza/

    Když se přihlásím jako "lojza", tak všechno funguje jak má, můžu ve sdílené složce provádět s existujícími soubory libovolnou činnost. Stejně tak, když se přihlásím jako "pepa", tak také mohu ve sdílené složce s existujícími soubory dělat co chci.

    Problém je ale s novými soubory, které může upravovat a číst jen autor. To se dá ale vyřešit tím, že se po uložení souboru provede změna práv a změna skupiny toho vytvořeného souboru.

    Například když Lojza vytvoří nový soubor:

    nano /home/lojza/sdilenaslozka/prispevek_od_lojzy.txt

    tak má soubor nastaveny tyto atributy:

    4.0K -rw-r--r-- 1 lojza lojza 6 Jan 6 17:08 prispevek_od_lojzy.txt
    Takže se musí ještě nastavit:

    chmod 770 /home/lojza/sdilenaslozka/prispevek_od_lojzy.txt

    chgrp sdileni /home/lojza/sdilenaslozka/prispevek_od_lojzy.txt

    protože jinak by ten soubor Pepa neotevřel.


    Řešení dotazu:


    Odpovědi

    Řešení 1× (Milan (tazatel))
    6.1.2018 18:41 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Základy sdílení souborů
    Nastavte tomu sdílenému adresáři sgid bit a jako vlastníka tu sdílenou skupinu. Nově vytvářené soubory v tomto adresáři pak nebudou mít skupinu uživatele, který soubor vytvořil, ale převezmou ji z toho nadřazeného adresáře.
    6.1.2018 19:03 Milan | skóre: 1
    Rozbalit Rozbalit vše Re: Základy sdílení souborů
    Nevím, jestli jsem to našel správně.

    Zkusil jsem příkaz:

    chmod g+s /home/pepa/sdilenaslozka/

    Složka "sdilenaslozka" má pak tyto atributy:
    4.0K drwxrws--- 2 pepa sdileni 4.0K Jan 6 18:53 sdilenaslozka
    U nově vytvořených souborů se nastaví automaticky skupina na "sdileni", ale práva souboru zůstávají pořád nedostatečná:
    4.0K -rw-r--r-- 1 pepa sdileni 11 Jan 6 18:53 vytvoril_pepa.txt
    6.1.2018 19:25 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Základy sdílení souborů
    Výchozí práva souborů nastavuje umask – nastavuje se tam, které bity se mají při vytváření souboru odebrat. V /etc/profile si to můžete přenastavit na hodnotu 002, která odebírá právo zápisu jen ostatním. Nyní zřejmě máte nastaveno 022, které odebírá práva zápisu ostatním i skupině.
    6.1.2018 19:46 Milan | skóre: 1
    Rozbalit Rozbalit vše Re: Základy sdílení souborů
    Díky za snahu, ale tohle už asi nedám. Obsah souboru /etc/profile:
    # /etc/profile: system-wide .profile file for the Bourne shell (sh(1))
    # and Bourne compatible shells (bash(1), ksh(1), ash(1), ...).
    
    if [ "`id -u`" -eq 0 ]; then
      PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin"
    else
      PATH="/usr/local/bin:/usr/bin:/bin:/usr/local/games:/usr/games"
    fi
    export PATH
    
    if [ "$PS1" ]; then
      if [ "$BASH" ] && [ "$BASH" != "/bin/sh" ]; then
        # The file bash.bashrc already sets the default PS1.
        # PS1='\h:\w\$ '
        if [ -f /etc/bash.bashrc ]; then
          . /etc/bash.bashrc
        fi
      else
        if [ "`id -u`" -eq 0 ]; then
          PS1='# '
        else
          PS1='$ '
        fi
      fi
    fi
    
    if [ -d /etc/profile.d ]; then
      for i in /etc/profile.d/*.sh; do
        if [ -r $i ]; then
          . $i
        fi
      done
      unset i
    fi
    
    
    
    
    Řešení 1× (Milan (tazatel))
    6.1.2018 20:02 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Základy sdílení souborů
    /etc/profile je normální shell skript, který se spouští každému uživateli po každé, když spustí shell. Můžete si do něj (např. na konec) přidat spuštění příkazu, v tomto případě umask 002. Případně ten skript spouští všechny soubory s příponou sh v adresáři /etc/profile.d/. Takže bych si vytvořil soubor /etc/profile.d/umask.ss a do něj zadal jen
    umask 002
    
    6.1.2018 20:02 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Základy sdílení souborů
    Pardon, překlep, ten soubor se má jmenovat /etc/profile.d/umask.sh.
    6.1.2018 20:10 Milan | skóre: 1
    Rozbalit Rozbalit vše Re: Základy sdílení souborů
    DÍKY MOC.

    Už to běží.
    7.1.2018 08:40 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Základy sdílení souborů

    Řešit sdílení přes skupiny má určitá úskalí.

    Například umask, ke které jste se se dopracovali, se uplatní na všechny vytvářené soubory. Nejen na ty, které budou ve sdíleném adresáři. Je pravda, že současné distribuce právě z tohoto důvodu dávají uživatelům jedinečnou primární skupinu, ale i tak je dobré na to myslet.

    Je-li uživatel jednou členem skupiny a není-li souborovým systémem zakázána interpretace SGID bitu, je nemožné uživatele ze skupiny vyloučit, protože uživatel si před odebráním členství může vytvořit SGID program a ten po odebrání členství použít k neoprávněnému získání členství.

    Jako lepší řešení lze použít ACL. Namísto SGID bitu sdíleným adresářům se nastaví default ACL, které se pak používá na nově vytvářené soubory. Rovněž je možné přidat přístup konkrétním uživatelům namísto přidání skupiny a uživatelů do skupiny.

    7.1.2018 18:30 jherne
    Rozbalit Rozbalit vše Re: Základy sdílení souborů

    "Rovněž je možné přidat přístup konkrétním uživatelům namísto přidání skupiny a uživatelů do skupiny"

    Můžeš to rozvést? Zajímá mě to, díky.
    7.1.2018 20:51 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Základy sdílení souborů

    Příklad:

    petr@album:/tmp $ echo text >/tmp/soubor
    petr@album:/tmp $ chmod 0400 /tmp/soubor
    root@album:/usr/src/linux-4.14.12 # su -c 'cat /tmp/soubor' blb
    cat: /tmp/soubor: Operace zamítnuta
    petr@album:/tmp $ setfacl -m u:blb:r /tmp/soubor 
    root@album:/usr/src/linux-4.14.12 # su -c 'cat /tmp/soubor' blb
    text
    petr@album:/tmp $ getfacl /tmp/soubor 
    getfacl: Removing leading '/' from absolute path names
    # file: tmp/soubor
    # owner: petr
    # group: users
    user::r--
    user:blb:r--
    group::---
    mask::r--
    other::---

    Přečti si acl(5), nástroje se jmenují setfacl(1) a getfacl(1). Případně si do vyhledávače zadej „POSIX Access Control List“.

    7.1.2018 21:46 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Základy sdílení souborů
    Klasická unixová práva nastavujete vlastníkovi souboru, skupině a ostatním. ACL umožňují nastavit práva (opět rwx) i dalším uživatelům a skupinám, ne jenom vlastníkovi.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.