Bükülmüş (yazılım) - Twisted (software)

Bükülmüş
Twisted Logo (yazılım) .svg
Orijinal yazar (lar)Glif Lefkowitz
Geliştirici (ler)Topluluk
İlk sürüm22 Ekim 2002; 18 yıl önce (2002-10-22)[1]
Kararlı sürüm20.3.0 (20 Mart 2020; 8 ay önce (2020-03-20)[2]) [±]
Depo Bunu Vikiveri'de düzenleyin
YazılmışPython
TürOlay odaklı ağ oluşturma
LisansMIT Lisansı
İnternet sitesiwww.twistedmatrix.com Bunu Vikiveri'de düzenleyin

Bükülmüş bir olay odaklı ağ programlama çerçeve yazılmış Python ve altında lisanslıdır MIT Lisansı.

Bükülmüş projeler çeşitli şekillerde destekler TCP, UDP, SSL / TLS, IP çok noktaya yayın, Unix alanı prizler, birçok protokol (dahil HTTP, XMPP, NNTP, IMAP, SSH, IRC, FTP ve diğerleri) ve çok daha fazlası. Twisted temel alır olay odaklı programlama paradigma, yani Twisted kullanıcılarının kısa yazması geri aramalar çerçeve tarafından çağrılan.

Temel fikirler

Protokollerin ve taşımaların ayrılması

Twisted, mantıksal protokoller arasında tam bir ayrım için tasarlanmıştır (genellikle HTTP veya HTTP gibi akış tabanlı bağlantı anlamlarına güvenir). POP3 ) ve bu tür akış tabanlı semantiği destekleyen fiziksel taşıma katmanları (dosyalar, soketler veya SSL kitaplıkları gibi). Mantıksal bir protokol ile bir taşıma katmanı arasındaki bağlantı, mümkün olan en son anda, bilgiler mantıksal protokol örneğine aktarılmadan hemen önce gerçekleşir. Mantıksal protokol, taşıma katmanı örneğinden haberdar edilir ve bunu mesajları geri göndermek ve eşin kimliğini kontrol etmek için kullanabilir. Protokol kodunda, aktarım sorunlarıyla ilgili olarak aktarım katmanını derinlemesine sorgulamanın (istemci tarafı SSL sertifikasının kontrol edilmesi gibi) hala mümkün olduğunu unutmayın. Doğal olarak, bu tür protokol kodu başarısız olacaktır (istisna yaratmak ) taşıma katmanı bu tür semantiği desteklemiyorsa.

Ertelenen

Twisted uygulama modelinin merkezinde, bir ertelenmiş (başka yerde a gelecek ). Ertelenmiş, henüz hesaplanmamış bir sonucu almak ve işlemek için tasarlanmış bir sınıfın örneğidir, örneğin uzak bir eşten gelen verilere dayandığı için. Ertelenmiş olanlar, tıpkı normal nesneler gibi dolaştırılabilir, ancak değerleri sorulamaz. Her ertelenen bir geri arama zincirini destekler. Ertelenen değeri aldığında, geri arama zincirindeki işlevlere geçirilir ve her geri aramanın sonucu bir sonraki için girdi olur. Ertelenmiş değerler, değeri kullanılabilir hale gelmeden önce bir işlev çağrısının sonucu üzerinde çalışmayı mümkün kılar.

Örneğin, ertelenmiş bir uzak uçtan bir dize döndürürse, IP adresi dörtlü biçimde, 32 bitlik bir sayıya çevirmek için bir geri arama eklenebilir. Ertelenen herhangi bir kullanıcı artık onu 32 bitlik bir sayı döndüren ertelenmiş olarak kabul edebilir. Bu ve ilgili "hata işleyicileri" (hata işleyicileri olarak adlandırılan geri çağırmalar) tanımlama yeteneği, kodun olayı beklemeyi bırakmadan zaman uyumsuz bir olay meydana geldiğinde ne yapılacağını önceden belirlemesine izin verir. Olay güdümlü olmayan sistemlerde, örneğin İş Parçacığı, işletim sistemi, her engelleme çağrısı yapıldığında erken ve ek düzenleme iş parçacığı oluşturur.

Konu desteği

Twisted, ertelenmiş kaynak olarak bir iş parçacığı kullanarak ham iş parçacıkları üzerinde bir soyutlamayı destekler. Böylece, iş parçacığı bittiğinde bir değer alacak olan bir ertelenmiş derhal döndürülür. Ana iş parçacığında çalışacak geri çağırmalar eklenebilir, böylece karmaşık kilitleme çözümlerine olan ihtiyacı azaltır. Twisted'ın destek kitaplıklarından gelen bu tür bir kullanımın en iyi örneği, veritabanlarını aramak için bu modeli kullanmaktır. Veritabanı çağrısının kendisi yabancı bir iş parçacığında gerçekleşir, ancak sonucun analizi ana iş parçacığında gerçekleşir.

Yabancı döngü desteği

