Předvánoční slevová akce PHP týden
Další šance dokončit svůj projekt a získat ceny v hodnotě 10.000 Kč! Pokračování úspěšné letní soutěže - ITnetwork winter
Využij předvánočních slev a získej od nás 20 % bodů navíc zdarma! Zároveň také probíhá PHP týden se slevou na e-learning až 80 %

Diskuze: .net core DI

Aktivity (4)
Avatar
Petr Kasnal
Člen
Avatar
Petr Kasnal:30. března 13:38

Ahoj, mám dotaz ohledně typů registrace do DI.
services.AddSin­gleton - Vím co znamená, existuje pouze jedna instance
services.AddScoped - Přesně neívm?
services.AddTran­sient - Taky přesně nevím

Mohl by mi to prosím někdo objasnit? Předem moc díky za informace

Zkusil jsem: Hledat na googlu a našel jsem to, ale úplně romu nerozunmím, proto bych si to chtěl ujistit.

Chci docílit: Správného fungování

 
Odpovědět
30. března 13:38
Avatar
Ilja Židkov
Člen
Avatar
Odpovídá na Petr Kasnal
Ilja Židkov:30. března 14:36

services.AddTran­sient<Služba, Implementace>- Každý HTTP požadavek vytvoří novou instanci služby (alokuje paměť).

Dejme tomu, že tvá služba vrací nový GUID (unikátní řetězec).

Představ si URL: http://localhost:5000/home/index

Zkus opakovaně vysílat požadavek na toto stejné URL (čili "refreshovat" stránku) a uvidíš, že GUID se pořád mění! Čili jak jsem se zmínil, Transient vytváří novou instanci pro každý HTTP požadavek.

Použivají se všude tam, kde není jistota sdílení dvou instantcí současně (což může způsobit únik paměti). Např. paralelní sdílení contextu Entity Frameworku.


services.AddSco­ped<Služba, Implementace> - Každý HTTP požadavek vytvoří novou instanci pro daný rozsah. Typickým příkladem jsou samotné kontrolery.

Čili kdybys refreshoval výše zmíněné URL, GUID by byl stejný jen pro home controller. Jinými slovy, instance je sdílená po dobu existence kontroleru.

 
Nahoru Odpovědět
30. března 14:36
Avatar
Petr Kasnal
Člen
Avatar
Odpovídá na Ilja Židkov
Petr Kasnal:30. března 15:07

A rozumím, já jsem měl právě porblém s tím EF jak zmiňuješ.Takže vzhledem k EF mám používát Scoped? Kčemu se třeba hodí Transient? Díky :)

 
Nahoru Odpovědět
30. března 15:07
Tento výukový obsah pomáhají rozvíjet následující firmy, které dost možná hledají právě tebe!
Avatar
Ilja Židkov
Člen
Avatar
Ilja Židkov:30. března 15:52

Takže vzhledem k EF mám používát Scoped?

To záleží. Pokud používáš jeden kontext ("jednu databázi") a provádíš klasické CRUD (Create, Read, Update, Delete) operace, tak v tomto případě bych nevymýšlel vesmír a zůstal u Scoped. Čili bych sdílel jednu instanci v po dobu existence kontroleru.

Typický příklad:

services.AddSco­ped<IEmployee­Repository, EmployeeReposi­tory>(); kde EmployeeRepository interně implementuje Entity Framework.


K čemu se třeba hodí Transient?

Transient se hodí všude tam, kde nepotřebuješ sdílet stejnou instanci buď v rozsahu celé aplikace (Singleton) nebo v rozsahu kontroleru (Scoped). Většinou to jsou drobné služby, které dělají jednu jedinou věc.

Např. zpracování nahrané fotografie.

services.AddTran­sient<IPhotoSer­vice, PhotoService>(); kde PhotoService implementuje logiku pro zpracování fotografie.

Přeci jen, celá tvá aplikace nepotřebuje vědět jak zpracovat foto, že ne? Nejčastěji je to úloha jedné jediné akce (např. profil uživatele), což v tomto případě by nebylo rozumné držet instanci PhotoService po dobu existence celé aplikace (Singleton) nebo po dobu existence kontroleru (Scoped).

Závěrem:

Singletony jsou nejčastěji služby samotného frameworku (HTTP požadavky, logování, konfigurace prostředí - test, vývoj, produkce).

Scoped jsou nejčastěji repozitáře. Všechno to, co komunikuje s externím zdrojem (jako např. databáze nebo API), protože celý kontroler využívá jednu instanci kontextu (např v Index akci zobrazíš seznam výrobku, v akci Detail načteš pouze data vztahující se k danému produktu), protože je to "levnější" než vytvářet novou instanci (Transient) a je úspornější využít existující.

Transient - malé, drobné služby, které vykonají jednu jedinou věc.

Akceptované řešení
+20 Zkušeností
+1 bodů
Řešení problému
 
Nahoru Odpovědět
30. března 15:52
Avatar
Petr Kasnal
Člen
Avatar
Odpovídá na Ilja Židkov
Petr Kasnal:30. března 17:42

Mockrát ti děkuji.

 
Nahoru Odpovědět
30. března 17:42
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 5 zpráv z 5.