مانگودی‌بی

از ویکی‌پدیا، دانشنامهٔ آزاد
(تغییرمسیر از مونگودی‌بی)
پرش به: ناوبری، جستجو
مانگودی‌بی
MongoDB Logo.png
نویسنده(های) اصلی 10gen
توسعه‌دهنده(ها) 10gen
انتشار پایدار ۲.۴.۸ / ۰۱ نوامبر ۲۰۱۳؛ ۱۷۰ روز پیش
نوشته شده به سی++
سیستم‌عامل چندسکویی
گونه پایگاه داده‌های سندگرا
پروانه گنو آجی‌پی‌ال نسخه ۳.۰ (ابزارهای ارتباط با این پایگاه داده تحت مجوز آپاچی هستند)
استفاده پایگاه داده
وب‌گاه http://www.mongodb.org/

مانگودی‌بی (به انگلیسی: MongoDB (برگرفته از «humongous») یک پایگاه داده‌های سند-گرای متن‌باز، کارا، مقیاس‌پذیر، بدون نیاز به طرح‌بندی اولیه نوشته شده در زبان برنامه‌نویسی سی++ است.[۱]

هدف مانگودی‌بی پرکردن فاصلهٔ ذخیره‌بندی‌های کلید/مقداری—که سریع و مقیاس پذیر هستند— و سامانه‌های سنتی مدیریت پایگاه داده رابطه‌ای—که درخواست‌های غنی و عملکرد عمیقی دارند— بوده‌است. مانگودی‌بی برای رفع مشکلاتی طراحی شده که با پایگاه داده‌های رابطه‌ای به سادگی رفع نمی‌شوند؛ برای مثال اگر پایگاه داده کارسازهای زیادی را دربرگیرد.

مانگودی‌بی به جای اینک همانند پایگاه های داده‌های رابطه‌ای کلاسیک داده‌ها را در جداول ذخیره کند، داده‌های ساختاریافته را در اسنادی با قالبی شبیه به جی‌سون (مانگودی‌بی این قالب را بی‌سون(BSON) می‌نامد) ذخیره‌سازی می کند، و بدین ترتیب یکپارچه‌سازی داده‌ها را در برخی اقسام برنامه‌های کاربردی آسان‌تر و سریع‌تر می کند.

تاریخچه[ویرایش]

توسعه مانگودی‌بی در 10gen در سال ٢٠٠٧، هنگامی که شرکت در حال ایجاد یک بستر به عنوان سرویس مشابه با ویندوز آژور یا گوگل اپ انجین بود، آغاز شد. در سال ٢٠٠٩ مانگودی‌بی عنوان یک محصول مستقل و متن باز با مجوز آجی‌پی‌ال ارائه شد.

در ماه مارس ٢٠١٠، با شروع از نسخه ١.۴، مانگودی‌بی قابل استفاده در خط تولید شناخته شد.

مجوز و پشتیبانی[ویرایش]

مانگودی‌بی به صورت آزاد تحت پروانه عمومی همگانی آفرو در دسترس است. درایور زبان‌های مختلف تحت پروانه آپاچی در دسترس هستند. علاوه بر این، 10gen پروانه‌های تجاری برای مانگودی‌بی ارائه می دهد.

نکات برجسته اصلی[ویرایش]

در زیر خلاصه ای از برخی از ویژگی های اصلی آمده است:

  • پرس و جوهای تک کاره: مانگودی‌بی از جستجو بر اساس فیلد، پرس و جوهای بازه‌ای، و جستجوهای با عبارت منظم پشتیبانی می کند.
  • فهرست بندی: هر فیلدی در مانگودی‌بی قابل فهرست بندی است. فهرست های ثانویه نیز موجود هستند.
  • انعکاس: مانگودی‌بی از انعکاس تابع-متبوع (master-slave) پشتیبانی می کند. هر متبوعی قادر به انجام نوشتن ها و خواندن ها است. یک تابع داده ها را از متبوع رونوشت می کند و تنها برای خواندن ها و یا پشتیبانی به کار می رود. تابع ها توانایی انتخاب متبوع جدید در صورت از کار افتادن متوبع فعلی را دارند.
  • توازن بار: مانگودی‌بی با استفاده از بخش بندی (sharding) قابل مقیاس پذیری به صورت افقی است. شخص توسعه دهنده کلید بخش بندی را انتخاب می کند که مشخص می کند داده در یک مجموعه چگونه توزیع خواهد شد. داده بر مبنای کلید بخش بندی به بازه های مختلف تکه تکه می شود و در بخش های مختلف توزیع می شود. (هر بخش یک متبوع با یک یا چند تابع است).
  • ذخیره‌سازی فایل: از مانگودی‌بی می توان به عنوان یک سیستم فایل استفاده کرد و از مزایای توازن بار و انعکاس داده در چندین ماشین برای ذخیره فایل های استفاده کرد.
  • تجمیع: برای پردازش دسته ای داده های و عملیات تجمیع می توان از نگاشت‌کاهش استفاده کرد.
  • اجرای جاواسکریپت سمت سرور
  • مجموعه‌های دربسته

برای اطلاعات بیشتر درباره موارد بالا به کتابچه‌ی توسعه‌دهندگان مانگودی‌بی مراجعه کنید.

موارد استفاده و استقرار[ویرایش]

با توجه به مقاله «موارد استفاده» در وب سایت مانگودی‌بی، مانگودی‌بی برای موارد زیر مناسب است:

  • بایگانی و ثبت رخداد ها
  • سامانه های مدیریت محتوا و سندها
  • تجارت الکترونیکی
  • بازی سازی
  • مساله های حجم بالا
  • موبایل
  • نگهداری داده در یک وب سایت
  • پروژه های که از روش های توسعه چابک استفاده می کنند
  • آمار و تحلیل های بلادرنگ

شرکت هایی که از مانگودی‌بی استفاده میکنند[ویرایش]

لیست شرکت هایی که از مانگودی‌بی استفاده می‌کنند شامل موارد زیر است:

برای لیست کامل و ارجاع به هر مورد استفاده خاص به مقاله "Production Deployments" در وب‌سایت مانگودی‌بی مراجعه کنید. [۲]

مجموعه‌ها و اسناد[ویرایش]

مانگودی‌بی داده‌های دارای ساختار را در اسنادی با قالبی شبیه جی‌سون (JSON) به اسم بی‌سون (BSON) ذخیره می کند. در مانگودی‌بی داده‌ها دارای طرح از پیش تعیین شده نیستند.

یک عنصر داده سند (document) نامید می شود، و سندها در مجموعه‌ها (collection) ذخیره می‌شوند. هر مجموعه ممکن است دارای هر تعداد از سندها باشد.

در مقایسه با پایگاه‌های داده‌ی رابطه‌ای، می‌توان گفت که مجموعه‌ها شبیه جدول‌ها، و سندها شبیه رکوردها هستند. ولی یک تفاوت بزرگ وجود دارد: تمام رکورد در یک جدول باید دارای فیلدهای یکسان و با ترتیب یکسان باشند، اما هر سند در یک مجموعه ممکن است دارای فیلدهای متفاوتی از سندهای دیگر باشد. تنها الزام برای طرح‌های سندها (علاوه بر محدودیت‌های اندازه) این است که هر سندی باید دارای فیلد '_id' با مقدار منحصر به فرد و غیر آرایه‌ای باشد.

یک جدول در پایگاه داده رابطه‌ای را می توان به صورت زیر نشان داد:

Last Name First Name Date of Birth
DUMONT Jean 01-22-1963
PELLERIN Franck 09-19-1983
GANNON Dustin 11-12-1982
هر رکورد در یک جدول دارای فیلدهای یکسان و با ترتیب یکسان است.

در مقابل، یک مجموعه مانگودی‌بی شبیه زیر است:

{
    "_id": ObjectId("4efa8d2b7d284dad101e4bc9"),
    "Last Name": "DUMONT",
    "First Name": "Jean",
    "Date of Birth": "01-22-1963"
},
{
    "_id": ObjectId("4efa8d2b7d284dad101e4bc7"),
    "Last Name": "PELLERIN",
    "First Name": "Franck",
    "Date of Birth": "09-19-1983",
    "Address": "1 chemin des Loges",
    "City": "VERSAILLES"
}
هر سند در یک مجموعه مانگودی‌بی ممکن است فیلدهای متفاوتی داشته باشد.

در هر لحظه می توان در یک سند، فیلد جدید اضافه کرد یا فیلدهای قبلی را تغییر نام داد یا حذف کرد. هیچ طرح پیش تعریف شده‌ای وجود ندارد. ساختار سند بسیار ساده است: از فرمت جی‌سون پیروی می‌کند، و شامل دنباله‌ای از جفت‌های کلید-مقدار است. بنابراین هر سند معادل آنچه در زبان‌های برنامه‌نویسی مختلف آرایه انجمنی، نگاشت، دیکشنری، یا جدول هش نامیده می‌شود است. کلید در جفت کلید-مقدار نام فیلد است، و مقدار در جفت کلید-مقدار محتوای فیلد است. کلید و مقدار با یک علامت ":" از هم جدا می‌شوند.

یک مقدار می‌تواند عدد، رشته، صحیح و ناصحیح، داده‌های دودویی مانند تصویر، آرایه‌ای از مقادیر (که هر عضو می‌تواند از نوع متفاوتی باشد)، و یا یک زیرسند کامل باشد:

{
    "_id": ObjectId("4efa8d2b7d284dad101e4bc7"),
    "Last Name": "PELLERIN",
    "First Name": "Franck",
    "Date of Birth": "09-19-1983",
    "phoneNumber": [
        {
            "type": "home",
            "number": "212 555-1234"
        },
        {
            "type": "fax",
            "number": "646 555-4567",
            "verified":  false
        }
    ],
    "Address": {
        "Street": "1 chemin des Loges",
        "City": "VERSAILLES"
    },
    "Months at Present Address":  37
}

در اینجا مشاهده می کنیم که فیلد "Address" شامل یک زیر سند است که دارای دو فیلد "Street" و "City" است.

زبانهای پشتیبانی شده[ویرایش]

مانگودی‌بی راه‌اندازهای زیر را به طور رسمی دارد:

زبان برنامه نویسی تحت وب اوپا(Opa) نیز دارای پشتیبانی توکار از مانگودی‌بی است، که به صورت کامل با زبان یکپارچه شده است، و لایه ی امنیت انواع را بر روی مانگودی‌بی ارایه می دهد.

در ضمن تعداد زیادی راه انداز غیر رسمی برای زبان‌های کلدفیوژن, دلفی, لوا, روبی, اسمال‌تاک و سایر زبان‌ها وجود دارد.

ابزارهای مدیریتی و گرافیکی[ویرایش]

ابزارهای مانگودی‌بی[ویرایش]

پس از نصب مانگودی‌بی، دستورهای زیر در دسترس هستند:

  • mongo: شل تعاملی که برای مشاهده، افزودن، تغییر، و حذف داده در پایگاه‌های داده، و همچنین مشاهده‌ی اطلاعات انعکاس، تنظیم بخش‌بندی، خاموش کردن سرورها، اجرای جاوااسکریپت، ... به کار می‌رود.
  • mongostat: برای مشاهده‌ی فهرست خلاصه آمار وضعیت نمونه‌ی در حال اجرای مانگودی‌بی به کار می‌رود: چه تعداد عملیات درج، تغییر، حذف، پرس و جو انجام شده است، و همچنین درصد زمانی که پایگاه داده در آن قفل بوده است و مقدار حافظه‌ی مصرف شده توسط پایگاه داده.
  • mongotop: برای پیگری مدت زمانی که مانگودی‌بی صرف خواندن و نوشتن داده می‌کند به کار می‌رود.
  • mongoimport، mongoexport: برای تبدیل مجموعه‌ها به و بازیابی مجموعه‌ها از قالب‌های JSON، CSV، یا TSV به کار می‌روند.
  • mongodump، mongorestore: برای تهیه‌ی نسخه‌ی پشتیبان و بازیابی از نسخه‌ی پشتیبان به کار می‌روند.

پانویس[ویرایش]

منابع[ویرایش]

پیوند به بیرون[ویرایش]