Twisted, aşağıdakiler gibi yabancı olay döngüleriyle bütünleşebilir: GTK +, Qt ve Kakao (vasıtasıyla PyObjC ). Bu, Twisted'ın ağ katmanı olarak kullanılmasına izin verir. grafiksel kullanıcı arayüzü (GUI) programları, Python'un yerel kütüphanesinde olduğu gibi soket başına iş parçacığı ek yükü eklemeden tüm kitaplıklarını kullanır. Tam teşekküllü bir web sunucusu, örneğin bu modeli kullanarak bir GUI programı ile süreç içi entegre edilebilir.

Twisted kullanan uygulamalar

  • BuildBot sürekli entegrasyon sistemi, istemci / sunucu iletişimi için Twisted'a dayanır.[3]
  • ITA Yazılımı için bir havayolu rezervasyon sistemi geliştirdi Air Canada Twisted'ı yoğun bir şekilde kullanan.[4]
  • SageMath, açık kaynaklı bir alternatif Mathematica, Akçaağaç, Magma, MATLAB, web tabanlı bir arayüze sahiptir, SageMath dizüstü bilgisayar,[5] Twisted sunucuda çalışır.[6]
  • Twisted kullanıldı Omegle bire bir sohbet hizmeti[7] performans nedenleriyle gevent ile değiştirilene kadar.[8]
  • Apple Takvim Sunucusu Twisted kullanır,[9] bazı dahili projeler gibi NASA.
  • Kabuklu deniz hayvanı, bir uygulaması Güvenli Kabuk (SSH) protokolü
  • Sosyal ağ ve mikroblog sitesinin orijinal versiyonu Jaiku Twisted kullanılır.[kaynak belirtilmeli ]
  • Fluidinfo, çevrimiçi bir bulut veri deposu olan, dahili RPC için yoğun olarak Twisted'ı kullanır (kısmen Tasarruf ve AMQP ), dahili hizmetleri ve harici API'ler için.
  • Dosya barındırma hizmeti Ubuntu One Twisted kullanılır.
  • Tor2web için bir HTTP proxy'si Tor Gizli Hizmetleri (HS) Twisted kullanır.
  • GlobaLeaks, açık kaynaklı bir bilgi uçurma çerçevesi Twisted'ı kullanır.
  • Cloudkick, bir bulut sunucu yönetimi web uygulaması olan Twisted'ı kullandı. Şimdi kullanılarak yeniden yazılmıştır Node.js.
  • Twilio, bir bulut telefon sağlayıcısı Twisted kullanıyor.
  • Seğirme Video oyun yayını ve sohbet topluluğu olan Twisted'ı kullanıyor.[10]
  • Bir meteorolojik veri işleme ve entegrasyon API'si olan Velocity Weather, Twisted üzerine inşa edilmiştir.[11]
  • qwebirc, web tabanlı bir IRC istemcisi Twisted'ı kullanır.
  • Zenoss Çekirdeği, bir ağ yönetimi platformu, birçok dahili ve koleksiyon arka plan programı için Twisted'ı kullanır.
  • Hurda Twisted tabanlı bir web tarayıcısı.
  • Wikipedia'yı dinleyin, bir Wikipedia ses-görselleştirici, gerçek zamanlı düzenleme olaylarını tarayıcılara yayınlamak için Twisted'ı kullanır.[12]
  • Tahoe-LAFS, dağıtılmış bir veri deposu ve dağıtılmış dosya sistemi.
  • Tufan oldukça modüler BitTorrent müşteri Twisted kullanıyor.[13]
  • Sihirli Solucan Deliği kullanarak güvenli bir dosya aktarım aracı PAKE.[14]

Ayrıca bakınız

Referanslar

  1. ^ Shtull-Trauring, Itamar (2002-10-22). "Twisted 1.0". bükülmüş piton (Mail listesi). Alındı 2008-08-14.
  2. ^ "Bültenler - bükülmüş / bükülmüş". Alındı 2020-11-04 - üzerinden GitHub.
  3. ^ "BuildBot Kılavuzu". github.com. Arşivlenen orijinal 2012-07-29 tarihinde. Alındı 2017-10-28.
  4. ^ "Python Slithers into Systems". eweek.com.
  5. ^ SageMath # Özellikleri
  6. ^ Sage a Temel Bakış[kalıcı ölü bağlantı ]
  7. ^ "mistah deejay". omegler.blogspot.com.
  8. ^ "Google Toplulukları". groups.google.com.
  9. ^ "Takvim ve Kişiler Sunucusu". www.calendarserver.org.
  10. ^ "Twitch - İşler". Seğirme.
  11. ^ "Hız Hava Durumu -". www.velocityweather.com.
  12. ^ Wikipedia için WebSocket odaklı bir monitör (ayrıca, wikimon, wikital canavarlar), hatnote, 2017-09-03, alındı 2017-09-21
  13. ^ "Tufan: kaynaktan derleyin". dev.deluge-torrent.org. Alındı 2020-01-08.
  14. ^ "Sihirli Solucan Deliği". github.com.
  15. ^ "EventMachine". Alındı 20 Ağustos 2011.
  16. ^ "Diğer Çerçevelerle entegrasyon - Kivy 1.11.0.dev0 belgeleri". kivy.org.

Dış bağlantılar