Josef Průša představil novou velkoformátovou uzavřenou CoreXY 3D tiskárnu Prusa CORE One L a nový open source standard chytrých cívek OpenPrintTag i s novou přepracovanou špulkou.
Na GOG.com běží Autumn Sale. Při té příležitosti je zdarma hororová počítačová hra STASIS (ProtonDB: Platinum).
Ubuntu 25.10 má nově balíčky sestavené také pro úroveň mikroarchitektury x86-64-v3 (amd64v3).
Byla vydána verze 1.91.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Ministerstvo průmyslu a obchodu vyhlásilo druhou veřejnou soutěž v programu TWIST, který podporuje výzkum, vývoj a využití umělé inteligence v podnikání. Firmy mohou získat až 30 milionů korun na jeden projekt zaměřený na nové produkty či inovaci podnikových procesů. Návrhy projektů lze podávat od 31. října do 17. prosince 2025. Celková alokace výzvy činí 800 milionů korun.
Google v srpnu oznámil, že na „certifikovaných“ zařízeních s Androidem omezí instalaci aplikací (včetně „sideloadingu“) tak, že bude vyžadovat, aby aplikace byly podepsány centrálně registrovanými vývojáři s ověřenou identitou. Iniciativa Keep Android Open se to snaží zvrátit. Podepsat lze otevřený dopis adresovaný Googlu nebo petici na Change.org.
Byla vydána nová verze 18 integrovaného vývojového prostředí (IDE) Qt Creator. S podporou Development Containers. Podrobný přehled novinek v changelogu.
Cursor (Wikipedie) od společnosti Anysphere byl vydán ve verzi 2.0. Jedná se o multiplatformní proprietární editor kódů s podporou AI (vibe coding).
Google Chrome 142 byl prohlášen za stabilní. Nejnovější stabilní verze 142.0.7444.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 20 bezpečnostních chyb. Za nejvážnější z nich bylo vyplaceno 50 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.
Pro moddery Minecraftu: Java edice Minecraftu bude bez obfuskace.
Zdravím,
chtěl bych se zeptat jestli by mě někdo neporadil jak udělat aby se aplikace spustila pod předem nastaveném PID ... mám administraci serverů pro gta samp.. a potřebuji nějak udělat zapínání a vypínání serverů a napadlo mě na to použít v php příkaz system("PRIKAZ"); ,ale nevim jak predem nastavit ten PID .. a nebo alespon jak v PHP zjistit jakej PID ten spustenej program má.
Předem děkuji. Michael Fanta
Tohle se řeší tak, že server (nebo skript, který ho startuje) při startu uloží do souboru své PID (v linuxu se k tomu běžně používá adresář /var/run/) a ty si pak z toho souboru načteš PID a můžeš zasílat signály.
Jo takle.. a neporadil byste trošku blíže? Přece jenom já dělám s linuxem teprve chvilku. Třeba kdybyste byl tak hodnej a nějakej příklad uvedl. Byl bych moc vděčný. Určitě nejsem jediný, ale věci lépe chápu spříkladu.
PID procesu sa dá zistiť shell príkazom pidof, kde ako parameter ide názov príkazu. Napríklad:
araxon@lighthouse ~ $ pidof firefox-bin
6217
To sa potom dá vložiť do iného príkazu cez operátor `:
araxon@lighthouse ~ $ kill -15 `pidof firefox-bin`
V php potom cez shell_exec takto: shell_exec("kill -15 `pidof firefox-bin`");
Takže jestli to chápu dobře tak to firefox-bin je nazev toho PID ?
No dejme tomu že mám aplikaci samp_7777 a chci kni dat PID 7777 to udělám jak?
zkoušel sem to i takto:
./samp_7777 -PID=777
ale nic
a co pro start třeba nějak takto
/sbin/start-stop-daemon --start -m -p ./samp.pid -b -x samp_7777
a pro kill pak takto
/sbin/start-stop-daemon --stop -p ./samp.pid
PID si nevyberáš, ten Ti pridelí operačný systém. firefox-bin bol názov programu, ktorého PID som chcel zistiť, a napísal som ho len pre ukážku. Ak taký program u Teba nie je spustený tak pidof nevráti nič.
Tak jinak.. udělal jsem to teda takto:
$pid = shell_exec("pidof samp_7779");
$akce = "kill ".$pid;
echo "PID (".$pid.") - Akce (".$akce.")";
shell_exec($akce);
echo "<p><font color='#008000'>Server vypnut...</font></p>";
Ale nic se neprovede.. nevíte proč? To by mě fakt zajímalo teda proč? :(
A ten program samp_7779 beží pod tým istým užívateľom ako webserver? Zistilo to ten PID? Čo to vypísalo?
Ano .. šak tam mám to echo kde se vypisuje ten PID kterej to zjistí... a pak teprve zadává KILL
Jinak vypsalo se to přesně takto
PID (9667 ) - Akce (kill 9667 )
Jedine co me napada ze to co chces stopnout bezi pod jinym uzivatelem (root nebo neco jineho) nez je apache a tudiz ten kill dat nemuzes.
Kdyz spustis ten kill rucne pod uzivatelem apache (www-data nebo nejaky jiny pouzivany) tak to zabije?
přes ssh ho to zabije... ale když dám top tak je tam user root a apache to samý
Ach jo ted na to kooukám.... apache běží přes usera nobody :(
515 nobody 15 0 27532 16m 5476 S 0 3.3 0:04.62 httpd
Dal sem si tam
echo shell_exec("groups")."<br>";
echo shell_exec("whoami")."<br>";
a vyplsalo mi to:
nogroup
nobody
tak jde nejak spustit ty servery pod temito udaji?
Vyřešeno.. použil jsem
su nobody -c ./samp_7777
ale ještě bych potřeboval jestli by mě někdo neporadil jak by měl vypadat script co by tohle zadaval.. např ... start.sh
a tam aby se provedlo
su nobody -c ./samp_7777
Takže mám tento script: start_7777.sh
#!/bin/bash
cd /root/servery/7777
su nobody -c ./samp_7777 &
a pouštím ho pomocí
shell_exec("./start_7777.sh");
nevíte pls někdo proč to nejde takto spustit? :)
Má ten skript práva pro spuštění (chmod +x start_7777.sh)?
BTW. proč to nejde takto spustit bys nám spíš měl říct ty podle nějaké chybové hlášky nebo výpisu z logu :)
A proč tam máš vlastně to su nobody, když to spouštíš z PHP pod Apache a Apache už pod nobody běží, jak píšeš výše?
Nejak jsem nepochopil proc potrebujete spoustenemu procesu prirazovat konkretni PID, navic si myslim (mozna se pletu) ze PID prirazuje samo jadro podle toho jak se jednotlive procesy spousteji a vy ho neovlivnite, max. ho muzete zjistit ...
Asi spise hledate UID (user ID) nebo GID (group ID) a ne PID (proces ID)
Tohle už je vyřešeno :)
Teďka se snažím příjít na tuhle chybu:
když kliknu na start serveru tak mě to server spustí ale apache čeká dokud se server nevypne.. až server vypne tak apache pokračuje v akci. :(
Ten server by se měl nějak daemonizovat. Měl by to umět sám - tato vlastnost se obecně od serverů celkem očekává
Takže se zkus podívat po nějakém přepínači v příkazové řádce. Nebo si můžeš pomoci nějakým trikem - např. nohup (nevím jestli bude fungovat), nebo teď mě napadá konstrukce typu "(su nobody -c ./samp_7777 &)".
Vyřešeno .. díky Messa :)
Nakonec stačilo jen přesměrovat standardní a chybový výstup do /dev/null a spustit skript na pozadí:
<?php
system("./skript.sh 2>/dev/null >/dev/null &");
?>
Nejpravděpodobnější vysvětlení - výstupy jsou napojeny na rouru, kterou čte PHP (jak jinak) a PHP považuje příkaz za dokončení evidentně zavřením této roury. Samozřejmě je nutné, aby se proces se shellem ukončil, proto ten ampersand.
Tiskni
Sdílej: