Gömülü veritabanı - Embedded database

Bir gömülü veritabanı sistem bir veritabanı Yönetim sistemi (DBMS) ile sıkı bir şekilde tümleşik Uygulama yazılımı erişim gerektiren depolanmış veri, öyle ki veritabanı sistemi uygulamanın son kullanıcısından "gizlenir" ve çok az veya hiç devam eden bakım gerektirmez. Aslında aşağıdakileri içeren geniş bir teknoloji kategorisidir:

Dönem gömülü veritabanı kafa karıştırıcı olabilir çünkü gömülü veritabanı ürünlerinin yalnızca küçük bir alt kümesi gerçek zaman gömülü sistemler gibi telekomünikasyon anahtarları ve tüketici elektroniği cihazlar.[1] (Görmek mobil veritabanı gömülü cihazlarda kullanılabilecek küçük ayak izine sahip veritabanları için.)

Uygulamalar

Başlıca gömülü veritabanı ürünleri, alfabetik sırayla şunları içerir:

Veritabanı depolama motorlarının karşılaştırmaları

Advantage Veritabanı Sunucusu

Sybase'in Advantage Veritabanı Sunucusu (ADS), tam özellikli bir gömülü veritabanı yönetim sistemidir. Hem ISAM hem de ilişkisel veri erişimi sağlar ve Windows, Linux ve Netware dahil olmak üzere birçok platformla uyumludur. Ücretsiz bir yerel dosya sunucusu veritabanı veya tam bir istemci-sunucu sürümü olarak mevcuttur. ADS, uzun yıllardır piyasadadır ve oldukça ölçeklenebilirdir, yönetim gerektirmez ve aşağıdakiler dahil çeşitli IDE'leri destekler: .NET Framework (.AĞ), Nesne Pascal (Delphi), Görsel FoxPro (FoxPro), PHP, Visual Basic (VB), Görsel Nesneler (VO), Vulkan, Clipper, Perl, Java, xHarbour, vb.

Apache Derbisi

Derby, tamamen Java ile yazılmış gömülebilir bir SQL motorudur. Tamamen işlemsel, iyi bir SQL alt kümesine sahip çok kullanıcılı Derby, olgun bir motordur ve Apache lisansı altında ücretsiz olarak kullanılabilir ve aktif olarak bakımı yapılır. Derby proje sayfası. Ayrıca, Java DB adı altında Oracle'ın Java SE Geliştirme Kitinin (JDK) bir parçası olarak dağıtılmaktadır.

Empress Gömülü Veritabanı

Empress Software, Inc., geliştiricisi Empress Gömülü Veritabanı, 1979'da kurulmuş özel bir şirkettir. Empress Gömülü Veritabanı, tıbbi sistemler, ağ yönlendiricileri, nükleer santral monitörleri, uydu yönetimi dahil dağıtım ortamları ile küçükten büyüğe kuruluşlar tarafından uygulamalara yerleştirilmiş tam işlevli, ilişkisel bir veritabanıdır. sistemler ve güvenilirlik ve güç gerektiren diğer tümleşik sistem uygulamaları.[2] İmparatoriçe bir ASİT Uysal, SQL C ile veritabanı motoru, C ++ Java JDBC, ODBC, SQL, ADO.NET ve çekirdek seviyesi API'ler. Bu API'ler kullanılarak geliştirilen uygulamalar bağımsız ve / veya sunucu modlarında çalıştırılabilir. Empress Gömülü Veritabanı Linux üzerinde çalışır, Unix, Microsoft Windows ve gerçek zamanlı işletim sistemleri.

Genişletilebilir Depolama Motoru

ESE, Microsoft'un bir Dizinli Sıralı Erişim Yöntemi (ISAM) veri depolama teknolojisidir. ESE, özellikle Microsoft Exchange Server ve Active Directory'nin bir çekirdeğidir. Amacı, uygulamaların indeksli ve sıralı erişim yoluyla verileri depolamasına ve almasına izin vermektir. Windows Vista işletim sistemindeki Windows Mail ve Masaüstü Araması da sırasıyla dizinleri ve özellik bilgilerini depolamak için ESE'yi kullanır.

eXtremeDB

