هذه المقالة يتيمة. ساعد بإضافة وصلة إليها في مقالة متعلقة بها
تحتوي هذه المقالة ترجمة آلية، يلزم إزالتها لتحسين المقالة.

بروتوكول التخزين المؤقت

من أرابيكا، الموسوعة الحرة
(بالتحويل من بروتوكول بفر)
اذهب إلى التنقل اذهب إلى البحث
بروتوكول التخزين المؤقت

بروتوكول التخزين المؤقت (بالإنجليزية: Protocol Buffers)‏ اختصارًا (Protobuf) هي تنسيق بيانات حُر، ومفتوح المصدر يعمل على عدة منصات يُستخدم في إجراء تسلسل للبيانات المهيكلة. يفيد في تطوير البرامج للتواصل مع بعضها البعض عبر شبكة أو لتخزين البيانات. تتضمن الطريقة لغة وصف الواجهة التي تصف بنية بعض البيانات والبرنامج الذي يولد شفرة المصدر من هذا الوصف لتوليد أو تحليل دفق البايت الذي يمثل البيانات المهيكلة.

ملخص

طورت Google Protocol Buffers للاستخدام الداخلي وقدمت منشئ رمز للغات متعددة بموجب ترخيص مفتوح المصدر (انظر أدناه).

أكدت أهداف تصميم بروتوكول التخزين المؤقت على البساطة والأداء. على وجه الخصوص، تم تصميمه ليكون أصغر وأسرع من XML .[1] تُستخدم بروتوكول التخزين المؤقت على نطاق واسع في Google لتخزين وتبادل جميع أنواع المعلومات المنظمة. تعمل هذه الطريقة كأساس لنظام استدعاء إجراء بعيد مخصص (RPC) يتم استخدامه تقريبًا لجميع الاتصالات بين الأجهزة في Google.[2]

تشبه بروتوكول التخزين المؤقت المؤقتة Apache Thrift (التي يستخدمها Facebook ، وEvernote)، أو Ion (التي أنشأتها Amazon)، أو بروتوكولات Microsoft Bond ، وتقدم أيضًا حزمة بروتوكول RPC ملموسة لاستخدامها في خدمات محددة تسمى gRPC .[3]

يتم وصف هياكل البيانات والخدمات في ملف تعريف .proto (.proto) ويتم تجميعها باستخدام protoc . ينشئ هذا التجميع رمزًا يمكن استدعاؤه بواسطة مرسل أو متلقي هياكل البيانات هذه. على سبيل المثال، يتم إنشاء example.pb.cc و example.pb.h example.proto . يعرّفون فئات ++C لكل رسالة وخدمة في example.proto .

من الناحية القانونية، يتم تسلسل الرسائل إلى تنسيق سلكي ثنائي يكون مضغوطًا ومتوافقًا مع الأمام والخلف، ولكنه لا يصف نفسه (أي، لا توجد طريقة لمعرفة الأسماء أو المعنى أو أنواع البيانات الكاملة للحقول بدون مواصفات خارجية). لا توجد طريقة محددة لتضمين أو الإشارة إلى مثل هذه المواصفات الخارجية (المخطط) داخل ملف Protocol Buffers. يشتمل التطبيق المدعوم رسميًا على تنسيق تسلسل ASCII ، [4] ولكن هذا التنسيق - على الرغم من أنه يصف ذاتيًا - يفقد سلوك التوافق الأمامي والخلفي، وبالتالي لا يعد اختيارًا جيدًا للتطبيقات بخلاف التصحيح.

على الرغم من أن الغرض الأساسي للمخازن المؤقتة للبروتوكول هو تسهيل الاتصال بالشبكة، إلا أن بساطتها وسرعتها تجعل من المخازن المؤقتة للبروتوكول بديلاً لفئات وهياكل ++C المتمحورة حول البيانات، خاصةً حيث قد تكون هناك حاجة للتشغيل البيني مع لغات أو أنظمة أخرى في المستقبل.

