API'ler, açık protokoller ve mimariler aracılığıyla uygulamaları birbirine bağlar. Bir API mimarisi, yazılım arayüzleri oluşturmak için bir kurallar çerçevesidir. Kurallar, kullanıcılara sunucu işlevselliğinin nasıl sağlanacağını belirler. Mimari türü, API'yi yöneten kuralları ve yapıları belirler.
REST'ten RPC'ye kadar birçok farklı API mimarisi türü vardır. Yapılarını ve bileşimlerini öğrenmek, uygulamanız için bir tane seçmenize yardımcı olacaktır.
1. DİNLENMEK
REST API'leri moderndir ve geliştiricilerin kullandığı en popüler API mimarisidir. DİNLENMEK (temsili durum aktarımı), istemci-sunucu uygulamalarını tasarlamak için kullanılan bir mimaridir. Bu bir protokol veya standart değildir, dolayısıyla onu çeşitli şekillerde uygulayabilirsiniz. Bu özellik, bir geliştirici olarak esnekliğinizi artırır.
REST, bir veritabanında saklanan istenen verilere erişim sağlar. Temel CRUD işlevlerini bir REST API ile gerçekleştirebilirsiniz. İstemciler bir RESTful API aracılığıyla içerik istediğinde, doğru başlıkları ve parametreleri kullanmaları gerekir. Başlıklar, durum kodları ve yetkilendirme gibi bir kaynağı tanımlamak için yararlı meta veriler içerir.
HTTP aracılığıyla aktarılan bilgiler JSON, HTML, XML veya düz metin biçiminde olabilir. JSON, REST API'leri için en yaygın kullanılan dosya biçimidir. JSON dilden bağımsızdır ve insanlar tarafından okunabilir.
2. SABUN
Basit Nesne Erişim Protokolü (SOAP) resmi bir API protokolüdür. World Wide Web Konsorsiyumu (W3C), en eski API mimarilerinden biri olan SOAP protokolünü sürdürür. Tasarımı, farklı diller ve platformlarla oluşturulmuş uygulamalar arasındaki iletişimi kolaylaştırır.
SOAP biçimi, web hizmeti açıklama dilini (WSDL) kullanan bir API'yi tanımlar. Kapsamlı biçimlendirme dilinde (XML) yazılmıştır. Biçim, güvenliği, tutarlılığı, izolasyonu ve dayanıklılığı artıran yerleşik uyumluluk standartlarını dayatır. Bu özellikler, SOAP'ı kurumsal geliştirme için daha iyi hale getiren güvenilir veritabanı işlemlerini sağlar.
Bir kullanıcı bir SOAP API aracılığıyla içerik istediğinde, standart katman protokollerinden geçer. Yanıt, insanların ve makinelerin okuyabileceği XML biçimindedir. REST API'leri gibi, SOAP API'leri de bilgileri önbelleğe almaz/depolamaz. Verilere daha sonra ihtiyacınız olursa, başka bir talepte bulunmanız gerekir.
SOAP, hem durum bilgisi olan hem de durum bilgisi olmayan veri alışverişlerini destekler.
3. GrafikQL
GraphQL bir sorgulama dilidir bir API için. Tanımlanmış bir veri kümesine dayalı olarak sorguları yürüten sunucu tarafı bir çalışma zamanıdır. GraphQL'nin belirli kullanım durumları vardır. Mimarisi, ihtiyacınız olan belirli bilgileri beyan etmenize izin verir.
HTTP'nin istemci isteklerini ve yanıtlarını işlediği REST mimarisinin aksine, GraphQL sorgularla veri ister. Bir GraphQL hizmeti, bu türlerin türlerini ve alanlarını tanımlar, ardından her alan ve tür için işlevler sağlar.
hizmet alır GraphQL sorguları doğrulamak ve yürütmek için. İlk olarak, tanımlanan türlere ve tanımlanmış alanlara başvurduğundan emin olmak için bir sorguyu kontrol eder. Ardından, istenen sonucu elde etmek için ilişkili işlevleri çalıştırır.
GraphQL, birden fazla kaynaktan veri almak gibi belirli kullanım durumları için harikadır. Ayrıca veri getirmeyi kontrol edebilir ve daha küçük cihazlar için bant genişliğini düzenleyebilirsiniz.
4. Apaçi Kafkası
Apaçi Kafkası olay akışını destekleyen dağıtılmış bir platformdur. Olay akışı, kaynaklardan gerçek zamanlı olarak veri alma işlemidir. Kaynaklar, veritabanları, sunucular veya yazılım uygulamaları olabilir. Kafka sistemi, sunucular ve istemcilerden oluşur. İletişim bir TCP ağ protokolü aracılığıyla gerçekleşir.
Sistemi donanım, sanal makineler ve kapsayıcılara dağıtabilirsiniz. Bunu şirket içinde ve bulut ortamlarında yapabilirsiniz. Apache Kafka sistemi verileri yakalar, işler ve gerçek zamanlı olarak bunlara tepki verir. Ayrıca verileri gerçek zamanlı olarak tercih edilen bir hedefe yönlendirebilir. Kafka, daha sonra kullanmak üzere alabileceğiniz verileri yakalar ve sistemde depolar.
Kafka, sürekli bir veri akışını ve entegrasyonunu destekler. Bu, bilginin doğru zamanda doğru yerde olmasını sağlar. Olay akışı, canlı veri akışlarına ihtiyaç duyan birçok kullanım durumu için geçerli olabilir. Bunlar finansal kurumları, sağlık hizmetlerini, hükümeti, ulaşım endüstrisini ve bilgisayar yazılım şirketlerini içerir.
5. Async API'si
Async API'si olay güdümlü mimarilerin oluşturulmasına ve sürdürülmesine yardımcı olan açık kaynaklı bir girişimdir. Spesifikasyonlarının OpenAPI spesifikasyonları ile birçok ortak noktası vardır. AsyncAPI, temelde birkaç farkla OpenAPI özelliklerinin bir uyarlaması ve geliştirilmesidir.
AsyncAPI mimarisi, REST API'leri ile olaya dayalı API'lerin bir karışımını bir araya getirir. İstekleri ve yanıtları ele alma şemaları şunlardır: olay API'lerininkine benzer. AsyncAPI, eşzamansız uygulamaları makine tarafından okunabilir bir şekilde açıklamak ve belgelemek için özellikler sağlar. biçim. Ayrıca, kullanıcıların bunları uygulamasını kolaylaştırmak için kod üreteçleri gibi araçlar sağlar.
AsyncAPI, Event-Driven mimarisinin (EDA) mevcut durumunu iyileştirir. Amaç, REST API'lerinde olduğu gibi EDA'larla çalışmayı kolaylaştırmaktır. AsyncAPI girişimi, olay yönetimini destekleyen belgeler ve kod sağlar. REST API'lerinde kullanılan işlemlerin çoğu, olaya dayalı/eşzamansız API'ler için geçerlidir.
Olay güdümlü sistemleri belgelemek için AsyncAPI belirtimini kullanmak çok önemlidir. Olay odaklı projelerde çalışan ekipler arasında tutarlılığı ve verimliliği yönetir ve sürdürür.
6. Uzaktan Yordam Çağrısı (RPC)
RPC, bir ağ üzerindeki farklı programlar arasında iletişime izin veren bir yazılım iletişim protokolüdür. Örneğin, bir program ağdaki başka bir bilgisayardan bilgi isteyebilir. Ağ protokollerine uymak zorunda değildir. Tıpkı yerel sistemdeki gibi uzak sistemlerdeki işlemleri çağırmak için RPC'yi kullanabilirsiniz.
RPC, istemci-sunucu modelinde çalışır. İstemci programı istekte bulunur ve sunucu programı bir hizmetle yanıt verir. RPC'ler senkronize çalışır. Bir program bir istek gönderdiğinde, sunucudan bir yanıt alana kadar askıda kalır.
RPC'ler dağıtılmış sistemler için en iyisidir. Komuta dayalı sistemler için en iyisidirler ve performansı artıran hafif yüklere sahiptirler.
Doğru API Mimarisi Nasıl Seçilir?
Doğru API mimarisi, kullanım durumunuza bağlıdır. Mimari, API'yi geliştirme metodolojisini ve nasıl çalışacağını belirler. API'nin mimari tasarımı, bileşenlerini ve etkileşimlerini tanımlar.
API'yi tasarlamadan ve geliştirmeden önce mimari kararlar verin. API, katman, yaşam döngüsü yönetimi ve güvenliğin teknik gereksinimlerini belirleyin. API mimarisi tasarımları yapısal katmanlar içerir. Katmanlar, geliştirmeyi yönlendirir ve oluşturulan API'nin amaçlanan amaca hizmet etmesini sağlar.