abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 12:55 | Nová verze

    CiviCRM (Wikipedie) bylo vydáno v nové verzi 6.14.0. Podrobnosti o nových funkcích a opravách najdete na release stránce. CiviCRM je robustní open-source CRM systém navržený speciálně pro neziskové organizace, spolky a občanské iniciativy. Projekt je napsán v jazyce PHP a licencován pod GNU Affero General Public License (AGPLv3). Český překlad má nyní 45 % přeložených řetězců a přibližuje se milníku 50 %. Potřebujeme vaši pomoc, abychom se dostali dál. Pokud máte chuť přispět překladem nebo korekturou, přidejte se na platformu Transifex.

    jardaIT | Komentářů: 1
    včera 12:22 | Bezpečnostní upozornění

    Další lokální zranitelností Linuxu je ssh-keysign-pwn. Uživatel si může přečíst obsah souborů, ke kterým má právo ke čtení pouze root, například soubory s SSH klíči nebo /etc/shadow. V upstreamu již opraveno [oss-security mailing list].

    Ladislav Hagara | Komentářů: 0
    14.5. 17:22 | Komunita

    Singularity (YouTube) je nejnovější otevřený film od Blender Studia. Jedná se o jejich první 4K HDR film.

    Ladislav Hagara | Komentářů: 0
    14.5. 16:55 | Zajímavý software

    Vyšla hra Život Není Krásný: Poslední Exekuce (Steam, ProtonDB). Kreslená point & click adventura ze staré školy plná černého humoru a nekorektního násilí. Vžijte se do role zpustlého exekutora Vladimíra Brehowského a projděte s ním jeho poslední pracovní den. Hra volně navazuje na sérii Život Není Krásný.

    Ladislav Hagara | Komentářů: 23
    14.5. 14:00 | Zajímavý projekt

    Společnost Red Hat představila Fedora Hummingbird, tj. linuxovou distribuci s nativním kontejnerovým designem určenou pro vývojáře využívající AI agenty.

    Pinhead | Komentářů: 6
    14.5. 02:22 | Zajímavý software

    Hru The Legend of Zelda: Twilight Princess od společnosti Nintendo si lze nově díky projektu Dusklight (původně Dusk) a reverznímu inženýrství zahrát i na počítačích a mobilních zařízeních. Vyžadována je kopie původní hry (textury, modely, hudba, zvukové efekty, …). Ukázka na YouTube. Projekt byl zahájen v srpnu 2020.

    Ladislav Hagara | Komentářů: 0
    14.5. 01:11 | Nová verze

    Byla vydána nová major verze 29.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Detailní přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 0
    13.5. 21:22 | Bezpečnostní upozornění

    Po zranitelnostech Copy Fail a Dirty Frag přichází zranitelnost Fragnesia. Další lokální eskalace práv na Linuxu. Zatím v upstreamu neopravena. Přiřazeno ji bylo CVE-2026-46300.

    Ladislav Hagara | Komentářů: 1
    13.5. 14:00 | Komunita

    Sovereign Tech Agency (Wikipedie) prostřednictvím svého fondu Sovereign Tech Fund podpoří KDE částkou 1 285 200 eur.

    Ladislav Hagara | Komentářů: 12
    13.5. 12:55 | IT novinky

    Google na včerejší akci The Android Show | I/O Edition 2026 (YouTube) představil celou řadu novinek: Gemini Intelligence, notebooky Googlebook, novou generaci Android Auto, …

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (13%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1633 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: start Apache a Mysql pomocí skriptu a sudoers

    17.8.2018 08:21 Pavel
    start Apache a Mysql pomocí skriptu a sudoers
    Přečteno: 437×
    Apache a MySQL si na localu startuji ručně. Chtěl bych to dělat ne v konzoli, ale pomocí skriptu. Vytvořil jsem soubor start.sh s obsahem:

    /bin/systemctl start mysqld.service

    /usr/sbin/apachectl start

    Funguje to, ale musím pro každý příkaz zadávat heslo správce.

    Chtěl bych využít Sudoers, ale neumím s tím pracovat. Našel jsem soubor /etc/sudoers, sudoers.dist a adresář sudoers.d Jméno přihlášeného uživatele je p, do souboru /etc/sudoers jsem tedy napsal:

    User_Alias PADMIN = p

    Cmnd_Alias STARTAPACHE = apachectl start

    Cmnd_Alias STARTMYSQL = systemctl start mysqld.service

    PADMIN ALL = NOPASSWD: STARTAPACHE

    PADMIN ALL = NOPASSWD: STARTMYSQL

    Po spuštění mého souboru start.sh ale pořád dialog vyžaduje 2x heslo. Co je špatně? Díky za rady.

    Řešení dotazu:


    Odpovědi

    17.8.2018 09:00 ping-pong
    Rozbalit Rozbalit vše Re: start Apache a Mysql pomocí skriptu a sudoers
    Pouzi setuid. Umozni spustat program pod inymi prava ako ten co ich spustat. Napr. program na spravu hesiel sa pusta pod pravami rootra, aby mohlo menit subor /etc/passwd, ktoreho vlastnikom je root. Ale ten program passwd moze spustit hocijaky uzivatel.

    Techn. poznamka: Setuid bit sa da nastavit len pre programy, nie skripty. Takze si budes musiet vytvorit pomocny program, ktory bude setuid a on bude volat skript.

    Nech:
    /opt/my_at_start                    # priecinok, kde je ulozeny program pri starte
    /opt/my_at_start/program_at_start   # program, kt. sa bude spustat s pravami root
    /opt/my_at_start/program_at_start.c # program v c
    /opt/my_at_start/my_start_script.sh # skript v (ba)sh, ktory spustas
    
    Potom:

    obsah program_at_start.c
    #include <stdib.h>
    #include <unistd.h>
    
    int main(int argc, char **argv)
    {
        setuid(0);   // you can set it at run time also
        system("/opt/my_at_start/my_start_script.sh");
        return 0;
    }
    
    preklad program z c
    gcc /opt/my_at_start/program_at_start.c -o /opt/my_at_start/program_at_start
    nastavenei prav na setuid (ako root)
    chmod 1000 /opt/my_at_start/program_at_start
    chmod +s /opt/my_at_start/program_at_start
    
    obsah skripty
    # u mna dmesg moze spustat iba root, tak som napr. nim to testoval
    dmesg
    
    Spustenie skriptu ako bezny uzivatel s pravami root
    $ /opt/my_at_start/program_at_start 
    Podklady, skompletizovane, upravene a odskusane z unix.stackexchange.com.
    Řešení 1× (Filip Jirsák)
    Max avatar 17.8.2018 09:22 Max | skóre: 73 | blog: Max_Devaine
    Rozbalit Rozbalit vše Re: start Apache a Mysql pomocí skriptu a sudoers
    To je bohužel nedobrá rada. Autor požaduje spustit pod specifickým uživatelem něco jako root. Ty mu radíš, aby si zkompiloval jednoduchý program, který bude spouštět ten skript a aby si na něm nastavil set uid bit. Jenomže tím docílíš toho, že každý uživatel v systému bude mít práva pro spuštění toho souboru, bude tedy moci ovládat mysql a apache. Leda by si ty práva na tom souboru pohlídal a v budoucnu se nespletl/omylem nezměnil atd.
    Ale proč to dělat, když stačí jeden řádek v sudoers?
    Tvá rada se spíš hodí pro automatizaci, kdy něco stavím a chci něco automaticky spouštět (dřív jsem to tak měl na jednom terminále, dnes nevím, zda bych to ještě použil, možností je dnes mnohem více, než v minulosti).

    Jinak tam máš chybu, nemá být "<stdib.h>", ale "<stdlib.h>"
    Zdar Max
    Měl jsem sen ... :(
    17.8.2018 09:40 ping-pong
    Rozbalit Rozbalit vše Re: start Apache a Mysql pomocí skriptu a sudoers
    true all
    Řešení 1× (Filip Jirsák)
    Max avatar 17.8.2018 09:01 Max | skóre: 73 | blog: Max_Devaine
    Rozbalit Rozbalit vše Re: start Apache a Mysql pomocí skriptu a sudoers
    Přidáš do sudo :
    sudoedit /etc/sudoers.d/p-user
    p ALL = (ALL) NOPASSWD: /usr/local/bin/my_start.sh
    
    A pak zavoláš z uživatele "p"
    sudo /usr/local/bin/my_start.sh
    
    Nebo :
    sudoedit /etc/sudoers.d/p-user
    p ALL=NOPASSWD: /bin/systemctl start mysqld.service
    p ALL=NOPASSWD: /bin/systemctl stop mysqld.service
    p ALL=NOPASSWD: /usr/sbin/apachectl start
    p ALL=NOPASSWD: /usr/sbin/apachectl stop
    
    A pak zavoláš z uživatele "p"
    sudo /bin/systemctl start mysqld.service
    ...
    
    Zdar Max
    Měl jsem sen ... :(
    17.8.2018 10:09 funguje to!
    Rozbalit Rozbalit vše Re: start Apache a Mysql pomocí skriptu a sudoers
    Max: Funguje to! Díky. Na sudo /bin/systemctl start mysqld.service jsem si vytvořil na ploše ještě soubor start.sh a ten spouštím myší. Jen se mi při jeho startu ukazuje okno, které píše:

    Chcete spustit "start.sh" nebo zobrazit jeho obsah?
    "start.sh" je spustitelný textový soubor.

    A tlačítka nabízí: Spustit v terminálu, Zobrazit, Zrušit a Spustit.

    Je možné nastavit, aby se start.sh spustil bez tohoto dialogu?

    Díky. Pavel
    Max avatar 17.8.2018 10:18 Max | skóre: 73 | blog: Max_Devaine
    Rozbalit Rozbalit vše Re: start Apache a Mysql pomocí skriptu a sudoers
    To je věc grafického prostředí, takže to se nastavuje v rámci něj. Napiš co používáš a někdo ti snad poradí.
    Zdar Max
    Měl jsem sen ... :(
    Max avatar 17.8.2018 10:19 Max | skóre: 73 | blog: Max_Devaine
    Rozbalit Rozbalit vše Re: start Apache a Mysql pomocí skriptu a sudoers
    Sice nevím, co používáš za DE, ale možná by bylo lepší místo umístění bash souboru na plochu, vytvořit pro ten skript zástupce, kde právě lze zadat, jak se má spouštět.
    Zdar Max
    Měl jsem sen ... :(
    17.8.2018 14:41 Pavel
    Rozbalit Rozbalit vše Re: start Apache a Mysql pomocí skriptu a sudoers
    ... Tak tohle je pro mě jako cizí řečí :-) Co je to DE? Jak vytvořím zástupce pro skript? Díky předem za radu.
    17.8.2018 14:49 Pavel
    Rozbalit Rozbalit vše Re: start Apache a Mysql pomocí skriptu a sudoers
    Už to mám. Klik pravým tlačítkem na plochu - Vytvořit spouštěč -
    Název: Start

    Příkaz: sudo /usr/local/bin/my_start.sh

    A funguje to. Díky.
    17.8.2018 14:38 Pavel
    Rozbalit Rozbalit vše můj systém a prostředí
    Jedu v Mageia 6 a používám MATE jago grafické prostředí.
    17.8.2018 14:48 ping-pong
    Rozbalit Rozbalit vše Re: start Apache a Mysql pomocí skriptu a sudoers
    Vytvor program co Ti spusta skript a daj si ho na plochu. :)

    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.