Sabah karanlıkta sırf bu videoyu izleyip ben de denemek için 2 saat erken geldim işe :) Yıllardır sorun yaşadığım, yüzlerce video izleyip ve makale okumuş olmama rağmen hala tam oturtamadığım, bana göre güvenlikten sonra en kritik konu olan bu konuyu sonunda anlayabildim hocam. Sadece 3 videoda tüm sorularıma cevap verdiniz. Ne kadar teşekkür etsem az. Bu verdiğiniz bilgileri bu şekilde bir anlatımla hiçbir yerde bulamıyordum. Burada bizimle paylaştığınız bilgilerin çok değerli hatta paha biçilmez. Çok çok teşekkür ederim hocam. Emeğinize sağlık. Tekrar iyi ki varsınız.
@ozancakin39222 жыл бұрын
Salih Bey, yine çok açıklayıcı bir eğitim videosu çekmişsiniz emeğinize sağlık
@aydemirzade343 жыл бұрын
Harika! Çok güzel eğitim. Teşekkürler
@TyfnCTN3 жыл бұрын
Eline sağlık bu hafta tamda multi treading işleriyle uğraştım :) temiz ve gayet başarılı anlatım her zaman ki gibi 😎
@TechBuddyTR3 жыл бұрын
Multi threading önemli ve üzerinde gerekli zamanın harcanması gereken bir konu bence. Faydalı olması dileği ile.
@asadullazadeh3 жыл бұрын
Mükemmel anlatım olmuş
@ugursesen76293 жыл бұрын
Salih hocam döktürüyorsun her zamanki gibi :)
@TechBuddyTR3 жыл бұрын
Estağfurullah. İyi seyirler
@muzafferakn68343 жыл бұрын
Hocam elinize sağlık çok güzel bir eğitim olmuş. Yalnız request count bilgisini kullanmadığınız 26 dakika boyunca elim ayağım titredi bağırdım ama duymadınız. En sonunda farkettiğinizde bi rahatlama geldi :D
@TechBuddyTR3 жыл бұрын
Çok teşekkür ederim. Arada bu tarz detaylar kaçabiliyor video sırasında :-) Geç olsun da güç olmasın
@ermekbakyt55073 жыл бұрын
Allah razi olsun! Cok guzel bir ders olmus!
2 жыл бұрын
Elinize sağlık.
@BatuhanxBayram Жыл бұрын
çok güzel bir video olmuş elinize sağlık
@sametersoy68063 жыл бұрын
Bu karşılaştırma örnekleri yazlımda çok değerli ama çok az maalesef bunun için öncelikle teşekkür ederiz. Monolitic vs microservis tarafında da böyle bir istek cevaplama örneği olsa çok değerli olurdu diye düşünüyorum.
@TechBuddyTR3 жыл бұрын
Çok teşekkür ederim. Bu örneğin Monolith ve Microservice tarafında olmasının çok bir önemi yok aslında. Çünkü her webapi projesi bu şekilde çalışıyor olacaktır. :)
@sametersoy68063 жыл бұрын
@@TechBuddyTR Hocam hem cevap için hem her video için ayrı yarı teşekkürler. Bende dediğinize katılıyorum sanırım kendi aklımdan geçeni doğru anlatamadım. Micro servislerde login için ayrı api projesi order için ayrı api projesi vs yapıyoruz ve bu projeler birbirleri ile iletişim halinde monolith de tek proje her şey kendi içinde çalışıyor onu kastetmiştim. Mesela login olup sepete ürün ekleyip ödemesini yapan 1000 istek göndersek hem monolith ve micro servis projesine sunucu yükünü ve işlem sürelerini görsek diye hayal etmiştim. Umarım bu sefer anlatabilmişimdir :)
@_ahmetkar3 ай бұрын
Merhabalar hocam, bende bir kere sync veya async seçsemde request count 16 deyip çalıştırdığımda TotalTime : 2100 gibi birşey çıkıyor request countu bir bir artırıp sonraki çalıştırmalarımda hep Totaltime : 63 ms , totaltime : 68 ms vs gibi değerler çıkıyor. Neden olabilir ?
@oyunkompetan71232 жыл бұрын
Salih Bey konu ile alakalı 2 videoyu da izledim hala istediğimi yapamıyorum. 2 siteden api istekleri ( client.GetAsync return ) 2 siteden de websocket dinliyorum ( client.ConnectAsync SendSocketMessage ). api de sorun çıkmıyor. Fakat iş websocket e geldiğin işler karışıyor. Websocket ten bağlantıyı kesemiyorum sürekli paketler geliyor ve içinde sürekli dönen while döngüsü var iş hiç bitmiyor. İş bitmediği içinde birinin bitip diğerini çalıştır gibi bir seçeneğim olmuyor. Ben saçma bir şekilde 3 program çalıştırıyorum. 1.si websocket 542 kalalı dinliyor ve .txt ye yazıyor , 2.si 613 numaralı kanalı dinliyor ve .txt ye yazıyor. 3.sü. 2 api den verileri alırken Anaform da da 542 ve 613 numaralı kanalların .txt lerini alıp işleyip verileri karşılaştırıyorum. Birde saçma bir olay var kanalları dinlerken form uygulamasında kanaldan gelen paketleri kaçırırken Console ile hiç kaçırmadan alabiliyorum. API leri Anaform dan Thread lar ile çalıştırıyorum, websocketler zaten ayrı 2 program. Bunları tek bir program da toplamak istiyorum. Anaform = -------------------------------------------------- API 1 = -- -- - - ------ - - - -- - - - - - -- ---- ---- - - API 2 = -- - - - - - -- - - - -- - - - - WS 1 =---------------------------------------------------- WS 2 =---------------------------------------------------- Umarım yukarıda yapmak istediğim şeyi anlatabilmişimdir. Bununla ilgili bir video hazırlar mısınız? Olumlu yada olumsuz dönüş yaptığınız için teşekkürler. Çalışmalarınızda başarılar diliyorum.
@someone97572 жыл бұрын
asyncde 1000 tanesi nasıl aynı anda çalışıyor 12 thread varsa,sadece bekleme yaptımız için mi öyle oldu mantıklı değil bence
@TechBuddyTR2 жыл бұрын
12 thread yok, 12 fiziksel core var thread create edebilen. Bunların içinde de her biri 32 bin thread oluşturup kullanabiliyor gibi düşünebiliriz. Ama bunu set de edebiliyoruz tabi ki
@someone97572 жыл бұрын
@@TechBuddyTR Hocam biraz araştırdım şimdi bizim UI olarak kullandığımız bi proje var o bir process, backend olark yine bir process bunların içinde sizin pcde 32k thread oluşturabiliyoruz. Biz backend processinin maxını 12 ye sabitledik ön tarafta hala 32k var. Anlamadığım nokta biz ön yüzden 1k istek atınca arkada 12 max thread yaptık, şimdi bu arkadaki 12 thread isteği alıyor task olarak direk ön tarafa mı döndürüyor yani öndeki 32k dan 12 tanesine yüklüyor işi ve tekrar bi 12 tane daha diye mi oluyor? Teşekkürler şimdiden.
@Furkan24664 Жыл бұрын
Benim kafam biraz karıştı , burada işi yapan threadler mi yoksa işi farklı bir yere mi taşıyor 'telefon bağlama örneginde oldugu gibi' . async durumda thread 2 işi aynı anda nasıl yapıyor alt trhread gibi bir şeyler mi var ? cevaplarsnı sevirinim.
@TechBuddyTR Жыл бұрын
Her uygulama, Application seviyesinde bir Ana Thread üzerinde çalışıyor. Bunun dışında biz istersek farklı thread ler oluşturabiliyoruz. Teorik olarak , Task'lar ana thread'i kilitlemeyen ayrı birer alt thread gibi düşünülebilir. Eğer await ile bekleme işlemi yapıyorsak, ana threadi kilitlemeden ama ana thread de bekleme yaparak alt thread'in işini bitirmesini bekliyoruz. Eğer bir Task çağırmışsak ve await ile beklememişsek, o thread alt thread tarafından çalıştırılıp bitiriliyor ve biz ne zaman bittiğini bilmiyoruz :)
@teknolojiuzmaniburada3 жыл бұрын
Hocam anlamadığım bir konu daha var. Sizin kanalda arattım ama bulamadım. Başkalarının anlatımını izliyorum hala ama gerçekten de onları izlemek zaman kaybı gibi geliyor artık bana. Ne işe yaradığını, kullanım alanlarını, hangi durumlarda kullanılabileceğini, çalışma mantığını hiç kimse sizin gibi anlatmıyor. 4 işlem üzerinden gösteriyorlar hep. Sizin gibi gerçek hayatta kullanımından bahsetmiyorlar. Bir tek ahanda hadi kullanalım şunu şuraya koyuyoz bunu buraya koyuyoz diyip bitiriyorlar videoları :) Konu ne diye sorduğunuzu duyar gibiyim :) Tabiki Delegeler :) Bu Delegate kavramını da rica etsem bize anlatabilir misiniz? Delegatelerin bir tek formlar, methodlar, sınıflar arasında iletişime yaradığı gibi bir izlenimim var izlediğim okuduğum kaynaklardan ama nedir ne değildir hala bilmiyorum. Bu konunun yeniden aklıma gelmesine vesile olan şey bir parmak okuyucu cihazın sdksını kullanırken f12 f12 yapa yapa sonunda events isimli bir interface'e ulaşıp içindeki EventHandlerlara da f12 yapınca birer satırlık delege oluşturulduğunu görmem oldu. Gidiş yolu şu şekildeydi f12 yapınca. public class CZKEMClass : IZKEM, CZKEM, _IZKEMEvents_Event public interface _IZKEMEvents_Event event _IZKEMEvents_OnDoorEventHandler OnDoor; public delegate void _IZKEMEvents_OnDoorEventHandler(int EventType); Ne amaçla kullanıldığını hiç kestiremiyorum şu an. Tamam bu sdk hazır, belki hiç bu kısımlarına ulaşıp kullanma ihtiyacım olmayacak ama kendi uygulamalarımda da sıfırdan delege yapısı oluşturabilip kullanabilmek istiyorum. Winforms uygulamalarında dinamik olarak farklı formlara veri gönderme gibisinden de kullanılıyor sanırım ama emin değilim. Bir video da Delegeler için gelir mi acaba? :) Bir ekleme daha: Yukarıda verdiğim bilgilerde delegate ve ilgili delege ismiyle event oluşturulmuş. Client tarafında eventa += yaparak bir metod veriyoruz kullanıyor. Cihazda birisi parmak okuttuğunda direkt bu event tetikleniyor. Anlayamadığım kısımlardan biri şu. Bu event ve delege olayı sanki bir listener gibi çalışıyor. Ama cihaza sürekli yeni veri var mı yok mu diye gidip bakmıyor olmasına rağmen, cihazda parmak okunduğunda nasıl oluyor da, cihaz veri gönderip bu eventı tetikleyebiliyor? Bu cihazın içinde var olan bir özellik mi? IP ve Port ile bağlanınca bağlı neresi varsa oraya veri mi gönderiyor.Bunu nasıl yapıyor olabilir ki anlamıyorum hocam :) Mesela ben winform uygulamamı kullanan tüm kullanıcılarıma db kullanmadan direkt bir mesaj ya da bildirim gönderebilir miyim? Mantığı nedir tam olarak? Çok teşekkür ederim.
@TechBuddyTR3 жыл бұрын
Selamlar, delegate ler metodlarımızın referansını tutan nesnelerdir. Bu konu yazarak anlatması biraz zor olan bir konu. Video için yakın dönemde gündemime alabilirim :-)
@teknolojiuzmaniburada3 жыл бұрын
@@TechBuddyTR Çok teşekkür ederim hocam. Sabırsızlıkla bekliyor olacağım :)
@saidcodesov21142 жыл бұрын
Eger dogru anladiysam konuyu :) soru guzel dostum . 1)delegate arkada nesne olaraq methodun referansini sakliyor(yani bellekdeki methodun addressini ) ve gerekdiginde call ediyorsun.....2) eventin isi listener gibi davranmak ola bilir amma o listener(event) neyi tetikleyecek ? delegate'i tabiiki , delegate == method . Dusunceme gore mantigi bu, programatik olaraq programda methodlari delegeler ile yazmak ve cagirmak, buyuk projelerde yuksek avantaj sagliyor. Cihazda surekli yeni veri varmi yokmu bakib bakmamasida methodun algortimasi ile alakali ola bilir. Cihaz veriyi barmak izinden aliyor ve internet(local olabilir) yoluyla, aldigi datani veritabanina gonderiyor eger veritabaninda eslesen "barmak verisi" (kimlik (ID)) varsa ---> return edib diger islemlere geciyor .Eger barmak okuyucuda "cache" mekanizmasi varsa gecici olaraq hizli calismasi amaciyla barmak izi ID'leri kendi dahili depolama belleyinde saklayabilir. Dusundugume gore anlamadigin konu barmak izi teknolojisi, onuda anlatirdim amma uzun konu, karisiklik ola bilir :) . Kisaca ozetlemek gerekirse :1) Barmak okuyucuya barmak koyulur 2)Sensor aktivlenir 3) Tarayici barmak izini gorur 4) Barmak izini ID'ye (baska bir ozellikde ola bilir) gore okumak icin database'e istek gondermek icin Eventi tetikler, Eventde methodu(delegate)'i tetikler 5) Db'e eslesen ID varsa veya yoksa ona gore davranilir
@teknolojiuzmaniburada2 жыл бұрын
@@saidcodesov2114 çok teşekkür ederim dillerinize sağlık çok güzel anlamışsınız 😊🙏
@saidcodesov21142 жыл бұрын
@@teknolojiuzmaniburada Rica ederim , teknolojide birlik ve bir birimize yardim etmek ve kafa kafaya vurub gelismek icin variz :0 :))))
@mansurdegirmenci86182 жыл бұрын
güzel anlatım olmuş hocam teşekürler. yalnız kafaya takılan soru şu olabilir o zaman her şeyi async yapalım dümdüz gidelim :)) bu durumun eksileri yokmudur? Sync yapmanın async yapmaya göre artısı nedir hocam?
@TechBuddyTR2 жыл бұрын
eğer her şeyi async yapabiliyorsak yapalım zaten :) Hayatımızı kolaylaştırıyor elbette ama bunun da bir maliyeti var. Şöyle bir arama yaparak biraz daha detaylı bilgiye ulaşabilirsiniz belki, ".net async state machine"