Unity Eğitim
Dersler
Forum Sınav Merkezi Premium 💎
Ağ Programlama

Unity'de NetworkManager.StopClient() ile İstemci Bağlantısını Kesme

Paylaşan: Unity Eğitim 07 November 2025 8 dakika okuma 11 görüntülenme

Giriş: İstemci Bağlantısını Güvenle Sonlandırmak

Unity'de çok oyunculu bir oyun geliştirirken, oyuncuların yani istemcilerin sunucuyla olan bağlantılarını doğru bir şekilde yönetmek büyük önem taşır. Bu yönetim sürecinin kritik bir parçası da, bir istemcinin ağ bağlantısını güvenli ve kontrollü bir şekilde sonlandırmaktır. İşte tam bu noktada Unity'nin NetworkManager sınıfının StopClient() metodu devreye girer. Bu makalede, NetworkManager istemci bağlantısı kesme işleminin neden bu kadar önemli olduğunu, StopClient() metodunun nasıl çalıştığını ve en iyi uygulamalarını detaylıca inceleyeceğiz.

NetworkManager ve İstemci Kavramları

Unity'nin dahili ağ çözümü (UNET) bağlamında, NetworkManager, bir oyunun ağ bileşenlerinin merkezidir. Hem istemci hem de sunucu tarafındaki bağlantıları, oyun nesnelerini ve ağ olaylarını yönetir. Bir istemci, sunucuya bağlanarak oyun oturumuna katılan her oyuncuyu veya makineyi temsil eder. NetworkManager ise, bu istemci ve sunucu arasındaki tüm ağ iletişimini yöneten ana bileşendir. StopClient() metodu, adından da anlaşılacağı gibi, mevcut NetworkManager istemci bağlantısını durdurmak için kullanılır.

NetworkManager.StopClient() Metodunun Detaylı İncelenmesi

NetworkManager.StopClient() metodu, istemcinin sunucuyla olan ağ bağlantısını sonlandırmak için tasarlanmıştır. Bu metodun temel amacı, istemcinin sunucuyla olan tüm ağ iletişimini kesmek, ağdaki tüm istemci nesnelerini temizlemek ve istemciyi "bağlantısız" duruma getirmektir. Kullanıcı oyundan çıktığında, bir bağlantı hatası oluştuğunda veya özel bir oyun içi mekanizma gerektirdiğinde NetworkManager istemci bağlantısını sonlandırmak için StopClient() çağrılır.

Nasıl Çalışır?

