NOVINKA! E-learningové kurzy umělé inteligence. Nyní AI za nejlepší ceny. Zjisti více:
NOVINKA – Víkendový online kurz Software tester, který tě posune dál. Zjisti, jak na to!
Avatar
Adam Ondrejkovič:5.7.2017 20:32

Dobrý deň,

mám naprogramovanú webovú aplikáciu v Laraveli (CMSko pre webové stránky(PHP s databázou MariaDB 10.1)). Zaujímalo by ma, ako sú v ostaných redakčných systémoch alebo webových aplikáciach riešené updaty. Keď software zistí, že používateľ nepoužíva aktuálnu verziu, vyhodí mu varovanie s tlačítkom, po ktorého stlačení sa software updatuje. Skúšal som googliť, ale asi hľadám zle. Stačí ma naviesť, čo si mám pozrieť, akú informáciu googliť. Vlastne, uvítam každú informáciu ktorú ste schopní a ochotní mi poskytnúť.

Vďaka

 
Odpovědět
5.7.2017 20:32
Avatar
Samuel Kodytek
Tvůrce
Avatar
Samuel Kodytek:6.7.2017 10:45

Ahoj,

Nemám moc zkušeností s tímhle, ale první nápad co jsem dostal bylo se přes ajax vždycky dotazovat na nějakou změnu např v komentářích každých 5 vteřin, ale dokážu si představit že to asi bude pak zbytečně velká zátěž na server...

třeba google to dělá trošku jinak: https://stackoverflow.com/…-interaction (jejich gmail)

a nebo můžeš prostě používat websockety ( https://en.wikipedia.org/wiki/WebSocket ) na websockety existuje spoustu frameworků který můžeš používat jak v js tak i phpku (Socket.io) ale není to podporovaný staršími prohlížeči

Nahoru Odpovědět
6.7.2017 10:45
There is more than one way to screw it
Avatar
Odpovídá na Samuel Kodytek
Patrik Valkovič:6.7.2017 11:02

Pokud jsem pochopil původní příspěvek, tak on chce updatovat serverovou část u zákazníka.

Nahoru Odpovědět
6.7.2017 11:02
Nikdy neumíme dost na to, abychom se nemohli něco nového naučit.
Avatar
TomasGlawaty
Člen
Avatar
Odpovídá na Adam Ondrejkovič
TomasGlawaty:6.7.2017 14:37

Ahoj,
Prvně bych chtěl podotknout, že je toto vcelku zajímavý dotaz :) Problém lze řešit mnoha způsoby, tak zkusím popsat, jak bych to řešil já.

Předpokládám tedy, že máš:

  • Několik klientů, každý má svůj web a každý z nich je samostatná instance (nebeží fyzických X webů na jedné [společné] fyzické administraci)
  • Jeden typ CMS, který mají všichni tví klienti (připadně je to rozmodulované, každý z klientů ma jiné moduly)
  • Píšeš, že to je v Laraveli, takže používáš Composer

Cílem je:
Upozornit klienta, že existuje nová verze tvého CMS, respektive některého jeho modulu a chceš jeho souhlas s aktualizací.

Jestli má každý zákazník specifický web (frontend) delaný "na míru" (ačkoliv je administrace stejná), tak jako největší problém mě napadají BC breaks, kdy ty upravíš nějakou funkcionalitu, která může rozbít třeba jen některé z front aplikací tvých klientů.

Z CMS bych udělal samostatný balíček, instalovatelný Composerem - pokud tak již nemáš. Takže samostatný repozitář, případně jestli se jedná o modulární CMS (což hádám, že ano), tak aby každý z těchto modulů byl samostatným repozitářem. Aby bylo možné repozitář stahovat Composerem, tak musí být k nalezení na https://packagist.org/ (repozitáře by musely být volně dostupné, například na GitHubu). Ovšem, pokud by jsi chtěl využívat privátní repozitáře (např. na Bitbucketu, Gitlabu ad.), tak si potřebuješ na nějaké doméně rozchodit Satis a říct Composeru, že ma hledat také tam. Více o Satisu ZDE , měl jsem i nějaký CZ članek od Filipa Procházky myslím, ale nemohu ho již dohlledat.

Takže ve výsledku máš aplikaci klienta a tvoje adminsitrace je dotahována composerem do vendoru. Dále se nabízí používat třeba Databázové Migrace, kdy při stažení nějakého tvého modulu se spustí migrace a vytvoří tabulky, případně číselníky, automaticky do dané DB.

Jak bych aktualizace ideálně řešil?
Uživatelský souhlas bych neřešil. Pro všechny projekty bych využíval CI (třeba Travis), kdy bych si nastavil, že po push do repozitáře se zavolá build aplikace, spustí se testy (ano ty jsou potřeba, aby odhalily případně chyby) a jakmile vše projde, tak se zaktualizuje ostrá, pustí se composer, migrace atd.
Takže situace by vypadala nějak takto:

  • Pošlu úpravy do repozitáře daného modulu z CMS
  • Spustí se mi testy, připadně code-checking ad. - musí vše projít
  • Klientských aplikacím, kde chci modul aktualizovat, upravím composer.json s danou verzi balíčku a pushnu změny
  • Spustí se mi build aplikace, testy. Jakmile vše projde, tak se zaktualizuje repozitář na ostré (daná aplikace), spustí se composer install a migrace.

Samozřejmě, že tohle je docela složitý proces vývoje a musíš zvážít, jestli se ti to oplatí jak z časového hlediska, tak finančního (Společnosti, které ti poskytují CI rozhraní si za to samozřejmě nechávají platit :) ).
A také se o aktualizace prakticky staráš ty.
Dovedu si představit, že by se to dalo řešit i bez continuous delivery. Například si na nějaké URL vystavovat aktuální verzi a pravidlně se z aplikací doptávat - následně si tuto informaci uložit a zobrazovat uživateli - po souhlasu si naplánovat cronjob, který spustí composer update daného balíku. Může se pak ale stát, že nějaká úprava něco specifického v klienské aplikaci rozbije a web pak nepojede :)

Akceptované řešení
+20 Zkušeností
Řešení problému
 
Nahoru Odpovědět
6.7.2017 14:37
Děláme co je v našich silách, aby byly zdejší diskuze co nejkvalitnější. Proto do nich také mohou přispívat pouze registrovaní členové. Pro zapojení do diskuze se přihlas. Pokud ještě nemáš účet, zaregistruj se, je to zdarma.

Zobrazeno 4 zpráv z 4.