مثال

مخطط لاستخدام معين للمخازن المؤقتة للبروتوكول يربط أنواع البيانات بأسماء الحقول، باستخدام الأعداد الصحيحة لتحديد كل حقل. تحتوي بيانات المخزن المؤقت للبروتوكول على الأرقام فقط، وليس أسماء الحقول، مما يوفر بعض توفير عرض النطاق الترددي / التخزين مقارنة بالأنظمة التي تتضمن أسماء الحقول في البيانات.

//polyline.proto
syntax = "proto2";

message Point {
  required int32 x = 1;
  required int32 y = 2;
  optional string label = 3;
}

message Line {
  required Point start = 1;
  required Point end = 2;
  optional string label = 3;
}

message Polyline {
  repeated Point point = 1;
  optional string label = 2;
}

تحدد رسالة «النقطة» عنصري بيانات إلزاميين، x و y . تسمية عنصر البيانات اختيارية. كل عنصر بيانات له علامة. يتم تحديد العلامة بعد علامة التساوي. على سبيل المثال، x لديه العلامة 1.

توضح الرسائل "Line" و "Polyline"، اللتان تستخدمان Point ، كيفية عمل التركيب في بروتوكول التخزين المؤقت. يحتوي Polyline على حقل متكرر يتصرف مثل المتجه.

يمكن بعد ذلك تجميع هذا المخطط لاستخدامه من قبل لغة برمجة واحدة أو أكثر. توفر Google protoc يسمى protoc والذي يمكنه إنتاج مخرجات لـ ++C أو Java أو Python. تتوفر برامج التحويل البرمجي للمخططات الأخرى من مصادر أخرى لإنشاء مخرجات تعتمد على اللغة لأكثر من 20 لغة أخرى.[5]

على سبيل المثال، بعد إنتاج إصدار ++ C من مخطط المخزن المؤقت للبروتوكول أعلاه، يمكن لملف شفرة المصدر C ++ ، polyline.cpp ، استخدام كائنات الرسالة على النحو التالي:

// polyline.cpp
#include "polyline.pb.h" // generated by calling "protoc polyline.proto"

Line* createNewLine(const std::string& name) {
  // create a line from (10, 20) to (30, 40)
  Line* line = new Line;
  line->mutable_start()->set_x(10);
  line->mutable_start()->set_y(20);
  line->mutable_end()->set_x(30);
  line->mutable_end()->set_y(40);
  line->set_label(name);
  return line;
}

Polyline* createNewPolyline() {
  // create a polyline with points at (10,10) and (20,20)
  Polyline* polyline = new Polyline;
  Point* point1 = polyline->add_point();
  point1->set_x(10);
  point1->set_y(10);
  Point* point2 = polyline->add_point();
  point2->set_x(20);
  point2->set_y(20);
  return polyline;
}

اللغات البرمجية المدعومة

يوفر Protobuf 2.0 مولد أكواد لـ ++C وJava و#C و [6] وPython .[7]