McObject LLC başlatıldı eXtremeDB gerçek zamanlı gömülü sistemler için sıfırdan tasarlanmış ilk bellek içi gömülü veritabanı olarak. İlk ürün kısa süre içinde eXtremeDB High Availability (HA) ile katıldı hata töleransı uygulamalar. Ürün ailesi artık 64 bit ve işlem kaydı sürümler ve bellek içi ve disk üzerinde veri depolamayı birleştiren hibrit eXtremeDB Fusion. McObject, 2008'de bir işletim sisteminde çalışmak üzere tasarlanmış ilk yerleşik DBMS olan eXtremeDB Kernel Mode'u tanıttı. çekirdek.[3] Günümüzde eXtremeDB, dünya çapında milyonlarca gerçek zamanlı ve gömülü sistemde kullanılmaktadır. McObject ayrıca şunları sunar: Perst, bir açık kaynak Java için nesne yönelimli gömülü veritabanı, Java ME, .AĞ, .NET Compact Framework ve Silverlight.

Firebird Gömülü

Firebird Embedded, ilişkisel bir veritabanı motorudur. InterBase'in açık kaynaklı bir çatalı, ASİT uyumludur, tetikleyicileri ve depolanan prosedürleri destekler ve Linux, OSX ve Windows sistemlerinde mevcuttur. Firebird'ün klasik ve süper sunucu sürümüyle aynı özelliklere sahiptir, iki veya daha fazla iş parçacığı (ve uygulama) Firebird 2.5'ten başlayarak aynı veritabanına aynı anda erişebilir. Dolayısıyla, Firebird gömülü, veritabanlarına erişen bir iş parçacığı istemci için yerel bir sunucu görevi görür (bu, ASP.NET web uygulamaları için düzgün çalıştığı anlamına gelir, çünkü orada, her kullanıcının kendi iş parçacığı vardır, bu da iki kullanıcının aynı veritabanına aynı anda erişebileceği anlamına gelir. zaman, ancak aynı iş parçacığında olmayacaklardı, çünkü ASP.NET her kullanıcı için yeni bir iş parçacığı açar). Standart Firebird API giriş noktalarını dışa aktarır. Firebird gömülü veritabanlarının ana avantajı, SQlite veya Access veritabanlarından farklı olarak, herhangi bir değişiklik yapılmadan tam bir Firebird sunucusuna takılabilmeleridir, ayrıca çoklu platformdur (Linux üzerinde çalışır, OS X tam ASP.NET Mono desteği ile)


H2

Java ile yazılmış Açık kaynak çok hızlı veritabanı motoru. Gömülü ve Sunucu modu, Kümeleme desteği, Google Uygulama Motoru. Şifrelenmiş veritabanı dosyalarını (AES veya XTEA) destekler. H2'nin geliştirilmesine Mayıs 2004'te başlandı, ancak ilk olarak 14 Aralık 2005'te yayınlandı. H2, çift lisanslıdır ve MPL 1.1'in (Mozilla Public License) değiştirilmiş bir sürümü veya (değiştirilmemiş) EPL 1.0 (Eclipse) altında kullanılabilir. Kamu Lisansı).

HailDB, önceden Gömülü InnoDB

HailDB, InnoDB Storage Engine'in bağımsız, gömülebilir bir şeklidir. HailDB'nin InnoDB Storage Engine ile aynı kod tabanına dayandığı göz önüne alındığında, aynı özelliklerin çoğunu içerir: yüksek performans ve ölçeklenebilirlik, multiversion eşzamanlılık kontrolü (MVCC), satır düzeyinde kilitleme, kilitlenme algılama, hata toleransı, otomatik çökme kurtarma vb. Ancak, gömülü motor MySQL'den tamamen bağımsız olduğu için ağ oluşturma, nesne düzeyinde izinler vb. Gibi sunucu bileşenlerinden yoksundur. MySQL sunucu ek yükü olan InnoDB, küçük bir ayak izine sahiptir ve yüksek performans ve eşzamanlılık gerektiren uygulamalara yerleştirmek için çok uygundur. Çoğu gömülü veritabanı sisteminde olduğu gibi, HailDB, SQL yerine ISAM benzeri bir C API ile erişilebilecek şekilde tasarlanmıştır (son derece basit bir SQL varyantı desteklenmektedir).[4]

Proje artık korunmuyor.[5]

HSQLDB

HSQLDB bir açık kaynaktır ilişkisel veritabanı yönetim sistemi gömülü uygulama ile aynı Java Virtual Machine'de çalışan BSD benzeri bir lisansla. HSQLDB, çeşitli bellek içi ve disk tabanlı tablo modlarını, Unicode ve SQL: 2016'yı destekler.

InfinityDB

