Diskuze: EF6 neuvolňování paměti
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Zobrazeno 5 zpráv z 5.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
GC čistí automaticky, ale uvolňuje z paměti pouze ty objekty, se kterými
se nějakou dobu nepracuje a nejsou na ně aktivní žádné vazby, takže v
tomto případě ti je GC na prd.
K čemu to vlastně má sloužit? Tato smyčka je podle mě naprosto zbytečná,
když informaci o synchronizaci můžeš někam ukládat rovnou při nějaké
jiné akci, např. když uložíš záznam do té tabulky dbImport...
Chapu spravne, ze v ramci nejakeho cyklu volas metodu s tim usingem, ktera udela to, ze vytvori spojeni s db, vytahne cely zaznam, upravi datum a zase ulozi?
Jak casto to volas?
Co dela BackendEntities? Neni to nahodou dbContext?
Jak casto musis zaznamy synchronizovat?
Celý program pracuje tak, že načte data z jedné DB, pak je pročistí, upraví a vloží do druhé DB. Jedná se např. o skladové karty, prodeje... Takže ve smyčce načítám data z první databáze, tam je to v pohodě to mám přes dotazy. Data pak pročistím a upravím. Následně vytvořím, pro každou "tabulku" vlastní dbContext a přes EntityFramework vytvářím/upravuji jednotlivé entity, které se uloží do DB. Celá práce s dbContextem je v using bloku. Takže by se mělo následně vše zahodit a uvolnit paměť. Cyklus běží každých 10 minut a problém je, že se můžou už zapsaná data změnit, takže musím entity porovnávat. (Mám skladovou kartu, tu si musím najít a pokud již existuje tak přepsat hodnoty). Co jsem zkoumal, tak problém je právě v hledání entit v dbContextu.
Dim zarizeniDb As Zarizeni = (From z In dbImport.Zarizeni Where z.Id_zarizeni = zarizeni.Id_zarizeni Select z).FirstOrDefault
To nějak zůstává v paměti.Ale asi ani ne ta entita jako taková, ale nějaká data ohledně vyhledávání. Nyní to v každém cyklu a 15tis. kartách skáče o 40mb nahoru.
A ještě jedna záhada, pokud se jedná o první spuštění programu, kde
se navíc na začátku jen vytváří DB jinak je proces stejný se stejnou
metodou tak vše funguje jak má. A uvolňuje se vše.
Zobrazeno 5 zpráv z 5.