انتقل إلى المحتوى

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

هذه المقالة يتيمة. ساعد بإضافة وصلة إليها في مقالة متعلقة بها
تحتوي هذه المقالة ترجمة آلية، يلزم إزالتها لتحسين المقالة.
من ويكيبيديا، الموسوعة الحرة
بروتوكول التخزين المؤقت
امتداد الملف
proto، txtpb[1]، binpb[2]الاطلاع ومراجعة البيانات على ويكي داتا
صيغة وسائط الإنترنت
application/protobuf — application/vnd.google.protobufالاطلاع ومراجعة البيانات على ويكي داتا
المطور
أول إصدار
7 يوليو 2008الاطلاع ومراجعة البيانات على ويكي داتا
موقع الويب

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

ملخص

[عدل]

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

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

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

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

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

على الرغم من أن الغرض الأساسي للمخازن المؤقتة للبروتوكول هو تسهيل الاتصال بالشبكة، إلا أن بساطتها وسرعتها تجعل من المخازن المؤقتة للبروتوكول بديلاً لفئات وهياكل ++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 لغة أخرى.[11]

على سبيل المثال، بعد إنتاج إصدار ++ 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 و [12] وPython .[13]

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

تتوفر تطبيقات الطرف الثالث أيضًا لـ Ballerina ، [16] C ، [17][18] C ++ ، [19] Dart ، Elixir ، [20][21] Erlang ، [22] Haskell ، [23] JavaScript ، [24] Perl ، PHP ، R ، [25] رست، [26][27][28] سكالا، سويفت، [29] جوليا [30] ونيم.[31]

انظر أيضًا

[عدل]

المراجع

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


روابط خارجية

[عدل]