InfinityDB Gömülü Java DBMS, sıralı bir hiyerarşik anahtar / değer deposudur. Artık bir Şifrelenmiş sürümü ve bir İstemci / Sunucu sürümü var. Çok çekirdekli hız patent başvurusu yapılmıştır. InfinityDB, anında kurulum ve sıfır yönetim için tek bir dosyada güvenli, işlemsel, sıkıştırıcı ve sağlamdır. API'ler arasında basit hızlı 'ItemSpace', ConcurrentNavigableMap görünümü ve JSON bulunur. Bir RemoteItemSpace, gömülü API'leri diğer db örneklerine şeffaf bir şekilde yeniden yönlendirebilir. İstemci / Sunucu, hafif bir Servlet sunucusu, web yöneticisi ve veritabanı taraması ve python için REST içerir.

Informix Dinamik Sunucu

Informix Dinamik Sunucusu (IDS), bir kurumsal sınıf gömülebilir veritabanı sunucusu, düşük ayak izi, programlanabilir ve otonom yetenekleri gibi gömülebilir özellikleri, yüksek kullanılabilirlik ve esnek çoğaltma özellikleri gibi kurumsal sınıf veritabanı özellikleriyle birleştirir.[6] IDS, IP telefon çağrı işleme sistemleri, satış noktası uygulamaları ve finansal işlem işleme sistemleri gibi derinlemesine gömülü senaryolarda kullanılır.

InterBase

InterBase, anahtar teslimi uygulamalara gömülebilen, IoT Ödüllü çapraz platform, Unicode etkin SQL veritabanı platformudur. Windows, Macintosh, Linux, Solaris, iOS ve Android platformları için kutudan çıkar çıkmaz SMP desteği ve diskte AES gücü 256bit şifreleme, SQL 92 ve ACID uyumluluğu ve desteği. Yüzlerce kullanıcıyı ve mobil uygulama geliştirmeyi destekleyen hem küçük-orta hem de büyük işletmeler için idealdir. InterBase Light, herhangi bir mobil cihazda kullanılabilen ve mobil uygulamalar için ideal olan ücretsiz bir versiyondur. Kuruluşlar, değişiklik yönetimi ve güvenlik gereksinimleri arttıkça ücretli bir sürüme geçebilirler. InterBase, savunma, hava sahası, petrol ve gaz ve imalat endüstrilerinde yüksek oranda benimsenmiştir.

LevelDB