StopClient() çağrıldığında aşağıdaki adımlar gerçekleşir:

  • İstemci sunucuya bir bağlantı kesme mesajı gönderir.
  • İstemcinin ağ bağlantısı sonlandırılır.
  • İstemcinin sahip olduğu tüm ağ nesneleri (NetworkIdentity bileşeni olanlar) yok edilir veya devre dışı bırakılır.
  • OnClientDisconnect callback metodu tetiklenir (eğer NetworkManager'dan türetilmiş bir sınıfınız varsa).

Ne Zaman Çağrılmalı?

  • Kullanıcı oyundan veya çok oyunculu oturumdan ayrılmak istediğinde.
  • Sunucu bağlantısı beklenmedik bir şekilde koptuğunda veya bir zaman aşımı hatası oluştuğunda.
  • Oyun bittiğinde ve istemcinin bağlantısı artık gerekli olmadığında.

Basit bir kullanım örneği:

using UnityEngine;;
using UnityEngine.Networking;

public class MyNetworkManager : NetworkManager
{
    public void DisconnectClient()
    {
        // Sadece bağlıyken çağrı yapmak iyi bir pratiktir.
        if (NetworkClient.active)
        {
            StopClient();
            Debug.Log("İstemci bağlantısı kesildi.");
        }
        else
        {
            Debug.Log("İstemci zaten bağlı değil.");
        }
    }

    // İstemci bağlantısı kesildiğinde çağrılan callback
    public override void OnClientDisconnect(NetworkConnection conn)
    {
        base.OnClientDisconnect(conn);
        Debug.Log("OnClientDisconnect tetiklendi. Bağlantı kesildi: " + conn.address);
        // Burada arayüz güncellemeleri veya kaynak temizliği yapılabilir.
    }
}

OnClientDisconnect Callback ile Etkileşim

Özellikle, bir NetworkManager istemci bağlantısı sonlandırıldığında, istemcinin sunucudan ayrıldığına dair bir olay tetiklenir. Bu olay, NetworkManager sınıfından türetilmiş kendi özel NetworkManager sınıfınızda geçersiz kılabileceğiniz (override edebileceğiniz) OnClientDisconnect(NetworkConnection conn) metodudur. Bu callback, bağlantı kesildikten sonra istemci tarafında yapılması gereken temizlik, kullanıcı arayüzü güncellemeleri veya diğer özel işlemler için ideal bir yerdir.

public override void OnClientDisconnect(NetworkConnection conn)
{
    base.OnClientDisconnect(conn);
    Debug.Log("İstemci bağlantısı kesildi. Kullanıcıya bilgi veriliyor...");
    // Örneğin, bir ayrılma mesajı gösterebilir veya ana menüye dönebilirsiniz.
    // UIManager.Instance.ShowMessage("Sunucu ile bağlantı kesildi.");
    // SceneManager.LoadScene("MainMenu");
}

Pratik İpuçları

1. Bağlantı Durumunu Her Zaman Kontrol Edin

StopClient() metodunu çağırmadan önce istemcinin gerçekten bağlı olup olmadığını kontrol etmek, gereksiz hataları ve uyarıları önler. NetworkClient.active veya NetworkManager.singleton.client.isConnected gibi özellikler bu kontrol için kullanılabilir.

if (NetworkManager.singleton != null && NetworkManager.singleton.client != null && NetworkManager.singleton.client.isConnected)
{
    NetworkManager.singleton.StopClient();
}

2. OnClientDisconnect Olayını Kaynak Temizliği İçin Kullanın

Bağlantı kesildiğinde, istemciye özel bazı kaynakların (örneğin, geçici UI elemanları, ses efektleri, görsel efektler) temizlenmesi gerekebilir. OnClientDisconnect bu tür temizlik işlemleri için merkezi bir nokta sağlar.

3. Kullanıcı Arayüzünü Güncellemeyi Unutmayın

Unutmayın, NetworkManager istemci bağlantısı sonlandırıldıktan sonra, oyuncunun arayüzünü de bu duruma uygun şekilde güncellemek, kullanıcı deneyimi açısından kritik öneme sahiptir. Bağlantı kesildiğinde bir bilgilendirme mesajı göstermek veya oyuncuyu ana menüye yönlendirmek iyi bir yaklaşımdır.

4. Yeniden Bağlanma Mekanizmaları Geliştirin

Eğer uygulamanızda bağlantı kesildikten sonra otomatik olarak yeniden bağlanma özelliği sunmak istiyorsanız, StopClient() çağrısının ardından belirli bir gecikmeyle veya kullanıcı onayıyla yeniden bağlantı denemeleri başlatacak bir mekanizma kurmayı düşünebilirsiniz.

Yaygın Hatalar ve Çözümleri

1. Bağlı Değilken StopClient() Çağırmak

Hata: İstemci zaten bağlı değilken StopClient() metodunu çağırmak, genellikle bir hata olmasa da gereksiz bir işlemdir ve bazen Unity konsolunda uyarı mesajlarına yol açabilir. Bu durum, uygulamanızın mantığında bir boşluk olduğunu gösterebilir.

Çözüm: Yukarıda belirtildiği gibi, StopClient() çağırmadan önce NetworkClient.active veya NetworkManager.singleton.client.isConnected kontrolünü yapın.

2. StopClient() ile StopHost() / StopServer() Karıştırmak

Hata: Özellikle bir host (hem sunucu hem istemci) çalıştırıyorsanız, sadece istemci bağlantısını kesmek yerine tüm hostu durdurmanız gerekebilir. StopClient() sadece istemci tarafını durdururken, StopHost() hem sunucuyu hem de istemciyi durdurur, StopServer() ise sadece sunucuyu durdurur.

Çözüm: İhtiyacınıza uygun metodu kullanın. Eğer sadece istemcinin ayrılmasını istiyorsanız StopClient(), eğer host'un tamamen kapanmasını istiyorsanız StopHost() kullanın.

3. Kaynak Temizliğini İhmal Etmek

Hata: StopClient() çağrıldıktan sonra, özellikle OnClientDisconnect içinde gerekli temizlik işlemleri yapılmazsa, bellek sızıntıları veya gereksiz nesne referansları oluşabilir. Bu durum, uygulamanın performansını düşürebilir veya kararsız hale getirebilir. Yanlış kullanım, uygulamanın beklenmedik şekillerde davranmasına veya kaynak sızıntılarına yol açabilir. NetworkManager istemci bağlantısı yönetimi, oyunun genel kararlılığı için merkezi bir rol oynar.

Çözüm: OnClientDisconnect metodunu kullanarak bağlantı kesildikten sonra özel oyun nesnelerini, UI elementlerini veya diğer geçici kaynakları temizlediğinizden emin olun.

Performans ve Optimizasyon Notları

NetworkManager.StopClient() metodunun kendisi, genellikle performans açısından kritik bir işlem değildir. Bir bağlantıyı kesme süreci, genellikle milisaniyeler içinde tamamlanır ve oyunun ana döngüsünü kayda değer şekilde etkilemez. Ancak, bağlantı kesildikten sonra temizlenmeyen ağ nesneleri, gereksiz referanslar veya uygun şekilde serbest bırakılmayan kaynaklar, zamanla bellek sızıntılarına veya performans düşüşlerine neden olabilir. Bu nedenle, NetworkManager istemci bağlantısı sonlandırma sürecinde kaynak temizliğine azami özen göstermek, uygulamanızın uzun vadeli sağlığı için kritik öneme sahiptir.

Optimizasyon açısından dikkat edilmesi gerekenler:

  • Gereksiz GC Allocations (Çöp Toplayıcı Ayırmaları): OnClientDisconnect içinde çok fazla yeni nesne oluşturmaktan kaçının. Mümkünse nesne havuzlama (object pooling) tekniklerini kullanın.
  • Referans Temizliği: Bağlantısı kesilen istemciye ait artık kullanılmayan nesnelere olan referansları temizleyin. Özellikle statik referanslar bellek sızıntılarına yol açabilir.
  • UI Güncellemeleri: Bağlantı kesildiğinde UI güncellemeleri yaparken, bu güncellemelerin performans etkisini göz önünde bulundurun. Karmaşık animasyonlar veya yoğun hesaplamalar içeren UI işlemleri, kısa süreli takılmalara neden olabilir.

Sonuç

Unity'de NetworkManager.StopClient() metodu, istemci ağ bağlantılarını güvenli ve etkin bir şekilde sonlandırmak için temel bir araçtır. Doğru kullanıldığında, oyununuzun kararlılığını artırır ve kullanıcı deneyimini iyileştirir. Bu makalede ele alınan ipuçları ve yaygın hatalara karşı çözümlerle, NetworkManager istemci bağlantısı yönetimini daha profesyonel bir şekilde gerçekleştirebilir, böylece çok oyunculu oyunlarınızın sorunsuz bir şekilde çalışmasını sağlayabilirsiniz.

🧠 Ders Sonu Değerlendirme Testi

Dersi tamamladıktan sonra bilgilerinizi test edin ve ekstra puanlar kazanın.

🔥 +50 XP Ödül
🔒

Sınava Katılmak İçin Giriş Yapın

Bu ders sonu testini çözebilmek, bilginizi test edip **+50 XP** kazanmak ve **Sınav Şampiyonu** rozetinin kilidini açmak için üye girişi yapmalısınız.

Yorumlar (0)

Yorum yazabilmek ve derslere katkıda bulunabilmek için giriş yapmalısınız.

İlk yorumu siz yapın!