يوفر Protobuf 3.0 مولد أكواد لـ ++ C ، وJava (بما في ذلك JavaNano ، وهي لغة مخصصة للبيئات منخفضة المواردوPython ، وGo ، وRuby ، وObjective-C ، و#C .[8] كما أنه يدعم JavaScript منذ 3.0.0-beta-2.[9]

تتوفر تطبيقات الطرف الثالث أيضًا لـ Ballerina ، [10] C ، [11][12] C ++ ، [13] Dart ، Elixir ، [14][15] Erlang ، [16] Haskell ، [17] JavaScript ، [18] Perl ، PHP ، R ، [19] رست، [20][21][22] سكالا، سويفت، [23] جوليا [24] ونيم.[25]

انظر أيضًا

المراجع

  1. ^ Eishay Smith. "jvm-serializers Benchmarks". مؤرشف من الأصل في 2021-03-23. اطلع عليه بتاريخ 2010-07-12.
  2. ^ Kenton Varda. "A response to Steve Vinoski". مؤرشف من الأصل في 2020-11-09. اطلع عليه بتاريخ 2008-07-14.
  3. ^ "grpc". grpc.io. مؤرشف من الأصل في 2021-11-14. اطلع عليه بتاريخ 2016-10-02.
  4. ^ "text_format.h - Protocol Buffers - Google Code". مؤرشف من الأصل في 2012-02-25. اطلع عليه بتاريخ 2012-03-02.
  5. ^ ThirdPartyAddOns - protobuf - Links to third-party add-ons. نسخة محفوظة 2015-03-18 على موقع واي باك مشين.
  6. ^ "Protocol Buffers in C#". Code Blockage. مؤرشف من الأصل في 2021-11-15. اطلع عليه بتاريخ 2017-05-12.
  7. ^ "Protocol Buffers Language Guide". Google Developers. مؤرشف من الأصل في 2021-11-01. اطلع عليه بتاريخ 2016-04-21.
  8. ^ "Language Guide (proto3) | Protocol Buffers". Google Developers (بEnglish). Archived from the original on 2021-11-10. Retrieved 2020-08-09.
  9. ^ "Release Protocol Buffers v3.0.0-beta-2 · protocolbuffers/protobuf". GitHub (بEnglish). Archived from the original on 2020-11-22. Retrieved 2020-08-09.
  10. ^ "Ballerina - GRPC". مؤرشف من الأصل في 2021-11-15.
  11. ^ "Nanopb - protocol buffers with small code size". مؤرشف من الأصل في 2021-09-30. اطلع عليه بتاريخ 2017-12-12.
  12. ^ "Protocol Buffers implementation in C". مؤرشف من الأصل في 2021-08-01. اطلع عليه بتاريخ 2017-12-12.
  13. ^ "Embedded Proto - Protobuf for microcontrollers". مؤرشف من الأصل في 2021-10-31. اطلع عليه بتاريخ 2021-08-15.
  14. ^ "Protox". 25 أكتوبر 2021. مؤرشف من الأصل في 2020-12-01.
  15. ^ "Protobuf-elixir". 26 أكتوبر 2021. مؤرشف من الأصل في 2021-07-15.
  16. ^ "Tomas-abrahamsson/GPB". 19 أكتوبر 2021. مؤرشف من الأصل في 2020-10-30.
  17. ^ "Proto-lens". 16 أكتوبر 2021. مؤرشف من الأصل في 2021-01-18.
  18. ^ "Protocol Buffers for JavaScript". github.com. مؤرشف من الأصل في 2021-11-12. اطلع عليه بتاريخ 2016-05-14.
  19. ^ "Rprotobuf/SRC at master · eddelbuettel/Rprotobuf". مؤرشف من الأصل في 2021-11-15.
  20. ^ "Rust-protobuf". 26 أكتوبر 2021. مؤرشف من الأصل في 2021-07-30.
  21. ^ "PROST!". 21 أغسطس 2021. مؤرشف من الأصل في 2021-10-13.
  22. ^ "Quick-protobuf". 12 أكتوبر 2021. مؤرشف من الأصل في 2021-01-03.
  23. ^ "Swift Protobuf". 26 أكتوبر 2021. مؤرشف من الأصل في 2021-11-12.
  24. ^ "ThirdPartyAddOns - protobuf - Links to third-party add-ons. - Protocol Buffers - Google's data interchange format - Google Project Hosting". مؤرشف من الأصل في 2015-03-18. اطلع عليه بتاريخ 2012-11-07.
  25. ^ "Protobuf implementation in pure Nim that leverages the power of the macro system to not depend on any external tools". GitHub (بEnglish). 21 Oct 2021. Archived from the original on 2020-11-18.


روابط خارجية