Epoll - Epoll

epoll bir Linux çekirdeği sistem çağrısı ölçeklenebilir bir G / Ç olay bildirim mekanizması için, ilk olarak 2.5.44 sürümünde Linux çekirdeği.[1] İşlevi, herhangi bir G / Ç'nin mümkün olup olmadığını görmek için birden çok dosya tanımlayıcısını izlemektir. Eskinin yerini alması amaçlanmıştır POSIX seçin (2) ve anket (2) sistem çağrıları, izlenen sayının daha fazla olduğu uygulamalarda daha iyi performans elde etmek için dosya tanımlayıcıları büyüktür (eski sistem çağrılarının aksine, Ö (n) zaman, epoll çalışır Ö(1 kez[2]).

epoll benzer FreeBSD 's Kqueue, bir dizi Kullanıcı alanı fonksiyonlar, her biri bir dosya tanımlayıcı birlikte çalıştıkları yapılandırılabilir çekirdek nesnesini ifade eden argüman. epoll kullanır kırmızı-siyah ağaç Şu anda izlenmekte olan tüm dosya tanımlayıcılarını takip etmek için (RB ağacı) veri yapısı.[3]

API

int epoll_create1(int bayraklar);

Bir oluşturur epoll nesne ve dosya tanımlayıcısını döndürür. bayraklar parametresi epoll davranışının değiştirilmesine izin verir. Yalnızca bir geçerli değeri vardır, EPOLL_CLOEXEC. epoll_create () eski bir çeşididir epoll_create1 () ve Linux çekirdek sürümü 2.6.27 ve glibc sürüm 2.9'dan itibaren kullanımdan kaldırılmıştır.[4]

int epoll_ctl(int epfd, int op, int fd, yapı epoll_event *Etkinlik);

Bu nesne tarafından hangi dosya tanımlayıcılarının ve hangi olaylar için izlendiğini kontrol eder (yapılandırır). op EKLE, DEĞİŞTİR veya SİL olabilir.

int epoll_wait(int epfd, yapı epoll_event *Etkinlikler, int Maxevents, int zaman aşımı);

İle kaydedilen olaylardan herhangi birini bekler epoll_ctl, en az biri gerçekleşene veya zaman aşımı süresi geçene kadar. İçinde meydana gelen olayları verir Etkinliklerkadar Maxevents bir kerede.

Tetikleme modları

epoll ikisini de sağlar Kenar tetikli ve seviye tetiklemeli modlar. Kenar tetiklemeli modda, epoll_wait yalnızca yeni bir olay ile sıraya alındığında dönecektir epoll nesne, seviye tetiklemeli moddayken, epoll_wait koşul geçerli olduğu sürece geri dönecektir.

Örneğin, eğer bir boru ile kayıtlı epoll veri aldı, aradı epoll_wait okunacak verilerin varlığını işaret ederek geri dönecektir. Diyelim ki, okuyucu arabellekteki verilerin sadece bir kısmını tüketti. Seviye tetiklemeli modda, epoll_wait boru tamponu okunacak verileri içerdiği sürece hemen dönecektir. Bununla birlikte, kenar tetiklemeli modda, epoll_wait yalnızca boruya yeni veri yazıldığında dönecektir.

Eleştiri

Bryan Cantrill bunu işaret etti epoll seleflerinden öğrenmiş olsaydı, önlenebilecek hatalar vardı: giriş / çıkış tamamlama bağlantı noktaları, olay bağlantı noktaları (Solaris) ve Kqueue.[5] Ancak eleştirisinin büyük bir kısmı, epoll's EPOLLONESHOT ve EPOLLEXCLUSIVE seçenekler. EPOLLONESHOT Şubat 2004'te piyasaya sürülen Linux çekirdek ana hattının 2.6.2 sürümüne eklendi. EPOLLEXCLUSIVE Mart 2016'da yayınlanan 4.5 sürümüne eklendi.[6]

Ayrıca bakınız

Referanslar

  1. ^ "epoll (7) - Linux kılavuz sayfası". Man7.org. 2012-04-17. Alındı 2014-03-01.
  2. ^ Oleksiy Kovyrin (2006-04-13). "Eşzamansız Ağ Programlama İçin epoll () Kullanma". Kovyrin.net. Alındı 2014-03-01.
  3. ^ https://idndx.com/2014/09/01/the-implementation-of-epoll-1/
  4. ^ Sevgiler, Robert (2013). Linux Sistem Programlama (İkinci baskı). O’Reilly. s. 97, 98. ISBN  978-1-449-33953-1.
  5. ^ https://www.youtube.com/watch?v=l6XQUciI-Sc&t=57m
  6. ^ "Epoll temelde 1/2 kırıktır". idea.popcount.org. 2017-02-20. Alındı 2017-10-06.

Dış bağlantılar