LevelDB bir sipariştir anahtar / değer deposu tarafından yaratıldı Google hafif bir uygulama olarak Buyuk masa depolama tasarımı. Bir kitaplık olarak (LevelDB'yi kullanmanın tek yolu budur), yerel API'si C ++ 'dır. Ayrıca çoğu işlevsellik için resmi C sarmalayıcıları içerir. Üçüncü taraf API sarmalayıcıları Python, PHP, Git (saf Go LevelDB uygulaması var ama hala devam ediyor), Node.js ve Hedef C. Google, LevelDB'yi şu şekilde dağıtır: Yeni BSD Lisansı.

LMDB

Lightning Bellek Eşlemeli Veritabanı (LMDB) bir bellek eşlemeli anahtar-değer veritabanı için OpenLDAP Proje. C ile yazılmıştır ve API, Berkeley DB API, çok basitleştirilmiş olsa da. Kitaplık son derece kompakttır, 40KB'nin altında x86 nesne kodu derlenir, bozulmaya karşı dayanıklıdır ve büyüklük sıraları gibi benzer kitaplıklardan daha hızlı, daha sağlam, daha ölçeklenebilir ve daha verimlidir. Berkeley DB, LevelDB, vb. Kütüphane, B + ağaçlarını multiversion eşzamanlılık kontrolü (MVCC), Tek seviyeli mağaza, Yazarken kopyala ve tam sağlar ASİT kilitlenmeyen işlemler. Kitaplık, yüksek okuma eşzamanlılığı için optimize edilmiştir; okuyucuların hiçbir kilide ihtiyacı yoktur. Okuyucular yazarları engellemez ve yazarlar da okuyucuları engellemez, bu nedenle okuma performansı, rastgele birçok iş parçacığı ve CPU üzerinde mükemmel doğrusal olarak ölçeklenir. Üçüncü taraf sarmalayıcılar C ++, Erlang ve Python. LMDB, OpenLDAP Projesi tarafından OpenLDAP Kamu Lisansı altında dağıtılır. 2013 itibariyle OpenLDAP Projesi, Berkeley DB'nin kullanımını LMDB lehine kullanımdan kaldırıyor.

Mimer SQL

Tescilli Mimer SQL veritabanının tümleşik bir sıfır bakım sürümü mevcuttur.

MySQL Gömülü Sunucu Kitaplığı

libmysqld, MySQL Gömülü Sunucu Kitaplığı sağlar özelliklerin çoğu normal MySQL'in bir istemci süreci bağlamında çalıştırılabilen bağlanabilir bir kitaplık olarak. Başlatma işleminden sonra istemciler, ayrı bir MySQL sunucusuyla konuşurken olduğu gibi aynı C API çağrılarını kullanabilir, ancak daha az iletişim ek yükü ile ve ayrı bir veritabanı işlemine gerek kalmadan.

NexusDB

NexusDB, ticari halefidir. FlashFiler artık açık kaynak olan veritabanı. Tam veritabanı işlevselliğine sahip bağımsız yürütülebilir dosyalar oluşturmak için her ikisi de Delphi uygulamalarına gömülebilir.

Oracle Berkeley DB

Adından da anlaşılacağı gibi, Oracle’ın gömülü veritabanı aslında Berkeley DB Oracle'ın Sleepycat Software'den satın aldığı. Başlangıçta Kaliforniya Üniversitesi'nde geliştirildi.[7] Berkeley DB hızlı, açık kaynaklı bir gömülü veritabanıdır ve Linux ve BSD Unix işletim sistemleri, Apache Web sunucusu, OpenOffice verimlilik paketi dahil olmak üzere birçok iyi bilinen açık kaynaklı üründe kullanılmaktadır. Bununla birlikte, son yıllarda birçok tanınmış proje, LMDB çünkü temel senaryolarda Berkeley DB'den daha iyi performans gösteriyor "Az ama öz "[netleştirme gerekli ] tasarım, ayrıca lisans değişikliği nedeniyle. [8]

Raima Veritabanı Yöneticisi

Raima Veritabanı Yöneticisi, tarafından üretilen Raima, gömülü veritabanı olarak kategorize edilen ilk veritabanı yönetim sistemlerinden biriydi. Raima'nın tanımına göre ürün, gömülü iki anlamda: birincisi, bir uygulamanın içine gömülüdür, uygulamanın bir uzantısı haline gelir ve ikincisi, küçük ayak izi ve verimli çalışması nedeniyle onu gömülü bilgisayar / işletim sistemi veya gerçek zamanlı ortamlarda kullanmak mümkündür. API'leri (C / C ++, SQL, JDBC, ODBC, ADO.NET ve RESTful için), gömülü ortamların sınırlı kaynaklarını desteklemek için tasarlanmıştır. RDM Embedded, ilk sürümünden bu yana sürekli olarak gelişmektedir ve şu anda sürüm 14.2 olarak piyasaya sürülmektedir.

RocksDB

RocksDB, oluşturulduğu yer Facebook çatal olarak başladı LevelDB.[9] Performansa odaklanır, özellikle SSD'ler. Dahil olmak üzere birçok özellik ekler işlemler,[10] yedekler,[11] anlık görüntüler,[12] çiçeklenme filtreleri,[13] sütun aileleri,[14] vade,[15] özel birleştirme operatörleri,[16] daha ayarlanabilir sıkıştırma,[17] istatistik koleksiyonu,[18] ve jeo-uzamsal indeksleme.[19] Aşağıdakiler dahil diğer birkaç veritabanında depolama motoru olarak kullanılır. ArangoDB,[20] Ceph,[21] HamamböceğiDB,[22] MongoRocks,[23] MyRocks,[24] Rocksandra,[25] ve TiKV.[26]

solidDB

solidDB, hibrit bir disk üstü / bellek içi, ilişkisel veritabanıdır ve genellikle telekomünikasyon ekipmanında, ağ yazılımında ve benzer sistemlerde gömülü bir sistem veritabanı olarak kullanılır. Bellek içi veritabanı teknolojisi, mikrosaniye cinsinden ölçülen yanıt süreleriyle saniyede on binlerce işlemin iş hacmini elde etmek için kullanılır. Yüksek kullanılabilirlik seçeneği, verilerin her zaman senkronize edilmiş iki kopyasını tutar. Sistem arızası durumunda, uygulamalar solidDB'ye erişimi bir saniyeden daha kısa sürede veri kaybı olmadan kurtarabilir.

SQLite

SQLite, bağımsız, sunucusuz, sıfır konfigürasyonlu, işlemsel SQL veritabanı motorunu uygulayan bir yazılım kitaplığıdır. SQLite, dünyadaki en yaygın kullanılan SQL veritabanı motorudur. SQLite için kaynak kodu, başlıca C, kamu malıdır. Hem yerel bir C kitaplığı hem de veritabanı için basit bir komut satırı istemcisi içerir. Birkaç işletim sistemine dahildir; aralarında Android, FreeBSD, iOS, OS X ve Windows 10.[27]

SQL Server Compact

Microsoft SQL Server Compact, çok işlemli bağlantılar, T-SQL, herhangi bir arka uç veritabanıyla senkronize etmek için ADO.NET Sync Hizmetleri, SQL Sunucusu ile Birleştirme Çoğaltma, Programlama API: LINQ to SQL, LINQ gibi çok çeşitli özelliklere sahip gömülü bir veritabanıdır. Varlıklara, ADO.NET. Ürün hem Masaüstü hem de Mobil Windows platformlarında çalışır. Uzun süredir piyasada olup, birçok işletme tarafından üretim yazılımlarında kullanılmaktadır (Durum çalışmaları ). Ürün, birden çok yeniden markalamadan geçti ve şu gibi birden çok adla biliniyordu: SQL CE, SQL Server CE, SQL Server Mobile, SQL Mobile.

Ayrıca bakınız

Referanslar

  1. ^ Mezarlar, Steve. "Gömülü Sistemler İçin COTS Veritabanları" Arşivlendi 2007-11-14 Wayback Makinesi, Gömülü Hesaplama Tasarımı dergisi, Ocak 2007. 13 Ağustos 2008'de erişildi.
  2. ^ Mullins, Craig. "Empress Etkili Bir Gömülü Veritabanı Çözümü Sunuyor", 2005. Erişim tarihi: 2008-12-09
  3. ^ Gorine, Andrei ve Krivolapov, Alexander. "Çekirdek Modu Veritabanları: Yüksek Performanslı Uygulamalar İçin Bir DBMS Teknolojisi", Dr. Dobb's Journal, Nisan 2008. Erişim tarihi 13 Ağustos 2008.
  4. ^ HailDB ana sayfası
  5. ^ HailDB'yi kapatma, Stewart Smith 19 Ağustos 2015 tarihinde, HailDB
  6. ^ "Informix Dinamik Sunucusunu Yerleştirme", Erişim tarihi: 30 Ağustos 2009.
  7. ^ Görmek Berkeley DB
  8. ^ Niccolai, James. "Güncelleme: Oracle, Sleepycat açık kaynak veritabanı satıcısını satın alıyor" Arşivlendi 2008-06-13 Wayback Makinesi, "InfoWorld", 2006-02-14. Erişim tarihi: 12 Haziran 2008.
  9. ^ "RocksDB Temelleri". Alındı 2018-07-19.
  10. ^ "RocksDB işlemleri". GitHub. Alındı 2016-04-04.
  11. ^ "RocksDB nasıl yedeklenir?". Alındı 2017-07-19.
  12. ^ "Kontrol noktaları". Alındı 2017-07-19.
  13. ^ "RocksDB çiçek filtreleri". GitHub. Alındı 2016-04-04.
  14. ^ "RocksDB'deki sütun aileleri". GitHub. Alındı 2016-04-04.
  15. ^ "RocksDB TTL desteği". GitHub. Alındı 2016-04-04.
  16. ^ "RocksDB birleştirme operatörü". GitHub. Alındı 2016-04-04.
  17. ^ "Evrensel sıkıştırma". GitHub. Alındı 2016-04-04.
  18. ^ "RocksDB performans içeriği ve IO istatistikleri bağlamı". GitHub. Alındı 2016-04-04.
  19. ^ "RocksDB'de konumsal indeksleme". Rocksdb.org. Alındı 2018-07-19.
  20. ^ "Yeni RocksDB ve MMFiles depolama motorlarının karşılaştırılması". Alındı 2018-07-19.
  21. ^ "Depolama Aygıtları - Ceph Belgeleri". Alındı 2018-07-19.
  22. ^ "Depolama Katmanı - CockroachDB". Alındı 2018-07-19.
  23. ^ "mongodb-partnerler / mongo-rock: Rocks depolama motoru için MongoDB depolama entegrasyon katmanı". Alındı 2018-07-19.
  24. ^ "MyRocks - MySQL ile bir RocksDB depolama motoru". Alındı 2018-07-19.
  25. ^ "Apache Cassandra kuyruk gecikmesinde 10 kat azalma açık kaynaklı". Alındı 2018-07-19.
  26. ^ "TiKV'de RocksDB - PingCAP". Alındı 2018-07-19.
  27. ^ Cevap, Usman (29 Ekim 2015). "Windows 10'da SQLite ile Yeni Bir Zihniyet Göndermek". Microsoft. Arşivlenen orijinal 2016-01-31 tarihinde. Alındı 6 Mart 2016.