CrUX ইতিহাস API

CrUX History API পৃষ্ঠা এবং মূল গ্রানুলারিটিতে ছয় মাসের ঐতিহাসিক বাস্তব-ব্যবহারকারীর অভিজ্ঞতার ডেটাতে কম লেটেন্সি অ্যাক্সেস দেয়।

এটা চেষ্টা করুন!

সাধারণ ব্যবহারের ক্ষেত্রে

CrUX History API একটি নির্দিষ্ট URI-এর জন্য ঐতিহাসিক ব্যবহারকারীর অভিজ্ঞতা মেট্রিক্সের অনুসন্ধানের জন্য অনুমতি দেয় যেমন " https://example.com মূলের জন্য ঐতিহাসিক UX প্রবণতা পান।"

হিস্টোরি এপিআই দৈনিক CrUX API- এর মতো একই কাঠামো অনুসরণ করে, ব্যতীত মানগুলি একটি অ্যারেতে দেওয়া হয়, এবং কীগুলিকে বহুবচন নামের লেবেল করা হয় (উদাহরণস্বরূপ, histogram পরিবর্তে histogramTimeseries , অথবা p75 এর পরিবর্তে p75s )।

CrUX API কী

দৈনিক API-এর মতো, CrUX History API ব্যবহার করার জন্য Chrome UX Report API ব্যবহারের জন্য একটি Google Cloud API কী ব্যবস্থা করা প্রয়োজন.. একই কী দৈনিক এবং ইতিহাস API-এর জন্য ব্যবহার করা যেতে পারে।

একটি API কী অর্জন এবং ব্যবহার করা

একটি চাবি পান

অথবা শংসাপত্র পৃষ্ঠায় একটি তৈরি করুন।

আপনার একটি API কী থাকার পরে, আপনার অ্যাপ্লিকেশনটি সমস্ত অনুরোধের URL-এ ক্যোয়ারী প্যারামিটার key= yourAPIKey যোগ করতে পারে।

API কী ইউআরএল-এ এম্বেড করার জন্য নিরাপদ; এটা কোন এনকোডিং প্রয়োজন নেই.

উদাহরণ প্রশ্ন দেখুন.

ডেটা মডেল

এই বিভাগে অনুরোধ এবং প্রতিক্রিয়া তথ্যের গঠন বিবরণ.

রেকর্ড

একটি পৃষ্ঠা বা সাইট সম্পর্কে তথ্যের একটি পৃথক অংশ। একটি রেকর্ডে এমন ডেটা থাকতে পারে যা একটি শনাক্তকারীর জন্য এবং মাত্রার একটি নির্দিষ্ট সংমিশ্রণের জন্য নির্দিষ্ট। একটি রেকর্ডে এক বা একাধিক মেট্রিক্সের ডেটা থাকতে পারে।

শনাক্তকারী

শনাক্তকারীরা উল্লেখ করে যে কোন রেকর্ডগুলো দেখতে হবে। CrUX-এ এই শনাক্তকারীগুলি হল ওয়েবপেজ এবং ওয়েবসাইট৷

উৎপত্তি

যখন শনাক্তকারী একটি উত্স হয় তখন সেই উত্সের সমস্ত পৃষ্ঠাগুলির জন্য উপস্থিত সমস্ত ডেটা একসাথে একত্রিত হয়৷ উদাহরণ স্বরূপ, বলুন যে http://www.example.com মূলে এই সাইটম্যাপ দ্বারা নির্ধারিত পৃষ্ঠাগুলি ছিল:

http://www.example.com/
http://www.example.com/foo.html
http://www.example.com/bar.html

এর মানে হল যে যখন Chrome UX রিপোর্টের জন্য অনুসন্ধান করা হয় তখন http://www.example.com , http://www.example.com/ , http://www.example.com/foo.html , এবং http://www.example.com/bar.html ফেরত দেওয়া হবে, একসাথে একত্রিত করা হবে, কারণ সেগুলি সেই মূলের অধীনে থাকা সমস্ত পৃষ্ঠা।

ইউআরএল

শনাক্তকারী একটি URL হলে, শুধুমাত্র সেই নির্দিষ্ট URL-এর জন্য ডেটা ফেরত দেওয়া হবে৷ http://www.example.com মূল সাইটম্যাপের দিকে আবার খুঁজছি:

http://www.example.com/
http://www.example.com/foo.html
http://www.example.com/bar.html

যদি শনাক্তকারীটি http://www.example.com/foo.html এর মান সহ URL-এ সেট করা থাকে, তবে শুধুমাত্র সেই পৃষ্ঠার ডেটা ফেরত দেওয়া হবে।

মাত্রা

মাত্রাগুলি ডেটার একটি নির্দিষ্ট গোষ্ঠীকে চিহ্নিত করে যার বিরুদ্ধে একটি রেকর্ড একত্রিত করা হচ্ছে। উদাহরণস্বরূপ, PHONE এর একটি ফর্ম ফ্যাক্টর নির্দেশ করে যে রেকর্ডে মোবাইল ডিভাইসে লোড হওয়া সম্পর্কে তথ্য রয়েছে।

CrUX History API শুধুমাত্র ফর্ম ফ্যাক্টর ডাইমেনশন দ্বারা একত্রিত পাওয়া যায়। এটি একটি সাধারণ শ্রেণির ডিভাইস যা PHONE , TABLET এবং DESKTOP বিভক্ত।

মেট্রিক

আমরা পরিসংখ্যানগত সমষ্টির টাইমসিরিজে মেট্রিক্স রিপোর্ট করি, যা হিস্টোগ্রাম, শতাংশ এবং ভগ্নাংশ।

হিস্টোগ্রাম

যখন মেট্রিকগুলি হিস্টোগ্রাম অ্যারেতে প্রকাশ করা হয়, তখন প্রতিটি টাইমসিরিজ এন্ট্রি পৃষ্ঠা লোডের শতাংশের প্রতিনিধিত্ব করে যার জন্য মেট্রিকটি সকলের সমানুপাতিকভাবে একটি ব্যবধানে পড়েছিল। ডেটা পয়েন্টগুলি এপিআই দ্বারা প্রত্যাবর্তিত সংগ্রহের সময়কালের তারিখের ক্রমানুসারে উপস্থাপন করা হয়, প্রথম বিন্দুটি হল প্রাচীনতম সময়কাল এবং চূড়ান্ত বিন্দুটি সবচেয়ে সাম্প্রতিক সংগ্রহের সময়।

একটি উদাহরণ মেট্রিকের জন্য একটি তিন বিন হিস্টোগ্রাম এইরকম দেখায়:

{
  "histogramTimeseries": [
    {
      "start": 0,
      "end": 2500,
      "densities": [0.9190, 0.9203, 0.9194, 0.9195, 0.9183, 0.9187]
    },
    {
      "start": 2500,
      "end": 4000,
      "densities": [0.0521, 0.0513, 0.0518, 0.0518, 0.0526, 0.0527]
    },
    {
      "start": 4000,
      "densities": [0.0288, 0.0282, 0.0286, 0.0285, 0.0290, 0.0285]
    }
  ],
}

এই তথ্যটি নির্দেশ করে যে পৃষ্ঠা লোডের 91.90% ইতিহাসের প্রথম সংগ্রহের সময়কালের জন্য 0ms এবং 2,500ms এর মধ্যে উদাহরণ মেট্রিক মান অনুভব করেছে, তারপরে 92.03%, 91.94%... মেট্রিকের ইউনিটগুলি এই হিস্টোগ্রামে নেই, এই ক্ষেত্রে আমরা মিলিসেকেন্ড ধরে নেব।

উপরন্তু, পৃষ্ঠা লোডের 5.21% ইতিহাসের প্রথম সংগ্রহের সময়কালে 2,500ms এবং 4,000ms এর মধ্যে উদাহরণ মেট্রিক মান অনুভব করেছে, এবং 2.88% পৃষ্ঠা লোড ইতিহাসের প্রথম সংগ্রহের সময়কালে 4,000ms এর চেয়ে বেশি মান অনুভব করেছে৷

শতকরা

মেট্রিক্সে পারসেন্টাইলের টাইমসিরিজও থাকতে পারে যা অতিরিক্ত বিশ্লেষণের জন্য উপযোগী হতে পারে।

ডেটা পয়েন্টগুলি এপিআই দ্বারা প্রত্যাবর্তিত সংগ্রহের সময়কালের তারিখের ক্রমানুসারে উপস্থাপন করা হয়, প্রথম বিন্দুটি হল প্রাচীনতম সময়কাল এবং চূড়ান্ত বিন্দুটি সবচেয়ে সাম্প্রতিক সংগ্রহের সময়।

{
  "percentilesTimeseries": {
    "p75s": [1362, 1352, 1344, 1356, 1366, 1377]
  },
}

এই পার্সেন্টাইলগুলি সেই মেট্রিকের জন্য প্রদত্ত শতাংশে নির্দিষ্ট মেট্রিক মান দেখাতে পারে। এগুলি উপলব্ধ ডেটার সম্পূর্ণ সেটের উপর ভিত্তি করে এবং চূড়ান্ত বিন করা ডেটা নয়, তাই তারা অগত্যা একটি ইন্টারপোলেটেড পার্সেন্টাইলের সাথে মেলে না যা চূড়ান্ত বিন করা হিস্টোগ্রামের উপর ভিত্তি করে।

ভগ্নাংশ

মেট্রিক্স লেবেলযুক্ত ভগ্নাংশের টাইমসিরিজ হিসাবে প্রকাশ করা যেতে পারে; প্রতিটি লেবেল একটি নির্দিষ্ট উপায়ে একটি পৃষ্ঠা লোড বর্ণনা করে। ডেটা পয়েন্টগুলি এপিআই দ্বারা প্রত্যাবর্তিত সংগ্রহের সময়কালের তারিখের ক্রমানুসারে উপস্থাপন করা হয়, প্রথম বিন্দুটি হল প্রাচীনতম সময়কাল এবং চূড়ান্ত বিন্দুটি সবচেয়ে সাম্প্রতিক সংগ্রহের সময়।

উদাহরণ:

{    
  "fractionTimeseries": {
    "desktop": {"fractions": [0.3195, 0.2115, 0.1421]},
    "phone": {"fractions": [0.6295, 0.7544, 0.8288]},
    "tablet": {"fractions": [0.051, 0.0341, 0.029]}
  }
}

এই উদাহরণে, সাম্প্রতিকতম ডেটা পয়েন্ট নির্দেশ করে যে 14.21% পৃষ্ঠা লোড হয়েছে ডেস্কটপ থেকে, এবং 82.88% ফোন থেকে এসেছে৷

মেট্রিক মান প্রকার

যেহেতু CrUX History API একই মেট্রিক মান প্রকারগুলি ব্যবহার করে, আপনি আরও বিশদ বিবরণের জন্য দৈনিক CrUX API মেট্রিক মান প্রকারের ডকুমেন্টেশন উল্লেখ করতে পারেন।

মেট্রিক যোগ্যতা

যোগ্যতার মানদণ্ডের উপর ভিত্তি করে একটি উত্স বা URL শুধুমাত্র CrUX ইতিহাস API দ্বারা আচ্ছাদিত কিছু সংগ্রহের সময়কালের জন্য যোগ্য হতে পারে। এই ক্ষেত্রে CrUX History API histogramTimeseries ঘনত্বের জন্য "NaN" এবং সংগ্রহের সময়কালের জন্য percentilesTimeseries জন্য null যা কোনো যোগ্য ডেটা নেই। পার্থক্যের কারণ হল হিস্টোগ্রামের ঘনত্ব সর্বদা সংখ্যা, যখন শতকরা সংখ্যা বা স্ট্রিং হতে পারে (সিএলএস স্ট্রিং ব্যবহার করে, যদিও তারা সংখ্যার মতো দেখায়)।

উদাহরণস্বরূপ, যদি দ্বিতীয় মেয়াদে কোনো যোগ্য ডেটা না থাকে, তাহলে এটি এইভাবে দেখাবে:

{
  "histogramTimeseries": [
    {
      "start": 0,
      "end": 2500,
      "densities": [0.9190, "NaN", 0.9194, 0.9195, 0.9183, 0.9187]
    },
    {
      "start": 2500,
      "end": 4000,
      "densities": [0.0521, "NaN", 0.0518, 0.0518, 0.0526, 0.0527]
    },
    {
      "start": 4000,
      "densities": [0.0288, "NaN", 0.0286, 0.0285, 0.0290, 0.0285]
    }
  ],
  "percentilesTimeseries": {
    "p75s": [1362, null, 1344, 1356, 1366, 1377]
  },
}

ইউআরএল বা উৎসগুলির জন্য যা সময়ের সাথে সাথে যোগ্যতার মধ্যে পড়ে এবং এর বাইরে, আপনি অনেক অনুপস্থিত এন্ট্রি লক্ষ্য করতে পারেন।

সংগ্রহের সময়কাল

CrUX History API-এ firstDate এবং endDate ক্ষেত্রগুলির একটি অ্যারে সহ একটি collectionPeriods অবজেক্ট রয়েছে যা প্রতিটি একত্রীকরণ উইন্ডোর শুরু এবং শেষ তারিখগুলিকে উপস্থাপন করে। যেমন:

    "collectionPeriods": [{
        "firstDate": { "year": 2022, "month": 7, "day": 10 },
        "lastDate": { "year": 2022, "month": 8, "day": 6 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 17 },
        "lastDate": { "year": 2022, "month": 8, "day": 13 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 24 },
        "lastDate": { "year": 2022, "month": 8, "day": 20 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 31 },
        "lastDate": { "year": 2022, "month": 8, "day": 27 }
      }, {
        "firstDate": { "year": 2022, "month": 8, "day": 7 },
        "lastDate": { "year": 2022, "month": 9, "day": 3 }
      }, {
        "firstDate": { "year": 2022, "month": 8, "day": 14 },
        "lastDate": { "year": 2022, "month": 9, "day": 10 }
      }
    ]

এই সংগ্রহের সময়কাল ক্রমবর্ধমান ক্রমে এবং প্রতিক্রিয়ার অন্যান্য বিভাগে প্রতিটি ডেটা পয়েন্টের তারিখ স্প্যান উপস্থাপন করে।

ইতিহাস API প্রতি সোমবার আপডেট করা হয় এবং আগের শনিবার পর্যন্ত ডেটা ধারণ করে (স্ট্যান্ডার্ড 2-দিনের ব্যবধান অনুযায়ী)। এটিতে আগের 25-সপ্তাহের ডেটা রয়েছে—প্রতি সপ্তাহে একটি সংগ্রহের সময়কাল।

যেহেতু প্রতিটি সংগ্রহের সময়কাল পূর্ববর্তী 28-দিনের সমষ্টিগত ডেটা ধারণ করে, এবং সংগ্রহের সময়কাল প্রতি সপ্তাহে, এর অর্থ সংগ্রহের সময়গুলি ওভারল্যাপ হবে। এগুলি ডেটার চলমান গড়ের মতো, প্রতিটি পরবর্তী সময়ের মধ্যে তিন সপ্তাহের মূল্যের ডেটা অন্তর্ভুক্ত করা হয় এবং এক সপ্তাহ আলাদা।

উদাহরণ প্রশ্ন

POST বডিতে JSON অবজেক্ট হিসেবে ক্যোয়ারী ডেটা সহ https://chromeuxreport.googleapis.com/v1/records:queryHistoryRecord?key=[YOUR_API_KEY]" এ পোস্ট অনুরোধ ব্যবহার করে JSON অবজেক্ট হিসেবে প্রশ্নগুলি জমা দেওয়া হয়।

দৈনিক CrUX API-এর queryRecord প্রতিস্থাপন করে queryHistoryRecord এর ব্যবহার লক্ষ্য করুন।

একটি উদাহরণ শরীর হল:

{
  "origin": "https://example.com",
  "formFactor": "PHONE",
  "metrics": [
    "largest_contentful_paint",
    "experimental_time_to_first_byte"
  ]
}

উদাহরণস্বরূপ, এটিকে নিম্নলিখিত কমান্ড লাইনের সাহায্যে curl থেকে কল করা যেতে পারে (আপনার কী দিয়ে API_KEY প্রতিস্থাপন করা):

curl -s --request POST 'https://chromeuxreport.googleapis.com/v1/records:queryHistoryRecord?key=API_KEY' \
    --header 'Accept: application/json' \
    --header 'Content-Type: application/json' \
    --data '{"formFactor":"PHONE","origin":"https://www.example.com","metrics":["largest_contentful_paint", "experimental_time_to_first_byte"]}'

পৃষ্ঠা-স্তরের ডেটা origin পরিবর্তে কোয়েরিতে একটি url সম্পত্তি পাস করে API-এর মাধ্যমে পাওয়া যায়:

{
  "url": "https://example.com/page",
  "formFactor": "PHONE",
  "metrics": [
    "largest_contentful_paint",
    "experimental_time_to_first_byte"
  ]
}

যদি metrics প্রপার্টি সেট করা না থাকে তাহলে সমস্ত উপলব্ধ মেট্রিক ফেরত দেওয়া হবে:

  • cumulative_layout_shift
  • first_contentful_paint
  • interaction_to_next_paint
  • largest_contentful_paint
  • experimental_time_to_first_byte
  • navigation_types
  • round_trip_time
  • form_factors (অনুরোধে কোনো formFactor উল্লেখ না থাকলে শুধুমাত্র রিপোর্ট করা হয়)

যদি কোন formFactor মান প্রদান করা না হয় তাহলে মানগুলি সমস্ত ফর্ম ফ্যাক্টর জুড়ে একত্রিত হবে।

আরও উদাহরণের জন্য CrUX History API নির্দেশিকা ব্যবহার করা দেখুন।

ডেটা পাইপলাইন

CrUX ডেটাসেট API-এর মাধ্যমে উপলব্ধ হওয়ার আগে ডেটা একত্রীকরণ, একত্রিত এবং ফিল্টার করার জন্য একটি পাইপলাইনের মাধ্যমে প্রক্রিয়া করা হয়।

রোলিং গড়

ক্রোম ইউএক্স রিপোর্টের ডেটা হল একত্রিত মেট্রিক্সের 28-দিনের রোলিং গড়৷ এর মানে হল যে কোনও নির্দিষ্ট সময়ে Chrome UX রিপোর্টে উপস্থাপিত ডেটা আসলে গত 28 দিনের একত্রিত ডেটা।

হিস্ট্রি এপিআই-এ অনেকগুলি সংগ্রহের সময়কাল রয়েছে, প্রতিটি এই 28 দিনের মধ্যে বিস্তৃত। যেহেতু প্রতিটি সংগ্রহের সময়কাল পূর্ববর্তী 28-দিনের সমষ্টিগত ডেটা ধারণ করে, এবং সংগ্রহের সময়কাল প্রতি সপ্তাহে, এর অর্থ সংগ্রহের সময়গুলি ওভারল্যাপ হবে। এগুলি ডেটার চলমান গড়ের মতো, প্রতিটি পরবর্তী সময়ের মধ্যে তিন সপ্তাহের মূল্যের ডেটা অন্তর্ভুক্ত করা হয় এবং এক সপ্তাহ আলাদা।

সাপ্তাহিক আপডেট

ইতিহাস API প্রতি সোমবার 04:00 UTC এর কাছাকাছি আপডেট করা হয় এবং এতে আগের শনিবার পর্যন্ত ডেটা থাকে (স্ট্যান্ডার্ড 2-দিনের ব্যবধান অনুযায়ী)। এতে আগের 25 সপ্তাহ (প্রায় 6 মাস) মূল্যের ডেটা রয়েছে, প্রতি সপ্তাহে একটি সংগ্রহের সময়কাল।

আপডেট সময়ের জন্য কোন পরিষেবা স্তর চুক্তি নেই; এটি প্রতিদিন সর্বোত্তম প্রচেষ্টার ভিত্তিতে পরিচালিত হয়।

স্কিমা

CrUX History API-এর জন্য একটি একক এন্ডপয়েন্ট রয়েছে যা POST HTTP অনুরোধ গ্রহণ করে। এপিআই এমন একটি record ফেরত দেয় যাতে অনুরোধ করা উৎস বা পৃষ্ঠা সম্পর্কে কর্মক্ষমতা ডেটার সাথে সম্পর্কিত এক বা একাধিক metrics থাকে।

HTTP অনুরোধ

POST https://chromeuxreport.googleapis.com/v1/records:queryHistoryRecord

URL gRPC ট্রান্সকোডিং সিনট্যাক্স ব্যবহার করে।

শরীরের অনুরোধ

CrUX History API দৈনিক CrUX API হিসাবে একই অনুরোধ সংস্থাগুলি ব্যবহার করে, effectiveConnectionType অনুরোধ ক্ষেত্রটিকে সমর্থন না করার ব্যতিক্রম।

উদাহরণস্বরূপ, web.dev হোমপেজের জন্য ডেস্কটপের সবচেয়ে বড় বিষয়বস্তুযুক্ত পেইন্ট মানগুলির অনুরোধ করতে:

{
  "origin": "https://web.dev/",
  "formFactor": "DESKTOP",
  "metrics": [
    "largest_contentful_paint"
  ]
}

প্রতিক্রিয়া শরীর

সফল অনুরোধগুলি নিম্নলিখিত কাঠামোতে একটি record অবজেক্ট এবং urlNormalizationDetails সহ প্রতিক্রিয়া ফেরত দেয়:

{
  "record": {
    "key": {
      object (Key)
    },
    "metrics": [
      string: {
        object (Metric)
      }
    ]
  },
  "urlNormalizationDetails": {
    object (UrlNormalization)
  }
}

উদাহরণস্বরূপ, পূর্ববর্তী অনুরোধে অনুরোধের বডির প্রতিক্রিয়া হতে পারে:

{
  "record": {
    "key": {
      "origin": "https://web.dev"
    },
    "metrics": {
      "largest_contentful_paint": {
        "histogramTimeseries": [{
            "start": 0, "end": 2500, "densities": [
              0.9190, 0.9203, 0.9194, 0.9195, 0.9183, 0.9187, ...
            ]
          }, {
            "start": 2500, "end": 4000, "densities": [
              0.0521, 0.0513, 0.0518, 0.0518, 0.0526, 0.0527, ...
            ]
          },  {
            "start": 4000, "densities": [
              0.0288, 0.0282, 0.0286, 0.0285, 0.0290, 0.0285, ...
            ]
          }
        ],
        "percentilesTimeseries": {
          "p75s": [
            1362, 1352, 1344, 1356, 1366, 1377, ...
          ]
        }
      }
    },
    "collectionPeriods": [{
        "firstDate": { "year": 2022, "month": 7, "day": 10 },
        "lastDate": { "year": 2022, "month": 8, "day": 6 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 17 },
        "lastDate": { "year": 2022, "month": 8, "day": 13 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 24 },
        "lastDate": { "year": 2022, "month": 8, "day": 20 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 31 },
        "lastDate": { "year": 2022, "month": 8, "day": 27 }
      }, {
        "firstDate": { "year": 2022, "month": 8, "day": 7 },
        "lastDate": { "year": 2022, "month": 9, "day": 3 }
      }, {
        "firstDate": { "year": 2022, "month": 8, "day": 14 },
        "lastDate": { "year": 2022, "month": 9, "day": 10 }
      }, {
        ...
      }
    ]
  }
}

চাবি

Key এই রেকর্ডটিকে অনন্য হিসাবে চিহ্নিত করে এমন সমস্ত মাত্রা সংজ্ঞায়িত করে।

{
  "formFactor": enum (FormFactor),

  // Union field url_pattern can be only one of the following:
  "origin": string,
  "url": string
  // End of list of possible types for union field url_pattern.
}
ক্ষেত্র
formFactor

enum ( FormFactor )

ফর্ম ফ্যাক্টর হল ডিভাইস ক্লাস যা সমস্ত ব্যবহারকারী এই রেকর্ডের জন্য সাইট অ্যাক্সেস করতে ব্যবহার করে।

যদি ফর্ম ফ্যাক্টর অনির্দিষ্ট হয়, তাহলে সমস্ত ফর্ম ফ্যাক্টরগুলির সমষ্টিগত ডেটা ফেরত দেওয়া হবে।

ইউনিয়ন ক্ষেত্র url_ pattern । URL প্যাটার্ন হল সেই URL যা রেকর্ড প্রযোজ্য। url_ pattern নিম্নলিখিতগুলির মধ্যে একটি হতে পারে:
origin

string

অরিজিন নির্দিষ্ট করে যে এই রেকর্ডের জন্য।

দ্রষ্টব্য: একটি উত্স নির্দিষ্ট করার সময়, সমস্ত পৃষ্ঠাগুলিতে এই উত্সের অধীনে লোডের জন্য ডেটা মূল স্তরের ব্যবহারকারীর অভিজ্ঞতা ডেটাতে একত্রিত হয়৷

url

string

url একটি নির্দিষ্ট URL উল্লেখ করে যার জন্য এই রেকর্ড।

দ্রষ্টব্য: একটি url নির্দিষ্ট করার সময় শুধুমাত্র সেই নির্দিষ্ট URL-এর জন্য ডেটা একত্রিত করা হবে।

মেট্রিক্স

একটি metric হল একটি একক ওয়েব পারফরম্যান্স মেট্রিকের জন্য ব্যবহারকারীর অভিজ্ঞতার ডেটার একটি সেট, যেমন প্রথম বিষয়বস্তুপূর্ণ পেইন্ট। এটি bins একটি সিরিজ হিসাবে বাস্তব বিশ্বের Chrome ব্যবহারের একটি সারাংশ হিস্টোগ্রাম রয়েছে৷

{
  "histogramTimeseries": [
    {
      object (Bin)
    }
  ],
  "percentilesTimeseries": {
    object (Percentiles)
  }
}

বা

"fractionTimeseries": {
  object (Fractions)
}
ক্ষেত্র
histogramTimeseries[]

object ( Bin )

একটি মেট্রিকের জন্য ব্যবহারকারীর অভিজ্ঞতার টাইমসিরিজ হিস্টোগ্রাম। টাইমসিরিজ হিস্টোগ্রামে কমপক্ষে একটি বিন থাকবে এবং সমস্ত বিনের ঘনত্ব ~1 পর্যন্ত যোগ হবে।

সেই নির্দিষ্ট সংগ্রহের সময়ের জন্য অনুপস্থিত মানগুলিকে "NaN" হিসাবে চিহ্নিত করা হবে৷

percentilesTimeseries

object ( Percentiles )

মেট্রিকের সাধারণ উপযোগী পার্সেন্টাইল। পারসেন্টাইলের মান প্রকার হিস্টোগ্রাম বিনের জন্য প্রদত্ত মান প্রকারের মতোই হবে।

সেই নির্দিষ্ট সংগ্রহের সময়ের জন্য অনুপস্থিত মানগুলিকে null হিসাবে চিহ্নিত করা হবে।

fractionTimeseries

object ( Fractions )

এই বস্তুটিতে লেবেলযুক্ত ভগ্নাংশের টাইমসিরিজ রয়েছে, যা প্রতি এন্ট্রিতে ~1 পর্যন্ত যোগ করে।

ভগ্নাংশগুলিকে 4 দশমিক স্থানে বৃত্তাকার করা হয়।

অনুপস্থিত এন্ট্রিগুলি সমস্ত ভগ্নাংশ জুড়ে `"NaN"` হিসাবে প্রকাশ করা হয়৷

বিন

একটি bin হল ডেটার একটি বিচ্ছিন্ন অংশ যা শুরু থেকে শেষ পর্যন্ত বিস্তৃত হয়, অথবা যদি শুরু থেকে ধনাত্মক অসীম পর্যন্ত কোন শেষ না দেওয়া হয়।

একটি বিনের শুরু এবং শেষের মানগুলি মেট্রিকের মান প্রকারে দেওয়া হয় যা এটি প্রতিনিধিত্ব করে। উদাহরণস্বরূপ, প্রথম কনটেন্টফুল পেইন্টটি মিলিসেকেন্ডে পরিমাপ করা হয় এবং ints হিসাবে প্রকাশ করা হয়, তাই এর মেট্রিক বিনগুলি এর শুরু এবং শেষ প্রকারের জন্য int32s ব্যবহার করবে। তবে ক্রমবর্ধমান বিন্যাস স্থানান্তর ইউনিটহীন দশমিকে পরিমাপ করা হয় এবং একটি স্ট্রিং হিসাবে এনকোড করা দশমিক হিসাবে উন্মুক্ত করা হয়, তাই এর মেট্রিক বিনগুলি এর মান প্রকারের জন্য স্ট্রিং ব্যবহার করবে।

{
  "start": value,
  "end": value,
  "densities": [number, number, number...etc.]
}
ক্ষেত্র
start

(integer | string)

স্টার্ট হল ডাটা বিনের শুরু।

end

(integer | string)

শেষ হল ডাটা বিনের শেষ। যদি শেষ জনবহুল না হয়, তাহলে বিনের কোন শেষ নেই এবং এটি শুরু থেকে +inf পর্যন্ত বৈধ।

densities

array[number]

প্রদত্ত মেট্রিকের জন্য এই বিনের মান অভিজ্ঞ ব্যবহারকারীদের অনুপাতের একটি টাইমসিরিজ৷

ঘনত্ব 4 দশমিক স্থানে বৃত্তাকার।

শতকরা

Percentiles একটি প্রদত্ত পরিসংখ্যানগত শতাংশে একটি মেট্রিকের সিন্থেটিক মান রয়েছে। মোট ব্যবহারকারীর সংখ্যার মধ্যে শতকরা শতাংশ ব্যবহারকারীর দ্বারা অভিজ্ঞ মেট্রিকের মান অনুমান করার জন্য এগুলি ব্যবহার করা হয়।

{
  "P75": value
}
ক্ষেত্র
p75s

array[(integer | string)]

75% পৃষ্ঠা লোড হওয়া মানগুলির টাইমসিরিজ প্রদত্ত মেট্রিকটি এই মানের বা তার চেয়ে কম অনুভব করেছে৷

ভগ্নাংশ

Fractions লেবেলযুক্ত ভগ্নাংশের টাইমসিরিজ রয়েছে যা প্রতি এন্ট্রিতে ~1 পর্যন্ত যোগ করে। প্রতিটি লেবেল কোনো না কোনোভাবে একটি পৃষ্ঠা লোডকে বর্ণনা করে, তাই এইভাবে উপস্থাপিত মেট্রিকগুলিকে সংখ্যাসূচক মানের পরিবর্তে স্বতন্ত্র মান তৈরি করার কথা ভাবা যেতে পারে এবং ভগ্নাংশগুলি প্রকাশ করে যে একটি নির্দিষ্ট স্বতন্ত্র মান কত ঘন ঘন পরিমাপ করা হয়েছিল।

{
  "label_1": { "fractions": array[fraction]},
  "label_1": { "fractions": array[fraction]},
  ...
  "label_n": { "fractions": array[fraction]}
}

অনেকটা হিস্টোগ্রাম বিনের ঘনত্বের মানের মতো, প্রতিটি fraction একটি সংখ্যা 0.0 <= value <= 1.0 , এবং তারা ~1.0 পর্যন্ত যোগ করে। যখন একটি নির্দিষ্ট সংগ্রহের সময়ের জন্য মেট্রিক উপলব্ধ না হয়, তখন সংশ্লিষ্ট এন্ট্রিটি ভগ্নাংশের সমস্ত অ্যারেতে "NaN" হবে৷

ক্ষেত্র
p75s

array[(integer | string)]

75% পৃষ্ঠা লোড হওয়া মানগুলির টাইমসিরিজ প্রদত্ত মেট্রিকটি এই মানের বা তার চেয়ে কম অনুভব করেছে৷

ইউআরএল স্বাভাবিককরণ

সফল লুকআপের একটি উচ্চতর সম্ভাবনা অর্জনের জন্য একটি URL স্বাভাবিক করার জন্য নেওয়া স্বাভাবিককরণের ক্রিয়াগুলিকে প্রতিনিধিত্ব করে। এইগুলি হল সহজ স্বয়ংক্রিয় পরিবর্তন যা প্রদত্ত url_pattern সন্ধান করার সময় নেওয়া হয় ব্যর্থ বলে জানা যাবে৷ নিম্নোক্ত পুনঃনির্দেশের মতো জটিল ক্রিয়াগুলি পরিচালনা করা হয় না।

{
  "originalUrl": string,
  "normalizedUrl": string
}
ক্ষেত্র
originalUrl

string

যেকোন স্বাভাবিকীকরণ কর্মের আগে মূল অনুরোধ করা URL।

normalizedUrl

string

যেকোন স্বাভাবিকীকরণ কর্মের পরে URL। এটি একটি বৈধ ব্যবহারকারীর অভিজ্ঞতা URL যা যুক্তিসঙ্গতভাবে দেখা যেতে পারে৷

হারের সীমা

CrUX History API CrUX API- এর সাথে একই সীমা ভাগ করে প্রতি মিনিটে Google ক্লাউড প্রকল্পে প্রতি মিনিটে 150টি প্রশ্নের জন্য, যেটি কোনো চার্জ ছাড়াই দেওয়া হয়। এই সীমা, এবং আপনার বর্তমান ব্যবহার, Google ক্লাউড কনসোলে দেখা যাবে। এই উদার কোটা বেশিরভাগ ব্যবহারের ক্ষেত্রে যথেষ্ট হওয়া উচিত এবং বর্ধিত কোটার জন্য অর্থ প্রদান করা সম্ভব নয়।

,

CrUX History API পৃষ্ঠা এবং মূল গ্রানুলারিটিতে ছয় মাসের ঐতিহাসিক বাস্তব-ব্যবহারকারীর অভিজ্ঞতার ডেটাতে কম লেটেন্সি অ্যাক্সেস দেয়।

এটা চেষ্টা করুন!

সাধারণ ব্যবহারের ক্ষেত্রে

CrUX History API একটি নির্দিষ্ট URI-এর জন্য ঐতিহাসিক ব্যবহারকারীর অভিজ্ঞতা মেট্রিক্সের অনুসন্ধানের জন্য অনুমতি দেয় যেমন " https://example.com মূলের জন্য ঐতিহাসিক UX প্রবণতা পান।"

হিস্টোরি এপিআই দৈনিক CrUX API- এর মতো একই কাঠামো অনুসরণ করে, ব্যতীত মানগুলি একটি অ্যারেতে দেওয়া হয়, এবং কীগুলিকে বহুবচন নামের লেবেল করা হয় (উদাহরণস্বরূপ, histogram পরিবর্তে histogramTimeseries , অথবা p75 এর পরিবর্তে p75s )।

CrUX API কী

দৈনিক API-এর মতো, CrUX History API ব্যবহার করার জন্য Chrome UX Report API ব্যবহারের জন্য একটি Google Cloud API কী ব্যবস্থা করা প্রয়োজন.. একই কী দৈনিক এবং ইতিহাস API-এর জন্য ব্যবহার করা যেতে পারে।

একটি API কী অর্জন এবং ব্যবহার করা

একটি চাবি পান

অথবা শংসাপত্র পৃষ্ঠায় একটি তৈরি করুন।

আপনার একটি API কী থাকার পরে, আপনার অ্যাপ্লিকেশনটি সমস্ত অনুরোধের URL-এ ক্যোয়ারী প্যারামিটার key= yourAPIKey যোগ করতে পারে।

API কী ইউআরএল-এ এম্বেড করার জন্য নিরাপদ; এটা কোন এনকোডিং প্রয়োজন নেই.

উদাহরণ প্রশ্ন দেখুন.

ডেটা মডেল

এই বিভাগে অনুরোধ এবং প্রতিক্রিয়া তথ্যের গঠন বিবরণ.

রেকর্ড

একটি পৃষ্ঠা বা সাইট সম্পর্কে তথ্যের একটি পৃথক অংশ। একটি রেকর্ডে এমন ডেটা থাকতে পারে যা একটি শনাক্তকারীর জন্য এবং মাত্রার একটি নির্দিষ্ট সংমিশ্রণের জন্য নির্দিষ্ট। একটি রেকর্ডে এক বা একাধিক মেট্রিক্সের ডেটা থাকতে পারে।

শনাক্তকারী

শনাক্তকারীরা উল্লেখ করে যে কোন রেকর্ডগুলো দেখতে হবে। CrUX-এ এই শনাক্তকারীগুলি হল ওয়েবপেজ এবং ওয়েবসাইট৷

উৎপত্তি

যখন শনাক্তকারী একটি উত্স হয় তখন সেই উত্সের সমস্ত পৃষ্ঠাগুলির জন্য উপস্থিত সমস্ত ডেটা একসাথে একত্রিত হয়৷ উদাহরণ স্বরূপ, বলুন যে http://www.example.com মূলে এই সাইটম্যাপ দ্বারা নির্ধারিত পৃষ্ঠাগুলি ছিল:

http://www.example.com/
http://www.example.com/foo.html
http://www.example.com/bar.html

এর মানে হল যে যখন Chrome UX রিপোর্টের জন্য অনুসন্ধান করা হয় তখন http://www.example.com , http://www.example.com/ , http://www.example.com/foo.html , এবং http://www.example.com/bar.html ফেরত দেওয়া হবে, একসাথে একত্রিত করা হবে, কারণ সেগুলি সেই মূলের অধীনে থাকা সমস্ত পৃষ্ঠা।

ইউআরএল

শনাক্তকারী একটি URL হলে, শুধুমাত্র সেই নির্দিষ্ট URL-এর জন্য ডেটা ফেরত দেওয়া হবে৷ http://www.example.com মূল সাইটম্যাপের দিকে আবার খুঁজছি:

http://www.example.com/
http://www.example.com/foo.html
http://www.example.com/bar.html

যদি শনাক্তকারীটি http://www.example.com/foo.html এর মান সহ URL-এ সেট করা থাকে, তবে শুধুমাত্র সেই পৃষ্ঠার ডেটা ফেরত দেওয়া হবে।

মাত্রা

মাত্রাগুলি ডেটার একটি নির্দিষ্ট গোষ্ঠীকে চিহ্নিত করে যার বিরুদ্ধে একটি রেকর্ড একত্রিত করা হচ্ছে। উদাহরণস্বরূপ, PHONE এর একটি ফর্ম ফ্যাক্টর নির্দেশ করে যে রেকর্ডে মোবাইল ডিভাইসে লোড হওয়া সম্পর্কে তথ্য রয়েছে।

CrUX History API শুধুমাত্র ফর্ম ফ্যাক্টর ডাইমেনশন দ্বারা একত্রিত পাওয়া যায়। এটি একটি সাধারণ শ্রেণির ডিভাইস যা PHONE , TABLET এবং DESKTOP বিভক্ত।

মেট্রিক

আমরা পরিসংখ্যানগত সমষ্টির টাইমসিরিজে মেট্রিক্স রিপোর্ট করি, যা হিস্টোগ্রাম, শতাংশ এবং ভগ্নাংশ।

হিস্টোগ্রাম

যখন মেট্রিকগুলি হিস্টোগ্রাম অ্যারেতে প্রকাশ করা হয়, তখন প্রতিটি টাইমসিরিজ এন্ট্রি পৃষ্ঠা লোডের শতাংশের প্রতিনিধিত্ব করে যার জন্য মেট্রিকটি সকলের সমানুপাতিকভাবে একটি ব্যবধানে পড়েছিল। ডেটা পয়েন্টগুলি এপিআই দ্বারা প্রত্যাবর্তিত সংগ্রহের সময়কালের তারিখের ক্রমানুসারে উপস্থাপন করা হয়, প্রথম বিন্দুটি হল প্রাচীনতম সময়কাল এবং চূড়ান্ত বিন্দুটি সবচেয়ে সাম্প্রতিক সংগ্রহের সময়।

একটি উদাহরণ মেট্রিকের জন্য একটি তিন বিন হিস্টোগ্রাম এইরকম দেখায়:

{
  "histogramTimeseries": [
    {
      "start": 0,
      "end": 2500,
      "densities": [0.9190, 0.9203, 0.9194, 0.9195, 0.9183, 0.9187]
    },
    {
      "start": 2500,
      "end": 4000,
      "densities": [0.0521, 0.0513, 0.0518, 0.0518, 0.0526, 0.0527]
    },
    {
      "start": 4000,
      "densities": [0.0288, 0.0282, 0.0286, 0.0285, 0.0290, 0.0285]
    }
  ],
}

এই তথ্যটি নির্দেশ করে যে পৃষ্ঠা লোডের 91.90% ইতিহাসের প্রথম সংগ্রহের সময়কালের জন্য 0ms এবং 2,500ms এর মধ্যে উদাহরণ মেট্রিক মান অনুভব করেছে, তারপরে 92.03%, 91.94%... মেট্রিকের ইউনিটগুলি এই হিস্টোগ্রামে নেই, এই ক্ষেত্রে আমরা মিলিসেকেন্ড ধরে নেব।

উপরন্তু, পৃষ্ঠা লোডের 5.21% ইতিহাসের প্রথম সংগ্রহের সময়কালে 2,500ms এবং 4,000ms এর মধ্যে উদাহরণ মেট্রিক মান অনুভব করেছে, এবং 2.88% পৃষ্ঠা লোড ইতিহাসের প্রথম সংগ্রহের সময়কালে 4,000ms এর চেয়ে বেশি মান অনুভব করেছে৷

শতকরা

মেট্রিক্সে পারসেন্টাইলের টাইমসিরিজও থাকতে পারে যা অতিরিক্ত বিশ্লেষণের জন্য উপযোগী হতে পারে।

ডেটা পয়েন্টগুলি এপিআই দ্বারা প্রত্যাবর্তিত সংগ্রহের সময়কালের তারিখের ক্রমানুসারে উপস্থাপন করা হয়, প্রথম বিন্দুটি হল প্রাচীনতম সময়কাল এবং চূড়ান্ত বিন্দুটি সবচেয়ে সাম্প্রতিক সংগ্রহের সময়।

{
  "percentilesTimeseries": {
    "p75s": [1362, 1352, 1344, 1356, 1366, 1377]
  },
}

এই পার্সেন্টাইলগুলি সেই মেট্রিকের জন্য প্রদত্ত শতাংশে নির্দিষ্ট মেট্রিক মান দেখাতে পারে। এগুলি উপলব্ধ ডেটার সম্পূর্ণ সেটের উপর ভিত্তি করে এবং চূড়ান্ত বিন করা ডেটা নয়, তাই তারা অগত্যা একটি ইন্টারপোলেটেড পার্সেন্টাইলের সাথে মেলে না যা চূড়ান্ত বিন করা হিস্টোগ্রামের উপর ভিত্তি করে।

ভগ্নাংশ

মেট্রিক্স লেবেলযুক্ত ভগ্নাংশের টাইমসিরিজ হিসাবে প্রকাশ করা যেতে পারে; প্রতিটি লেবেল একটি নির্দিষ্ট উপায়ে একটি পৃষ্ঠা লোড বর্ণনা করে। ডেটা পয়েন্টগুলি এপিআই দ্বারা প্রত্যাবর্তিত সংগ্রহের সময়কালের তারিখের ক্রমানুসারে উপস্থাপন করা হয়, প্রথম বিন্দুটি হল প্রাচীনতম সময়কাল এবং চূড়ান্ত বিন্দুটি সবচেয়ে সাম্প্রতিক সংগ্রহের সময়।

উদাহরণ:

{    
  "fractionTimeseries": {
    "desktop": {"fractions": [0.3195, 0.2115, 0.1421]},
    "phone": {"fractions": [0.6295, 0.7544, 0.8288]},
    "tablet": {"fractions": [0.051, 0.0341, 0.029]}
  }
}

এই উদাহরণে, সাম্প্রতিকতম ডেটা পয়েন্ট নির্দেশ করে যে 14.21% পৃষ্ঠা লোড হয়েছে ডেস্কটপ থেকে, এবং 82.88% ফোন থেকে এসেছে৷

মেট্রিক মান প্রকার

যেহেতু CrUX History API একই মেট্রিক মান প্রকারগুলি ব্যবহার করে, আপনি আরও বিশদ বিবরণের জন্য দৈনিক CrUX API মেট্রিক মান প্রকারের ডকুমেন্টেশন উল্লেখ করতে পারেন।

মেট্রিক যোগ্যতা

যোগ্যতার মানদণ্ডের উপর ভিত্তি করে একটি উত্স বা URL শুধুমাত্র CrUX ইতিহাস API দ্বারা আচ্ছাদিত কিছু সংগ্রহের সময়কালের জন্য যোগ্য হতে পারে। এই ক্ষেত্রে CrUX History API histogramTimeseries ঘনত্বের জন্য "NaN" এবং সংগ্রহের সময়কালের জন্য percentilesTimeseries জন্য null যা কোনো যোগ্য ডেটা নেই। পার্থক্যের কারণ হল হিস্টোগ্রামের ঘনত্ব সর্বদা সংখ্যা, যখন শতকরা সংখ্যা বা স্ট্রিং হতে পারে (সিএলএস স্ট্রিং ব্যবহার করে, যদিও তারা সংখ্যার মতো দেখায়)।

উদাহরণস্বরূপ, যদি দ্বিতীয় মেয়াদে কোনো যোগ্য ডেটা না থাকে, তাহলে এটি এইভাবে দেখাবে:

{
  "histogramTimeseries": [
    {
      "start": 0,
      "end": 2500,
      "densities": [0.9190, "NaN", 0.9194, 0.9195, 0.9183, 0.9187]
    },
    {
      "start": 2500,
      "end": 4000,
      "densities": [0.0521, "NaN", 0.0518, 0.0518, 0.0526, 0.0527]
    },
    {
      "start": 4000,
      "densities": [0.0288, "NaN", 0.0286, 0.0285, 0.0290, 0.0285]
    }
  ],
  "percentilesTimeseries": {
    "p75s": [1362, null, 1344, 1356, 1366, 1377]
  },
}

ইউআরএল বা উৎসগুলির জন্য যা সময়ের সাথে সাথে যোগ্যতার মধ্যে পড়ে এবং এর বাইরে, আপনি অনেক অনুপস্থিত এন্ট্রি লক্ষ্য করতে পারেন।

সংগ্রহের সময়কাল

CrUX History API-এ firstDate এবং endDate ক্ষেত্রগুলির একটি অ্যারে সহ একটি collectionPeriods অবজেক্ট রয়েছে যা প্রতিটি একত্রীকরণ উইন্ডোর শুরু এবং শেষ তারিখগুলিকে উপস্থাপন করে। যেমন:

    "collectionPeriods": [{
        "firstDate": { "year": 2022, "month": 7, "day": 10 },
        "lastDate": { "year": 2022, "month": 8, "day": 6 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 17 },
        "lastDate": { "year": 2022, "month": 8, "day": 13 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 24 },
        "lastDate": { "year": 2022, "month": 8, "day": 20 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 31 },
        "lastDate": { "year": 2022, "month": 8, "day": 27 }
      }, {
        "firstDate": { "year": 2022, "month": 8, "day": 7 },
        "lastDate": { "year": 2022, "month": 9, "day": 3 }
      }, {
        "firstDate": { "year": 2022, "month": 8, "day": 14 },
        "lastDate": { "year": 2022, "month": 9, "day": 10 }
      }
    ]

এই সংগ্রহের সময়কাল ক্রমবর্ধমান ক্রমে এবং প্রতিক্রিয়ার অন্যান্য বিভাগে প্রতিটি ডেটা পয়েন্টের তারিখ স্প্যান উপস্থাপন করে।

ইতিহাস API প্রতি সোমবার আপডেট করা হয় এবং আগের শনিবার পর্যন্ত ডেটা ধারণ করে (স্ট্যান্ডার্ড 2-দিনের ব্যবধান অনুযায়ী)। এটিতে আগের 25-সপ্তাহের ডেটা রয়েছে—প্রতি সপ্তাহে একটি সংগ্রহের সময়কাল।

যেহেতু প্রতিটি সংগ্রহের সময়কাল পূর্ববর্তী 28-দিনের সমষ্টিগত ডেটা ধারণ করে, এবং সংগ্রহের সময়কাল প্রতি সপ্তাহে, এর অর্থ সংগ্রহের সময়গুলি ওভারল্যাপ হবে। এগুলি ডেটার চলমান গড়ের মতো, প্রতিটি পরবর্তী সময়ের মধ্যে তিন সপ্তাহের মূল্যের ডেটা অন্তর্ভুক্ত করা হয় এবং এক সপ্তাহ আলাদা।

উদাহরণ প্রশ্ন

POST বডিতে JSON অবজেক্ট হিসেবে ক্যোয়ারী ডেটা সহ https://chromeuxreport.googleapis.com/v1/records:queryHistoryRecord?key=[YOUR_API_KEY]" এ পোস্ট অনুরোধ ব্যবহার করে JSON অবজেক্ট হিসেবে প্রশ্নগুলি জমা দেওয়া হয়।

দৈনিক CrUX API-এর queryRecord প্রতিস্থাপন করে queryHistoryRecord এর ব্যবহার লক্ষ্য করুন।

একটি উদাহরণ শরীর হল:

{
  "origin": "https://example.com",
  "formFactor": "PHONE",
  "metrics": [
    "largest_contentful_paint",
    "experimental_time_to_first_byte"
  ]
}

উদাহরণস্বরূপ, এটিকে নিম্নলিখিত কমান্ড লাইনের সাহায্যে curl থেকে কল করা যেতে পারে (আপনার কী দিয়ে API_KEY প্রতিস্থাপন করা):

curl -s --request POST 'https://chromeuxreport.googleapis.com/v1/records:queryHistoryRecord?key=API_KEY' \
    --header 'Accept: application/json' \
    --header 'Content-Type: application/json' \
    --data '{"formFactor":"PHONE","origin":"https://www.example.com","metrics":["largest_contentful_paint", "experimental_time_to_first_byte"]}'

পৃষ্ঠা-স্তরের ডেটা origin পরিবর্তে কোয়েরিতে একটি url সম্পত্তি পাস করে API-এর মাধ্যমে পাওয়া যায়:

{
  "url": "https://example.com/page",
  "formFactor": "PHONE",
  "metrics": [
    "largest_contentful_paint",
    "experimental_time_to_first_byte"
  ]
}

যদি metrics প্রপার্টি সেট করা না থাকে তাহলে সমস্ত উপলব্ধ মেট্রিক ফেরত দেওয়া হবে:

  • cumulative_layout_shift
  • first_contentful_paint
  • interaction_to_next_paint
  • largest_contentful_paint
  • experimental_time_to_first_byte
  • navigation_types
  • round_trip_time
  • form_factors (অনুরোধে কোনো formFactor উল্লেখ না থাকলে শুধুমাত্র রিপোর্ট করা হয়)

যদি কোন formFactor মান প্রদান করা না হয় তাহলে মানগুলি সমস্ত ফর্ম ফ্যাক্টর জুড়ে একত্রিত হবে।

আরও উদাহরণের জন্য CrUX History API নির্দেশিকা ব্যবহার করা দেখুন।

ডেটা পাইপলাইন

CrUX ডেটাসেট API-এর মাধ্যমে উপলব্ধ হওয়ার আগে ডেটা একত্রীকরণ, একত্রিত এবং ফিল্টার করার জন্য একটি পাইপলাইনের মাধ্যমে প্রক্রিয়া করা হয়।

রোলিং গড়

ক্রোম ইউএক্স রিপোর্টের ডেটা হল একত্রিত মেট্রিক্সের 28-দিনের রোলিং গড়৷ এর মানে হল যে কোনও নির্দিষ্ট সময়ে Chrome UX রিপোর্টে উপস্থাপিত ডেটা আসলে গত 28 দিনের একত্রিত ডেটা।

হিস্ট্রি এপিআই-এ অনেকগুলি সংগ্রহের সময়কাল রয়েছে, প্রতিটি এই 28 দিনের মধ্যে বিস্তৃত। যেহেতু প্রতিটি সংগ্রহের সময়কাল পূর্ববর্তী 28-দিনের সমষ্টিগত ডেটা ধারণ করে, এবং সংগ্রহের সময়কাল প্রতি সপ্তাহে, এর অর্থ সংগ্রহের সময়গুলি ওভারল্যাপ হবে। এগুলি ডেটার চলমান গড়ের মতো, প্রতিটি পরবর্তী সময়ের মধ্যে তিন সপ্তাহের মূল্যের ডেটা অন্তর্ভুক্ত করা হয় এবং এক সপ্তাহ আলাদা।

সাপ্তাহিক আপডেট

ইতিহাস API প্রতি সোমবার 04:00 UTC এর কাছাকাছি আপডেট করা হয় এবং এতে আগের শনিবার পর্যন্ত ডেটা থাকে (স্ট্যান্ডার্ড 2-দিনের ব্যবধান অনুযায়ী)। এতে আগের 25 সপ্তাহ (প্রায় 6 মাস) মূল্যের ডেটা রয়েছে, প্রতি সপ্তাহে একটি সংগ্রহের সময়কাল।

আপডেট সময়ের জন্য কোন পরিষেবা স্তর চুক্তি নেই; এটি প্রতিদিন সর্বোত্তম প্রচেষ্টার ভিত্তিতে পরিচালিত হয়।

স্কিমা

CrUX History API-এর জন্য একটি একক এন্ডপয়েন্ট রয়েছে যা POST HTTP অনুরোধ গ্রহণ করে। এপিআই এমন একটি record ফেরত দেয় যাতে অনুরোধ করা উৎস বা পৃষ্ঠা সম্পর্কে কর্মক্ষমতা ডেটার সাথে সম্পর্কিত এক বা একাধিক metrics থাকে।

HTTP অনুরোধ

POST https://chromeuxreport.googleapis.com/v1/records:queryHistoryRecord

URL gRPC ট্রান্সকোডিং সিনট্যাক্স ব্যবহার করে।

শরীরের অনুরোধ

CrUX History API দৈনিক CrUX API হিসাবে একই অনুরোধ সংস্থাগুলি ব্যবহার করে, effectiveConnectionType অনুরোধ ক্ষেত্রটিকে সমর্থন না করার ব্যতিক্রম।

উদাহরণস্বরূপ, web.dev হোমপেজের জন্য ডেস্কটপের সবচেয়ে বড় বিষয়বস্তুযুক্ত পেইন্ট মানগুলির অনুরোধ করতে:

{
  "origin": "https://web.dev/",
  "formFactor": "DESKTOP",
  "metrics": [
    "largest_contentful_paint"
  ]
}

প্রতিক্রিয়া শরীর

সফল অনুরোধগুলি নিম্নলিখিত কাঠামোতে একটি record অবজেক্ট এবং urlNormalizationDetails সহ প্রতিক্রিয়া ফেরত দেয়:

{
  "record": {
    "key": {
      object (Key)
    },
    "metrics": [
      string: {
        object (Metric)
      }
    ]
  },
  "urlNormalizationDetails": {
    object (UrlNormalization)
  }
}

উদাহরণস্বরূপ, পূর্ববর্তী অনুরোধে অনুরোধের বডির প্রতিক্রিয়া হতে পারে:

{
  "record": {
    "key": {
      "origin": "https://web.dev"
    },
    "metrics": {
      "largest_contentful_paint": {
        "histogramTimeseries": [{
            "start": 0, "end": 2500, "densities": [
              0.9190, 0.9203, 0.9194, 0.9195, 0.9183, 0.9187, ...
            ]
          }, {
            "start": 2500, "end": 4000, "densities": [
              0.0521, 0.0513, 0.0518, 0.0518, 0.0526, 0.0527, ...
            ]
          },  {
            "start": 4000, "densities": [
              0.0288, 0.0282, 0.0286, 0.0285, 0.0290, 0.0285, ...
            ]
          }
        ],
        "percentilesTimeseries": {
          "p75s": [
            1362, 1352, 1344, 1356, 1366, 1377, ...
          ]
        }
      }
    },
    "collectionPeriods": [{
        "firstDate": { "year": 2022, "month": 7, "day": 10 },
        "lastDate": { "year": 2022, "month": 8, "day": 6 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 17 },
        "lastDate": { "year": 2022, "month": 8, "day": 13 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 24 },
        "lastDate": { "year": 2022, "month": 8, "day": 20 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 31 },
        "lastDate": { "year": 2022, "month": 8, "day": 27 }
      }, {
        "firstDate": { "year": 2022, "month": 8, "day": 7 },
        "lastDate": { "year": 2022, "month": 9, "day": 3 }
      }, {
        "firstDate": { "year": 2022, "month": 8, "day": 14 },
        "lastDate": { "year": 2022, "month": 9, "day": 10 }
      }, {
        ...
      }
    ]
  }
}

চাবি

Key এই রেকর্ডটিকে অনন্য হিসাবে চিহ্নিত করে এমন সমস্ত মাত্রা সংজ্ঞায়িত করে।

{
  "formFactor": enum (FormFactor),

  // Union field url_pattern can be only one of the following:
  "origin": string,
  "url": string
  // End of list of possible types for union field url_pattern.
}
ক্ষেত্র
formFactor

enum ( FormFactor )

ফর্ম ফ্যাক্টর হল ডিভাইস ক্লাস যা সমস্ত ব্যবহারকারী এই রেকর্ডের জন্য সাইট অ্যাক্সেস করতে ব্যবহার করে।

যদি ফর্ম ফ্যাক্টর অনির্দিষ্ট হয়, তাহলে সমস্ত ফর্ম ফ্যাক্টরগুলির সমষ্টিগত ডেটা ফেরত দেওয়া হবে।

ইউনিয়ন ক্ষেত্র url_ pattern । URL প্যাটার্ন হল সেই URL যা রেকর্ড প্রযোজ্য। url_ pattern নিম্নলিখিতগুলির মধ্যে একটি হতে পারে:
origin

string

অরিজিন নির্দিষ্ট করে যে এই রেকর্ডের জন্য।

দ্রষ্টব্য: একটি উত্স নির্দিষ্ট করার সময়, সমস্ত পৃষ্ঠাগুলিতে এই উত্সের অধীনে লোডের জন্য ডেটা মূল স্তরের ব্যবহারকারীর অভিজ্ঞতা ডেটাতে একত্রিত হয়৷

url

string

url একটি নির্দিষ্ট URL উল্লেখ করে যার জন্য এই রেকর্ড।

দ্রষ্টব্য: একটি url নির্দিষ্ট করার সময় শুধুমাত্র সেই নির্দিষ্ট URL-এর জন্য ডেটা একত্রিত করা হবে।

মেট্রিক্স

একটি metric হল একটি একক ওয়েব পারফরম্যান্স মেট্রিকের জন্য ব্যবহারকারীর অভিজ্ঞতার ডেটার একটি সেট, যেমন প্রথম বিষয়বস্তুপূর্ণ পেইন্ট। এটি bins একটি সিরিজ হিসাবে বাস্তব বিশ্বের Chrome ব্যবহারের একটি সারাংশ হিস্টোগ্রাম রয়েছে৷

{
  "histogramTimeseries": [
    {
      object (Bin)
    }
  ],
  "percentilesTimeseries": {
    object (Percentiles)
  }
}

বা

"fractionTimeseries": {
  object (Fractions)
}
ক্ষেত্র
histogramTimeseries[]

object ( Bin )

একটি মেট্রিকের জন্য ব্যবহারকারীর অভিজ্ঞতার টাইমসিরিজ হিস্টোগ্রাম। টাইমসিরিজ হিস্টোগ্রামে কমপক্ষে একটি বিন থাকবে এবং সমস্ত বিনের ঘনত্ব ~1 পর্যন্ত যোগ হবে।

সেই নির্দিষ্ট সংগ্রহের সময়ের জন্য অনুপস্থিত মানগুলিকে "NaN" হিসাবে চিহ্নিত করা হবে৷

percentilesTimeseries

object ( Percentiles )

মেট্রিকের সাধারণ উপযোগী পার্সেন্টাইল। পারসেন্টাইলের মান প্রকার হিস্টোগ্রাম বিনের জন্য প্রদত্ত মান প্রকারের মতোই হবে।

সেই নির্দিষ্ট সংগ্রহের সময়ের জন্য অনুপস্থিত মানগুলিকে null হিসাবে চিহ্নিত করা হবে।

fractionTimeseries

object ( Fractions )

এই বস্তুটিতে লেবেলযুক্ত ভগ্নাংশের টাইমসিরিজ রয়েছে, যা প্রতি এন্ট্রিতে ~1 পর্যন্ত যোগ করে।

ভগ্নাংশগুলিকে 4 দশমিক স্থানে বৃত্তাকার করা হয়।

অনুপস্থিত এন্ট্রিগুলি সমস্ত ভগ্নাংশ জুড়ে `"NaN"` হিসাবে প্রকাশ করা হয়৷

বিন

একটি bin হল ডেটার একটি বিচ্ছিন্ন অংশ যা শুরু থেকে শেষ পর্যন্ত বিস্তৃত হয়, অথবা যদি শুরু থেকে ধনাত্মক অসীম পর্যন্ত কোন শেষ না দেওয়া হয়।

একটি বিনের শুরু এবং শেষের মানগুলি মেট্রিকের মান প্রকারে দেওয়া হয় যা এটি প্রতিনিধিত্ব করে। উদাহরণস্বরূপ, প্রথম কনটেন্টফুল পেইন্টটি মিলিসেকেন্ডে পরিমাপ করা হয় এবং ints হিসাবে প্রকাশ করা হয়, তাই এর মেট্রিক বিনগুলি এর শুরু এবং শেষ প্রকারের জন্য int32s ব্যবহার করবে। তবে ক্রমবর্ধমান বিন্যাস স্থানান্তর ইউনিটহীন দশমিকে পরিমাপ করা হয় এবং একটি স্ট্রিং হিসাবে এনকোড করা দশমিক হিসাবে উন্মুক্ত করা হয়, তাই এর মেট্রিক বিনগুলি এর মান প্রকারের জন্য স্ট্রিং ব্যবহার করবে।

{
  "start": value,
  "end": value,
  "densities": [number, number, number...etc.]
}
ক্ষেত্র
start

(integer | string)

স্টার্ট হল ডাটা বিনের শুরু।

end

(integer | string)

শেষ হল ডাটা বিনের শেষ। যদি শেষ জনবহুল না হয়, তাহলে বিনের কোন শেষ নেই এবং এটি শুরু থেকে +inf পর্যন্ত বৈধ।

densities

array[number]

প্রদত্ত মেট্রিকের জন্য এই বিনের মান অভিজ্ঞ ব্যবহারকারীদের অনুপাতের একটি টাইমসিরিজ৷

ঘনত্ব 4 দশমিক স্থানে বৃত্তাকার।

শতকরা

Percentiles একটি প্রদত্ত পরিসংখ্যানগত শতাংশে একটি মেট্রিকের সিন্থেটিক মান রয়েছে। মোট ব্যবহারকারীর সংখ্যার মধ্যে শতকরা শতাংশ ব্যবহারকারীর দ্বারা অভিজ্ঞ মেট্রিকের মান অনুমান করার জন্য এগুলি ব্যবহার করা হয়।

{
  "P75": value
}
ক্ষেত্র
p75s

array[(integer | string)]

75% পৃষ্ঠা লোড হওয়া মানগুলির টাইমসিরিজ প্রদত্ত মেট্রিকটি এই মানের বা তার চেয়ে কম অনুভব করেছে৷

ভগ্নাংশ

Fractions লেবেলযুক্ত ভগ্নাংশের টাইমসিরিজ রয়েছে যা প্রতি এন্ট্রিতে ~1 পর্যন্ত যোগ করে। প্রতিটি লেবেল কোনো না কোনোভাবে একটি পৃষ্ঠা লোডকে বর্ণনা করে, তাই এইভাবে উপস্থাপিত মেট্রিকগুলিকে সংখ্যাসূচক মানের পরিবর্তে স্বতন্ত্র মান তৈরি করার কথা ভাবা যেতে পারে এবং ভগ্নাংশগুলি প্রকাশ করে যে একটি নির্দিষ্ট স্বতন্ত্র মান কত ঘন ঘন পরিমাপ করা হয়েছিল।

{
  "label_1": { "fractions": array[fraction]},
  "label_1": { "fractions": array[fraction]},
  ...
  "label_n": { "fractions": array[fraction]}
}

অনেকটা হিস্টোগ্রাম বিনের ঘনত্বের মানের মতো, প্রতিটি fraction একটি সংখ্যা 0.0 <= value <= 1.0 , এবং তারা ~1.0 পর্যন্ত যোগ করে। যখন একটি নির্দিষ্ট সংগ্রহের সময়ের জন্য মেট্রিক উপলব্ধ না হয়, তখন সংশ্লিষ্ট এন্ট্রিটি ভগ্নাংশের সমস্ত অ্যারেতে "NaN" হবে৷

ক্ষেত্র
p75s

array[(integer | string)]

75% পৃষ্ঠা লোড হওয়া মানগুলির টাইমসিরিজ প্রদত্ত মেট্রিকটি এই মানের বা তার চেয়ে কম অনুভব করেছে৷

ইউআরএল স্বাভাবিককরণ

সফল লুকআপের একটি উচ্চতর সম্ভাবনা অর্জনের জন্য একটি URL স্বাভাবিক করার জন্য নেওয়া স্বাভাবিককরণের ক্রিয়াগুলিকে প্রতিনিধিত্ব করে। এইগুলি হল সহজ স্বয়ংক্রিয় পরিবর্তন যা প্রদত্ত url_pattern সন্ধান করার সময় নেওয়া হয় ব্যর্থ বলে জানা যাবে৷ নিম্নোক্ত পুনঃনির্দেশের মতো জটিল ক্রিয়াগুলি পরিচালনা করা হয় না।

{
  "originalUrl": string,
  "normalizedUrl": string
}
ক্ষেত্র
originalUrl

string

যেকোন স্বাভাবিকীকরণ কর্মের আগে মূল অনুরোধ করা URL।

normalizedUrl

string

যেকোন স্বাভাবিকীকরণ কর্মের পরে URL। এটি একটি বৈধ ব্যবহারকারীর অভিজ্ঞতা URL যা যুক্তিসঙ্গতভাবে দেখা যেতে পারে৷

হারের সীমা

CrUX History API CrUX API- এর সাথে একই সীমা ভাগ করে প্রতি মিনিটে Google ক্লাউড প্রকল্পে প্রতি মিনিটে 150টি প্রশ্নের জন্য, যেটি কোনো চার্জ ছাড়াই দেওয়া হয়। এই সীমা, এবং আপনার বর্তমান ব্যবহার, Google ক্লাউড কনসোলে দেখা যাবে। এই উদার কোটা বেশিরভাগ ব্যবহারের ক্ষেত্রে যথেষ্ট হওয়া উচিত এবং বর্ধিত কোটার জন্য অর্থ প্রদান করা সম্ভব নয়।

,

CrUX History API পৃষ্ঠা এবং মূল গ্রানুলারিটিতে ছয় মাসের ঐতিহাসিক বাস্তব-ব্যবহারকারীর অভিজ্ঞতার ডেটাতে কম লেটেন্সি অ্যাক্সেস দেয়।

এটা চেষ্টা করুন!

সাধারণ ব্যবহারের ক্ষেত্রে

CrUX History API একটি নির্দিষ্ট URI-এর জন্য ঐতিহাসিক ব্যবহারকারীর অভিজ্ঞতা মেট্রিক্সের অনুসন্ধানের জন্য অনুমতি দেয় যেমন " https://example.com মূলের জন্য ঐতিহাসিক UX প্রবণতা পান।"

হিস্টোরি এপিআই দৈনিক CrUX API- এর মতো একই কাঠামো অনুসরণ করে, ব্যতীত মানগুলি একটি অ্যারেতে দেওয়া হয়, এবং কীগুলিকে বহুবচন নামের লেবেল করা হয় (উদাহরণস্বরূপ, histogram পরিবর্তে histogramTimeseries , অথবা p75 এর পরিবর্তে p75s )।

CrUX API কী

দৈনিক API-এর মতো, CrUX History API ব্যবহার করার জন্য Chrome UX Report API ব্যবহারের জন্য একটি Google Cloud API কী ব্যবস্থা করা প্রয়োজন.. একই কী দৈনিক এবং ইতিহাস API-এর জন্য ব্যবহার করা যেতে পারে।

একটি API কী অর্জন এবং ব্যবহার করা

একটি চাবি পান

অথবা শংসাপত্র পৃষ্ঠায় একটি তৈরি করুন।

আপনার একটি API কী থাকার পরে, আপনার অ্যাপ্লিকেশনটি সমস্ত অনুরোধের URL-এ ক্যোয়ারী প্যারামিটার key= yourAPIKey যোগ করতে পারে।

API কী ইউআরএল-এ এম্বেড করার জন্য নিরাপদ; এটা কোন এনকোডিং প্রয়োজন নেই.

উদাহরণ প্রশ্ন দেখুন.

ডেটা মডেল

এই বিভাগে অনুরোধ এবং প্রতিক্রিয়া তথ্যের গঠন বিবরণ.

রেকর্ড

একটি পৃষ্ঠা বা সাইট সম্পর্কে তথ্যের একটি পৃথক অংশ। একটি রেকর্ডে এমন ডেটা থাকতে পারে যা একটি শনাক্তকারীর জন্য এবং মাত্রার একটি নির্দিষ্ট সংমিশ্রণের জন্য নির্দিষ্ট। একটি রেকর্ডে এক বা একাধিক মেট্রিক্সের ডেটা থাকতে পারে।

শনাক্তকারী

শনাক্তকারীরা উল্লেখ করে যে কোন রেকর্ডগুলো দেখতে হবে। CrUX-এ এই শনাক্তকারীগুলি হল ওয়েবপেজ এবং ওয়েবসাইট৷

উৎপত্তি

যখন শনাক্তকারী একটি উত্স হয় তখন সেই উত্সের সমস্ত পৃষ্ঠাগুলির জন্য উপস্থিত সমস্ত ডেটা একসাথে একত্রিত হয়৷ উদাহরণ স্বরূপ, বলুন যে http://www.example.com মূলে এই সাইটম্যাপ দ্বারা নির্ধারিত পৃষ্ঠাগুলি ছিল:

http://www.example.com/
http://www.example.com/foo.html
http://www.example.com/bar.html

এর মানে হল যে যখন Chrome UX রিপোর্টের জন্য অনুসন্ধান করা হয় তখন http://www.example.com , http://www.example.com/ , http://www.example.com/foo.html , এবং http://www.example.com/bar.html ফেরত দেওয়া হবে, একসাথে একত্রিত করা হবে, কারণ সেগুলি সেই মূলের অধীনে থাকা সমস্ত পৃষ্ঠা।

ইউআরএল

শনাক্তকারী একটি URL হলে, শুধুমাত্র সেই নির্দিষ্ট URL-এর জন্য ডেটা ফেরত দেওয়া হবে৷ http://www.example.com মূল সাইটম্যাপের দিকে আবার খুঁজছি:

http://www.example.com/
http://www.example.com/foo.html
http://www.example.com/bar.html

যদি শনাক্তকারীটি http://www.example.com/foo.html এর মান সহ URL-এ সেট করা থাকে, তবে শুধুমাত্র সেই পৃষ্ঠার ডেটা ফেরত দেওয়া হবে।

মাত্রা

মাত্রাগুলি ডেটার একটি নির্দিষ্ট গোষ্ঠীকে চিহ্নিত করে যার বিরুদ্ধে একটি রেকর্ড একত্রিত করা হচ্ছে। উদাহরণস্বরূপ, PHONE এর একটি ফর্ম ফ্যাক্টর নির্দেশ করে যে রেকর্ডে মোবাইল ডিভাইসে লোড হওয়া সম্পর্কে তথ্য রয়েছে।

CrUX History API শুধুমাত্র ফর্ম ফ্যাক্টর ডাইমেনশন দ্বারা একত্রিত পাওয়া যায়। এটি একটি সাধারণ শ্রেণির ডিভাইস যা PHONE , TABLET এবং DESKTOP বিভক্ত।

মেট্রিক

আমরা পরিসংখ্যানগত সমষ্টির টাইমসিরিজে মেট্রিক্স রিপোর্ট করি, যা হিস্টোগ্রাম, শতাংশ এবং ভগ্নাংশ।

হিস্টোগ্রাম

যখন মেট্রিকগুলি হিস্টোগ্রাম অ্যারেতে প্রকাশ করা হয়, তখন প্রতিটি টাইমসিরিজ এন্ট্রি পৃষ্ঠা লোডের শতাংশের প্রতিনিধিত্ব করে যার জন্য মেট্রিকটি সকলের সমানুপাতিকভাবে একটি ব্যবধানে পড়েছিল। ডেটা পয়েন্টগুলি এপিআই দ্বারা প্রত্যাবর্তিত সংগ্রহের সময়কালের তারিখের ক্রমানুসারে উপস্থাপন করা হয়, প্রথম বিন্দুটি হল প্রাচীনতম সময়কাল এবং চূড়ান্ত বিন্দুটি সবচেয়ে সাম্প্রতিক সংগ্রহের সময়।

একটি উদাহরণ মেট্রিকের জন্য একটি তিন বিন হিস্টোগ্রাম এইরকম দেখায়:

{
  "histogramTimeseries": [
    {
      "start": 0,
      "end": 2500,
      "densities": [0.9190, 0.9203, 0.9194, 0.9195, 0.9183, 0.9187]
    },
    {
      "start": 2500,
      "end": 4000,
      "densities": [0.0521, 0.0513, 0.0518, 0.0518, 0.0526, 0.0527]
    },
    {
      "start": 4000,
      "densities": [0.0288, 0.0282, 0.0286, 0.0285, 0.0290, 0.0285]
    }
  ],
}

এই তথ্যটি নির্দেশ করে যে পৃষ্ঠা লোডের 91.90% ইতিহাসের প্রথম সংগ্রহের সময়কালের জন্য 0ms এবং 2,500ms এর মধ্যে উদাহরণ মেট্রিক মান অনুভব করেছে, তারপরে 92.03%, 91.94%... মেট্রিকের ইউনিটগুলি এই হিস্টোগ্রামে নেই, এই ক্ষেত্রে আমরা মিলিসেকেন্ড ধরে নেব।

উপরন্তু, পৃষ্ঠা লোডের 5.21% ইতিহাসের প্রথম সংগ্রহের সময়কালে 2,500ms এবং 4,000ms এর মধ্যে উদাহরণ মেট্রিক মান অনুভব করেছে, এবং 2.88% পৃষ্ঠা লোড ইতিহাসের প্রথম সংগ্রহের সময়কালে 4,000ms এর চেয়ে বেশি মান অনুভব করেছে৷

শতকরা

মেট্রিক্সে পারসেন্টাইলের টাইমসিরিজও থাকতে পারে যা অতিরিক্ত বিশ্লেষণের জন্য উপযোগী হতে পারে।

ডেটা পয়েন্টগুলি এপিআই দ্বারা প্রত্যাবর্তিত সংগ্রহের সময়কালের তারিখের ক্রমানুসারে উপস্থাপন করা হয়, প্রথম বিন্দুটি হল প্রাচীনতম সময়কাল এবং চূড়ান্ত বিন্দুটি সবচেয়ে সাম্প্রতিক সংগ্রহের সময়।

{
  "percentilesTimeseries": {
    "p75s": [1362, 1352, 1344, 1356, 1366, 1377]
  },
}

এই পার্সেন্টাইলগুলি সেই মেট্রিকের জন্য প্রদত্ত শতাংশে নির্দিষ্ট মেট্রিক মান দেখাতে পারে। এগুলি উপলব্ধ ডেটার সম্পূর্ণ সেটের উপর ভিত্তি করে এবং চূড়ান্ত বিন করা ডেটা নয়, তাই তারা অগত্যা একটি ইন্টারপোলেটেড পার্সেন্টাইলের সাথে মেলে না যা চূড়ান্ত বিন করা হিস্টোগ্রামের উপর ভিত্তি করে।

ভগ্নাংশ

মেট্রিক্স লেবেলযুক্ত ভগ্নাংশের টাইমসিরিজ হিসাবে প্রকাশ করা যেতে পারে; প্রতিটি লেবেল একটি নির্দিষ্ট উপায়ে একটি পৃষ্ঠা লোড বর্ণনা করে। ডেটা পয়েন্টগুলি এপিআই দ্বারা প্রত্যাবর্তিত সংগ্রহের সময়কালের তারিখের ক্রমানুসারে উপস্থাপন করা হয়, প্রথম বিন্দুটি হল প্রাচীনতম সময়কাল এবং চূড়ান্ত বিন্দুটি সবচেয়ে সাম্প্রতিক সংগ্রহের সময়।

উদাহরণ:

{    
  "fractionTimeseries": {
    "desktop": {"fractions": [0.3195, 0.2115, 0.1421]},
    "phone": {"fractions": [0.6295, 0.7544, 0.8288]},
    "tablet": {"fractions": [0.051, 0.0341, 0.029]}
  }
}

এই উদাহরণে, সাম্প্রতিকতম ডেটা পয়েন্ট নির্দেশ করে যে 14.21% পৃষ্ঠা লোড হয়েছে ডেস্কটপ থেকে, এবং 82.88% ফোন থেকে এসেছে৷

মেট্রিক মান প্রকার

যেহেতু CrUX History API একই মেট্রিক মান প্রকারগুলি ব্যবহার করে, আপনি আরও বিশদ বিবরণের জন্য দৈনিক CrUX API মেট্রিক মান প্রকারের ডকুমেন্টেশন উল্লেখ করতে পারেন।

মেট্রিক যোগ্যতা

যোগ্যতার মানদণ্ডের উপর ভিত্তি করে একটি উত্স বা URL শুধুমাত্র CrUX ইতিহাস API দ্বারা আচ্ছাদিত কিছু সংগ্রহের সময়কালের জন্য যোগ্য হতে পারে। এই ক্ষেত্রে CrUX History API histogramTimeseries ঘনত্বের জন্য "NaN" এবং সংগ্রহের সময়কালের জন্য percentilesTimeseries জন্য null যা কোনো যোগ্য ডেটা নেই। পার্থক্যের কারণ হল হিস্টোগ্রামের ঘনত্ব সর্বদা সংখ্যা, যখন শতকরা সংখ্যা বা স্ট্রিং হতে পারে (সিএলএস স্ট্রিং ব্যবহার করে, যদিও তারা সংখ্যার মতো দেখায়)।

উদাহরণস্বরূপ, যদি দ্বিতীয় মেয়াদে কোনো যোগ্য ডেটা না থাকে, তাহলে এটি এইভাবে দেখাবে:

{
  "histogramTimeseries": [
    {
      "start": 0,
      "end": 2500,
      "densities": [0.9190, "NaN", 0.9194, 0.9195, 0.9183, 0.9187]
    },
    {
      "start": 2500,
      "end": 4000,
      "densities": [0.0521, "NaN", 0.0518, 0.0518, 0.0526, 0.0527]
    },
    {
      "start": 4000,
      "densities": [0.0288, "NaN", 0.0286, 0.0285, 0.0290, 0.0285]
    }
  ],
  "percentilesTimeseries": {
    "p75s": [1362, null, 1344, 1356, 1366, 1377]
  },
}

ইউআরএল বা উৎসগুলির জন্য যা সময়ের সাথে সাথে যোগ্যতার মধ্যে পড়ে এবং এর বাইরে, আপনি অনেক অনুপস্থিত এন্ট্রি লক্ষ্য করতে পারেন।

সংগ্রহের সময়কাল

CrUX History API-এ firstDate এবং endDate ক্ষেত্রগুলির একটি অ্যারে সহ একটি collectionPeriods অবজেক্ট রয়েছে যা প্রতিটি একত্রীকরণ উইন্ডোর শুরু এবং শেষ তারিখগুলিকে উপস্থাপন করে। যেমন:

    "collectionPeriods": [{
        "firstDate": { "year": 2022, "month": 7, "day": 10 },
        "lastDate": { "year": 2022, "month": 8, "day": 6 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 17 },
        "lastDate": { "year": 2022, "month": 8, "day": 13 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 24 },
        "lastDate": { "year": 2022, "month": 8, "day": 20 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 31 },
        "lastDate": { "year": 2022, "month": 8, "day": 27 }
      }, {
        "firstDate": { "year": 2022, "month": 8, "day": 7 },
        "lastDate": { "year": 2022, "month": 9, "day": 3 }
      }, {
        "firstDate": { "year": 2022, "month": 8, "day": 14 },
        "lastDate": { "year": 2022, "month": 9, "day": 10 }
      }
    ]

এই সংগ্রহের সময়কাল ক্রমবর্ধমান ক্রমে এবং প্রতিক্রিয়ার অন্যান্য বিভাগে প্রতিটি ডেটা পয়েন্টের তারিখ স্প্যান উপস্থাপন করে।

ইতিহাস API প্রতি সোমবার আপডেট করা হয় এবং আগের শনিবার পর্যন্ত ডেটা ধারণ করে (স্ট্যান্ডার্ড 2-দিনের ব্যবধান অনুযায়ী)। এটিতে আগের 25-সপ্তাহের ডেটা রয়েছে—প্রতি সপ্তাহে একটি সংগ্রহের সময়কাল।

যেহেতু প্রতিটি সংগ্রহের সময়কাল পূর্ববর্তী 28-দিনের সমষ্টিগত ডেটা ধারণ করে, এবং সংগ্রহের সময়কাল প্রতি সপ্তাহে, এর অর্থ সংগ্রহের সময়গুলি ওভারল্যাপ হবে। এগুলি ডেটার চলমান গড়ের মতো, প্রতিটি পরবর্তী সময়ের মধ্যে তিন সপ্তাহের মূল্যের ডেটা অন্তর্ভুক্ত করা হয় এবং এক সপ্তাহ আলাদা।

উদাহরণ প্রশ্ন

POST বডিতে JSON অবজেক্ট হিসেবে ক্যোয়ারী ডেটা সহ https://chromeuxreport.googleapis.com/v1/records:queryHistoryRecord?key=[YOUR_API_KEY]" এ পোস্ট অনুরোধ ব্যবহার করে JSON অবজেক্ট হিসেবে প্রশ্নগুলি জমা দেওয়া হয়।

দৈনিক CrUX API-এর queryRecord প্রতিস্থাপন করে queryHistoryRecord এর ব্যবহার লক্ষ্য করুন।

একটি উদাহরণ শরীর হল:

{
  "origin": "https://example.com",
  "formFactor": "PHONE",
  "metrics": [
    "largest_contentful_paint",
    "experimental_time_to_first_byte"
  ]
}

উদাহরণস্বরূপ, এটিকে নিম্নলিখিত কমান্ড লাইনের সাহায্যে curl থেকে কল করা যেতে পারে (আপনার কী দিয়ে API_KEY প্রতিস্থাপন করা):

curl -s --request POST 'https://chromeuxreport.googleapis.com/v1/records:queryHistoryRecord?key=API_KEY' \
    --header 'Accept: application/json' \
    --header 'Content-Type: application/json' \
    --data '{"formFactor":"PHONE","origin":"https://www.example.com","metrics":["largest_contentful_paint", "experimental_time_to_first_byte"]}'

পৃষ্ঠা-স্তরের ডেটা origin পরিবর্তে কোয়েরিতে একটি url সম্পত্তি পাস করে API-এর মাধ্যমে পাওয়া যায়:

{
  "url": "https://example.com/page",
  "formFactor": "PHONE",
  "metrics": [
    "largest_contentful_paint",
    "experimental_time_to_first_byte"
  ]
}

যদি metrics প্রপার্টি সেট করা না থাকে তাহলে সমস্ত উপলব্ধ মেট্রিক ফেরত দেওয়া হবে:

  • cumulative_layout_shift
  • first_contentful_paint
  • interaction_to_next_paint
  • largest_contentful_paint
  • experimental_time_to_first_byte
  • navigation_types
  • round_trip_time
  • form_factors (অনুরোধে কোনো formFactor উল্লেখ না থাকলে শুধুমাত্র রিপোর্ট করা হয়)

যদি কোন formFactor মান প্রদান করা না হয় তাহলে মানগুলি সমস্ত ফর্ম ফ্যাক্টর জুড়ে একত্রিত হবে।

আরও উদাহরণের জন্য CrUX History API নির্দেশিকা ব্যবহার করা দেখুন।

ডেটা পাইপলাইন

CrUX ডেটাসেট API-এর মাধ্যমে উপলব্ধ হওয়ার আগে ডেটা একত্রীকরণ, একত্রিত এবং ফিল্টার করার জন্য একটি পাইপলাইনের মাধ্যমে প্রক্রিয়া করা হয়।

রোলিং গড়

ক্রোম ইউএক্স রিপোর্টের ডেটা হল একত্রিত মেট্রিক্সের 28-দিনের রোলিং গড়৷ এর মানে হল যে কোনও নির্দিষ্ট সময়ে Chrome UX রিপোর্টে উপস্থাপিত ডেটা আসলে গত 28 দিনের একত্রিত ডেটা।

হিস্ট্রি এপিআই-এ অনেকগুলি সংগ্রহের সময়কাল রয়েছে, প্রতিটি এই 28 দিনের মধ্যে বিস্তৃত। যেহেতু প্রতিটি সংগ্রহের সময়কাল পূর্ববর্তী 28-দিনের সমষ্টিগত ডেটা ধারণ করে, এবং সংগ্রহের সময়কাল প্রতি সপ্তাহে, এর অর্থ সংগ্রহের সময়গুলি ওভারল্যাপ হবে। এগুলি ডেটার চলমান গড়ের মতো, প্রতিটি পরবর্তী সময়ের মধ্যে তিন সপ্তাহের মূল্যের ডেটা অন্তর্ভুক্ত করা হয় এবং এক সপ্তাহ আলাদা।

সাপ্তাহিক আপডেট

ইতিহাস API প্রতি সোমবার 04:00 UTC এর কাছাকাছি আপডেট করা হয় এবং এতে আগের শনিবার পর্যন্ত ডেটা থাকে (স্ট্যান্ডার্ড 2-দিনের ব্যবধান অনুযায়ী)। এতে আগের 25 সপ্তাহ (প্রায় 6 মাস) মূল্যের ডেটা রয়েছে, প্রতি সপ্তাহে একটি সংগ্রহের সময়কাল।

আপডেট সময়ের জন্য কোন পরিষেবা স্তর চুক্তি নেই; এটি প্রতিদিন সর্বোত্তম প্রচেষ্টার ভিত্তিতে পরিচালিত হয়।

স্কিমা

CrUX History API-এর জন্য একটি একক এন্ডপয়েন্ট রয়েছে যা POST HTTP অনুরোধ গ্রহণ করে। এপিআই এমন একটি record ফেরত দেয় যাতে অনুরোধ করা উৎস বা পৃষ্ঠা সম্পর্কে কর্মক্ষমতা ডেটার সাথে সম্পর্কিত এক বা একাধিক metrics থাকে।

HTTP অনুরোধ

POST https://chromeuxreport.googleapis.com/v1/records:queryHistoryRecord

URL gRPC ট্রান্সকোডিং সিনট্যাক্স ব্যবহার করে।

শরীরের অনুরোধ

CrUX History API দৈনিক CrUX API হিসাবে একই অনুরোধ সংস্থাগুলি ব্যবহার করে, effectiveConnectionType অনুরোধ ক্ষেত্রটিকে সমর্থন না করার ব্যতিক্রম।

উদাহরণস্বরূপ, web.dev হোমপেজের জন্য ডেস্কটপের সবচেয়ে বড় বিষয়বস্তুযুক্ত পেইন্ট মানগুলির অনুরোধ করতে:

{
  "origin": "https://web.dev/",
  "formFactor": "DESKTOP",
  "metrics": [
    "largest_contentful_paint"
  ]
}

প্রতিক্রিয়া শরীর

সফল অনুরোধগুলি নিম্নলিখিত কাঠামোতে একটি record অবজেক্ট এবং urlNormalizationDetails সহ প্রতিক্রিয়া ফেরত দেয়:

{
  "record": {
    "key": {
      object (Key)
    },
    "metrics": [
      string: {
        object (Metric)
      }
    ]
  },
  "urlNormalizationDetails": {
    object (UrlNormalization)
  }
}

উদাহরণস্বরূপ, পূর্ববর্তী অনুরোধে অনুরোধের বডির প্রতিক্রিয়া হতে পারে:

{
  "record": {
    "key": {
      "origin": "https://web.dev"
    },
    "metrics": {
      "largest_contentful_paint": {
        "histogramTimeseries": [{
            "start": 0, "end": 2500, "densities": [
              0.9190, 0.9203, 0.9194, 0.9195, 0.9183, 0.9187, ...
            ]
          }, {
            "start": 2500, "end": 4000, "densities": [
              0.0521, 0.0513, 0.0518, 0.0518, 0.0526, 0.0527, ...
            ]
          },  {
            "start": 4000, "densities": [
              0.0288, 0.0282, 0.0286, 0.0285, 0.0290, 0.0285, ...
            ]
          }
        ],
        "percentilesTimeseries": {
          "p75s": [
            1362, 1352, 1344, 1356, 1366, 1377, ...
          ]
        }
      }
    },
    "collectionPeriods": [{
        "firstDate": { "year": 2022, "month": 7, "day": 10 },
        "lastDate": { "year": 2022, "month": 8, "day": 6 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 17 },
        "lastDate": { "year": 2022, "month": 8, "day": 13 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 24 },
        "lastDate": { "year": 2022, "month": 8, "day": 20 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 31 },
        "lastDate": { "year": 2022, "month": 8, "day": 27 }
      }, {
        "firstDate": { "year": 2022, "month": 8, "day": 7 },
        "lastDate": { "year": 2022, "month": 9, "day": 3 }
      }, {
        "firstDate": { "year": 2022, "month": 8, "day": 14 },
        "lastDate": { "year": 2022, "month": 9, "day": 10 }
      }, {
        ...
      }
    ]
  }
}

চাবি

Key এই রেকর্ডটিকে অনন্য হিসাবে চিহ্নিত করে এমন সমস্ত মাত্রা সংজ্ঞায়িত করে।

{
  "formFactor": enum (FormFactor),

  // Union field url_pattern can be only one of the following:
  "origin": string,
  "url": string
  // End of list of possible types for union field url_pattern.
}
ক্ষেত্র
formFactor

enum ( FormFactor )

ফর্ম ফ্যাক্টর হল ডিভাইস ক্লাস যা সমস্ত ব্যবহারকারী এই রেকর্ডের জন্য সাইট অ্যাক্সেস করতে ব্যবহার করে।

যদি ফর্ম ফ্যাক্টর অনির্দিষ্ট হয়, তাহলে সমস্ত ফর্ম ফ্যাক্টরগুলির সমষ্টিগত ডেটা ফেরত দেওয়া হবে।

ইউনিয়ন ক্ষেত্র url_ pattern । URL প্যাটার্ন হল সেই URL যা রেকর্ড প্রযোজ্য। url_ pattern নিম্নলিখিতগুলির মধ্যে একটি হতে পারে:
origin

string

অরিজিন নির্দিষ্ট করে যে এই রেকর্ডের জন্য।

দ্রষ্টব্য: একটি উত্স নির্দিষ্ট করার সময়, সমস্ত পৃষ্ঠাগুলিতে এই উত্সের অধীনে লোডের জন্য ডেটা মূল স্তরের ব্যবহারকারীর অভিজ্ঞতা ডেটাতে একত্রিত হয়৷

url

string

url একটি নির্দিষ্ট URL উল্লেখ করে যার জন্য এই রেকর্ড।

দ্রষ্টব্য: একটি url নির্দিষ্ট করার সময় শুধুমাত্র সেই নির্দিষ্ট URL-এর জন্য ডেটা একত্রিত করা হবে।

মেট্রিক্স

একটি metric হল একটি একক ওয়েব পারফরম্যান্স মেট্রিকের জন্য ব্যবহারকারীর অভিজ্ঞতার ডেটার একটি সেট, যেমন প্রথম বিষয়বস্তুপূর্ণ পেইন্ট। এটি bins একটি সিরিজ হিসাবে বাস্তব বিশ্বের Chrome ব্যবহারের একটি সারাংশ হিস্টোগ্রাম রয়েছে৷

{
  "histogramTimeseries": [
    {
      object (Bin)
    }
  ],
  "percentilesTimeseries": {
    object (Percentiles)
  }
}

বা

"fractionTimeseries": {
  object (Fractions)
}
ক্ষেত্র
histogramTimeseries[]

object ( Bin )

একটি মেট্রিকের জন্য ব্যবহারকারীর অভিজ্ঞতার টাইমসিরিজ হিস্টোগ্রাম। টাইমসিরিজ হিস্টোগ্রামে কমপক্ষে একটি বিন থাকবে এবং সমস্ত বিনের ঘনত্ব ~1 পর্যন্ত যোগ হবে।

সেই নির্দিষ্ট সংগ্রহের সময়ের জন্য অনুপস্থিত মানগুলিকে "NaN" হিসাবে চিহ্নিত করা হবে৷

percentilesTimeseries

object ( Percentiles )

মেট্রিকের সাধারণ উপযোগী পার্সেন্টাইল। পারসেন্টাইলের মান প্রকার হিস্টোগ্রাম বিনের জন্য প্রদত্ত মান প্রকারের মতোই হবে।

সেই নির্দিষ্ট সংগ্রহের সময়ের জন্য অনুপস্থিত মানগুলিকে null হিসাবে চিহ্নিত করা হবে।

fractionTimeseries

object ( Fractions )

এই বস্তুটিতে লেবেলযুক্ত ভগ্নাংশের টাইমসিরিজ রয়েছে, যা প্রতি এন্ট্রিতে ~1 পর্যন্ত যোগ করে।

ভগ্নাংশগুলিকে 4 দশমিক স্থানে বৃত্তাকার করা হয়।

অনুপস্থিত এন্ট্রিগুলি সমস্ত ভগ্নাংশ জুড়ে `"NaN"` হিসাবে প্রকাশ করা হয়৷

বিন

একটি bin হল ডেটার একটি বিচ্ছিন্ন অংশ যা শুরু থেকে শেষ পর্যন্ত বিস্তৃত হয়, অথবা যদি শুরু থেকে ধনাত্মক অসীম পর্যন্ত কোন শেষ না দেওয়া হয়।

একটি বিনের শুরু এবং শেষের মানগুলি মেট্রিকের মান প্রকারে দেওয়া হয় যা এটি প্রতিনিধিত্ব করে। উদাহরণস্বরূপ, প্রথম কনটেন্টফুল পেইন্টটি মিলিসেকেন্ডে পরিমাপ করা হয় এবং ints হিসাবে প্রকাশ করা হয়, তাই এর মেট্রিক বিনগুলি এর শুরু এবং শেষ প্রকারের জন্য int32s ব্যবহার করবে। তবে ক্রমবর্ধমান বিন্যাস স্থানান্তর ইউনিটহীন দশমিকে পরিমাপ করা হয় এবং একটি স্ট্রিং হিসাবে এনকোড করা দশমিক হিসাবে উন্মুক্ত করা হয়, তাই এর মেট্রিক বিনগুলি এর মান প্রকারের জন্য স্ট্রিং ব্যবহার করবে।

{
  "start": value,
  "end": value,
  "densities": [number, number, number...etc.]
}
ক্ষেত্র
start

(integer | string)

স্টার্ট হল ডাটা বিনের শুরু।

end

(integer | string)

শেষ হল ডাটা বিনের শেষ। যদি শেষ জনবহুল না হয়, তাহলে বিনের কোন শেষ নেই এবং এটি শুরু থেকে +inf পর্যন্ত বৈধ।

densities

array[number]

প্রদত্ত মেট্রিকের জন্য এই বিনের মান অভিজ্ঞ ব্যবহারকারীদের অনুপাতের একটি টাইমসিরিজ৷

ঘনত্ব 4 দশমিক স্থানে বৃত্তাকার।

শতকরা

Percentiles একটি প্রদত্ত পরিসংখ্যানগত শতাংশে একটি মেট্রিকের সিন্থেটিক মান রয়েছে। মোট ব্যবহারকারীর সংখ্যার মধ্যে শতকরা শতাংশ ব্যবহারকারীর দ্বারা অভিজ্ঞ মেট্রিকের মান অনুমান করার জন্য এগুলি ব্যবহার করা হয়।

{
  "P75": value
}
ক্ষেত্র
p75s

array[(integer | string)]

75% পৃষ্ঠা লোড হওয়া মানগুলির টাইমসিরিজ প্রদত্ত মেট্রিকটি এই মানের বা তার চেয়ে কম অনুভব করেছে৷

ভগ্নাংশ

Fractions লেবেলযুক্ত ভগ্নাংশের টাইমসিরিজ রয়েছে যা প্রতি এন্ট্রিতে ~1 পর্যন্ত যোগ করে। প্রতিটি লেবেল কোনো না কোনোভাবে একটি পৃষ্ঠা লোডকে বর্ণনা করে, তাই এইভাবে উপস্থাপিত মেট্রিকগুলিকে সংখ্যাসূচক মানের পরিবর্তে স্বতন্ত্র মান তৈরি করার কথা ভাবা যেতে পারে এবং ভগ্নাংশগুলি প্রকাশ করে যে একটি নির্দিষ্ট স্বতন্ত্র মান কত ঘন ঘন পরিমাপ করা হয়েছিল।

{
  "label_1": { "fractions": array[fraction]},
  "label_1": { "fractions": array[fraction]},
  ...
  "label_n": { "fractions": array[fraction]}
}

অনেকটা হিস্টোগ্রাম বিনের ঘনত্বের মানের মতো, প্রতিটি fraction একটি সংখ্যা 0.0 <= value <= 1.0 , এবং তারা ~1.0 পর্যন্ত যোগ করে। যখন একটি নির্দিষ্ট সংগ্রহের সময়ের জন্য মেট্রিক উপলব্ধ না হয়, তখন সংশ্লিষ্ট এন্ট্রিটি ভগ্নাংশের সমস্ত অ্যারেতে "NaN" হবে৷

ক্ষেত্র
p75s

array[(integer | string)]

75% পৃষ্ঠা লোড হওয়া মানগুলির টাইমসিরিজ প্রদত্ত মেট্রিকটি এই মানের বা তার চেয়ে কম অনুভব করেছে৷

ইউআরএল স্বাভাবিককরণ

সফল লুকআপের একটি উচ্চতর সম্ভাবনা অর্জনের জন্য একটি URL স্বাভাবিক করার জন্য নেওয়া স্বাভাবিককরণের ক্রিয়াগুলিকে প্রতিনিধিত্ব করে। এইগুলি হল সহজ স্বয়ংক্রিয় পরিবর্তন যা প্রদত্ত url_pattern সন্ধান করার সময় নেওয়া হয় ব্যর্থ বলে জানা যাবে৷ নিম্নোক্ত পুনঃনির্দেশের মতো জটিল ক্রিয়াগুলি পরিচালনা করা হয় না।

{
  "originalUrl": string,
  "normalizedUrl": string
}
ক্ষেত্র
originalUrl

string

যেকোন স্বাভাবিকীকরণ কর্মের আগে মূল অনুরোধ করা URL।

normalizedUrl

string

যেকোন স্বাভাবিকীকরণ কর্মের পরে URL। এটি একটি বৈধ ব্যবহারকারীর অভিজ্ঞতা URL যা যুক্তিসঙ্গতভাবে দেখা যেতে পারে৷

হারের সীমা

CrUX History API CrUX API- এর সাথে একই সীমা ভাগ করে প্রতি মিনিটে Google ক্লাউড প্রকল্পে প্রতি মিনিটে 150টি প্রশ্নের জন্য, যেটি কোনো চার্জ ছাড়াই দেওয়া হয়। এই সীমা, এবং আপনার বর্তমান ব্যবহার, Google ক্লাউড কনসোলে দেখা যাবে। এই উদার কোটা বেশিরভাগ ব্যবহারের ক্ষেত্রে যথেষ্ট হওয়া উচিত এবং বর্ধিত কোটার জন্য অর্থ প্রদান করা সম্ভব নয়।

,

CrUX History API পৃষ্ঠা এবং মূল গ্রানুলারিটিতে ছয় মাসের ঐতিহাসিক বাস্তব-ব্যবহারকারীর অভিজ্ঞতার ডেটাতে কম লেটেন্সি অ্যাক্সেস দেয়।

এটা চেষ্টা করুন!

সাধারণ ব্যবহারের ক্ষেত্রে

CrUX History API একটি নির্দিষ্ট URI-এর জন্য ঐতিহাসিক ব্যবহারকারীর অভিজ্ঞতা মেট্রিক্সের অনুসন্ধানের জন্য অনুমতি দেয় যেমন " https://example.com মূলের জন্য ঐতিহাসিক UX প্রবণতা পান।"

হিস্টোরি এপিআই দৈনিক CrUX API- এর মতো একই কাঠামো অনুসরণ করে, ব্যতীত মানগুলি একটি অ্যারেতে দেওয়া হয়, এবং কীগুলিকে বহুবচন নামের লেবেল করা হয় (উদাহরণস্বরূপ, histogram পরিবর্তে histogramTimeseries , অথবা p75 এর পরিবর্তে p75s )।

CrUX API কী

দৈনিক API-এর মতো, CrUX History API ব্যবহার করার জন্য Chrome UX Report API ব্যবহারের জন্য একটি Google Cloud API কী ব্যবস্থা করা প্রয়োজন.. একই কী দৈনিক এবং ইতিহাস API-এর জন্য ব্যবহার করা যেতে পারে।

একটি API কী অর্জন এবং ব্যবহার করা

একটি চাবি পান

অথবা শংসাপত্র পৃষ্ঠায় একটি তৈরি করুন।

আপনার একটি API কী থাকার পরে, আপনার অ্যাপ্লিকেশনটি সমস্ত অনুরোধের URL-এ ক্যোয়ারী প্যারামিটার key= yourAPIKey যোগ করতে পারে।

API কী ইউআরএল-এ এম্বেড করার জন্য নিরাপদ; এটা কোন এনকোডিং প্রয়োজন নেই.

উদাহরণ প্রশ্ন দেখুন.

ডেটা মডেল

এই বিভাগে অনুরোধ এবং প্রতিক্রিয়া তথ্যের গঠন বিবরণ.

রেকর্ড

একটি পৃষ্ঠা বা সাইট সম্পর্কে তথ্যের একটি পৃথক অংশ। একটি রেকর্ডে এমন ডেটা থাকতে পারে যা একটি শনাক্তকারীর জন্য এবং মাত্রার একটি নির্দিষ্ট সংমিশ্রণের জন্য নির্দিষ্ট। একটি রেকর্ডে এক বা একাধিক মেট্রিক্সের ডেটা থাকতে পারে।

শনাক্তকারী

শনাক্তকারীরা উল্লেখ করে যে কোন রেকর্ডগুলো দেখতে হবে। CrUX-এ এই শনাক্তকারীগুলি হল ওয়েবপেজ এবং ওয়েবসাইট৷

উৎপত্তি

যখন শনাক্তকারী একটি উত্স হয় তখন সেই উত্সের সমস্ত পৃষ্ঠাগুলির জন্য উপস্থিত সমস্ত ডেটা একসাথে একত্রিত হয়৷ উদাহরণ স্বরূপ, বলুন যে http://www.example.com মূলে এই সাইটম্যাপ দ্বারা নির্ধারিত পৃষ্ঠাগুলি ছিল:

http://www.example.com/
http://www.example.com/foo.html
http://www.example.com/bar.html

এর মানে হল যে যখন Chrome UX রিপোর্টের জন্য অনুসন্ধান করা হয় তখন http://www.example.com , http://www.example.com/ , http://www.example.com/foo.html , এবং http://www.example.com/bar.html ফেরত দেওয়া হবে, একসাথে একত্রিত করা হবে, কারণ সেগুলি সেই মূলের অধীনে থাকা সমস্ত পৃষ্ঠা।

ইউআরএল

শনাক্তকারী একটি URL হলে, শুধুমাত্র সেই নির্দিষ্ট URL-এর জন্য ডেটা ফেরত দেওয়া হবে৷ http://www.example.com মূল সাইটম্যাপের দিকে আবার খুঁজছি:

http://www.example.com/
http://www.example.com/foo.html
http://www.example.com/bar.html

যদি শনাক্তকারীটি http://www.example.com/foo.html এর মান সহ URL-এ সেট করা থাকে, তবে শুধুমাত্র সেই পৃষ্ঠার ডেটা ফেরত দেওয়া হবে।

মাত্রা

মাত্রাগুলি ডেটার একটি নির্দিষ্ট গোষ্ঠীকে চিহ্নিত করে যার বিরুদ্ধে একটি রেকর্ড একত্রিত করা হচ্ছে। উদাহরণস্বরূপ, PHONE এর একটি ফর্ম ফ্যাক্টর নির্দেশ করে যে রেকর্ডে মোবাইল ডিভাইসে লোড হওয়া সম্পর্কে তথ্য রয়েছে।

CrUX History API শুধুমাত্র ফর্ম ফ্যাক্টর ডাইমেনশন দ্বারা একত্রিত পাওয়া যায়। এটি একটি সাধারণ শ্রেণির ডিভাইস যা PHONE , TABLET এবং DESKTOP বিভক্ত।

মেট্রিক

আমরা পরিসংখ্যানগত সমষ্টির টাইমসিরিজে মেট্রিক্স রিপোর্ট করি, যা হিস্টোগ্রাম, শতাংশ এবং ভগ্নাংশ।

হিস্টোগ্রাম

যখন মেট্রিকগুলি হিস্টোগ্রাম অ্যারেতে প্রকাশ করা হয়, তখন প্রতিটি টাইমসিরিজ এন্ট্রি পৃষ্ঠা লোডের শতাংশের প্রতিনিধিত্ব করে যার জন্য মেট্রিকটি সকলের সমানুপাতিকভাবে একটি ব্যবধানে পড়েছিল। ডেটা পয়েন্টগুলি এপিআই দ্বারা প্রত্যাবর্তিত সংগ্রহের সময়কালের তারিখের ক্রমানুসারে উপস্থাপন করা হয়, প্রথম বিন্দুটি হল প্রাচীনতম সময়কাল এবং চূড়ান্ত বিন্দুটি সবচেয়ে সাম্প্রতিক সংগ্রহের সময়।

একটি উদাহরণ মেট্রিকের জন্য একটি তিন বিন হিস্টোগ্রাম এইরকম দেখায়:

{
  "histogramTimeseries": [
    {
      "start": 0,
      "end": 2500,
      "densities": [0.9190, 0.9203, 0.9194, 0.9195, 0.9183, 0.9187]
    },
    {
      "start": 2500,
      "end": 4000,
      "densities": [0.0521, 0.0513, 0.0518, 0.0518, 0.0526, 0.0527]
    },
    {
      "start": 4000,
      "densities": [0.0288, 0.0282, 0.0286, 0.0285, 0.0290, 0.0285]
    }
  ],
}

এই তথ্যটি নির্দেশ করে যে পৃষ্ঠা লোডের 91.90% ইতিহাসের প্রথম সংগ্রহের সময়কালের জন্য 0ms এবং 2,500ms এর মধ্যে উদাহরণ মেট্রিক মান অনুভব করেছে, তারপরে 92.03%, 91.94%... মেট্রিকের ইউনিটগুলি এই হিস্টোগ্রামে নেই, এই ক্ষেত্রে আমরা মিলিসেকেন্ড ধরে নেব।

উপরন্তু, পৃষ্ঠা লোডের 5.21% ইতিহাসের প্রথম সংগ্রহের সময়কালে 2,500ms এবং 4,000ms এর মধ্যে উদাহরণ মেট্রিক মান অনুভব করেছে, এবং 2.88% পৃষ্ঠা লোড ইতিহাসের প্রথম সংগ্রহের সময়কালে 4,000ms এর চেয়ে বেশি মান অনুভব করেছে৷

শতকরা

মেট্রিক্সে পারসেন্টাইলের টাইমসিরিজও থাকতে পারে যা অতিরিক্ত বিশ্লেষণের জন্য উপযোগী হতে পারে।

ডেটা পয়েন্টগুলি এপিআই দ্বারা প্রত্যাবর্তিত সংগ্রহের সময়কালের তারিখের ক্রমানুসারে উপস্থাপন করা হয়, প্রথম বিন্দুটি হল প্রাচীনতম সময়কাল এবং চূড়ান্ত বিন্দুটি সবচেয়ে সাম্প্রতিক সংগ্রহের সময়।

{
  "percentilesTimeseries": {
    "p75s": [1362, 1352, 1344, 1356, 1366, 1377]
  },
}

এই পার্সেন্টাইলগুলি সেই মেট্রিকের জন্য প্রদত্ত শতাংশে নির্দিষ্ট মেট্রিক মান দেখাতে পারে। এগুলি উপলব্ধ ডেটার সম্পূর্ণ সেটের উপর ভিত্তি করে এবং চূড়ান্ত বিন করা ডেটা নয়, তাই তারা অগত্যা একটি ইন্টারপোলেটেড পার্সেন্টাইলের সাথে মেলে না যা চূড়ান্ত বিন করা হিস্টোগ্রামের উপর ভিত্তি করে।

ভগ্নাংশ

মেট্রিক্স লেবেলযুক্ত ভগ্নাংশের টাইমসিরিজ হিসাবে প্রকাশ করা যেতে পারে; প্রতিটি লেবেল একটি নির্দিষ্ট উপায়ে একটি পৃষ্ঠা লোড বর্ণনা করে। ডেটা পয়েন্টগুলি এপিআই দ্বারা প্রত্যাবর্তিত সংগ্রহের সময়কালের তারিখের ক্রমানুসারে উপস্থাপন করা হয়, প্রথম বিন্দুটি হল প্রাচীনতম সময়কাল এবং চূড়ান্ত বিন্দুটি সবচেয়ে সাম্প্রতিক সংগ্রহের সময়।

উদাহরণ:

{    
  "fractionTimeseries": {
    "desktop": {"fractions": [0.3195, 0.2115, 0.1421]},
    "phone": {"fractions": [0.6295, 0.7544, 0.8288]},
    "tablet": {"fractions": [0.051, 0.0341, 0.029]}
  }
}

এই উদাহরণে, সাম্প্রতিকতম ডেটা পয়েন্ট নির্দেশ করে যে 14.21% পৃষ্ঠা লোড হয়েছে ডেস্কটপ থেকে, এবং 82.88% ফোন থেকে এসেছে৷

মেট্রিক মান প্রকার

যেহেতু CrUX History API একই মেট্রিক মান প্রকারগুলি ব্যবহার করে, আপনি আরও বিশদ বিবরণের জন্য দৈনিক CrUX API মেট্রিক মান প্রকারের ডকুমেন্টেশন উল্লেখ করতে পারেন।

মেট্রিক যোগ্যতা

যোগ্যতার মানদণ্ডের উপর ভিত্তি করে একটি উত্স বা URL শুধুমাত্র CrUX ইতিহাস API দ্বারা আচ্ছাদিত কিছু সংগ্রহের সময়কালের জন্য যোগ্য হতে পারে। এই ক্ষেত্রে CrUX History API histogramTimeseries ঘনত্বের জন্য "NaN" এবং সংগ্রহের সময়কালের জন্য percentilesTimeseries জন্য null যা কোনো যোগ্য ডেটা নেই। পার্থক্যের কারণ হল হিস্টোগ্রামের ঘনত্ব সর্বদা সংখ্যা, যখন শতকরা সংখ্যা বা স্ট্রিং হতে পারে (সিএলএস স্ট্রিং ব্যবহার করে, যদিও তারা সংখ্যার মতো দেখায়)।

উদাহরণস্বরূপ, যদি দ্বিতীয় মেয়াদে কোনো যোগ্য ডেটা না থাকে, তাহলে এটি এইভাবে দেখাবে:

{
  "histogramTimeseries": [
    {
      "start": 0,
      "end": 2500,
      "densities": [0.9190, "NaN", 0.9194, 0.9195, 0.9183, 0.9187]
    },
    {
      "start": 2500,
      "end": 4000,
      "densities": [0.0521, "NaN", 0.0518, 0.0518, 0.0526, 0.0527]
    },
    {
      "start": 4000,
      "densities": [0.0288, "NaN", 0.0286, 0.0285, 0.0290, 0.0285]
    }
  ],
  "percentilesTimeseries": {
    "p75s": [1362, null, 1344, 1356, 1366, 1377]
  },
}

ইউআরএল বা উৎসগুলির জন্য যা সময়ের সাথে সাথে যোগ্যতার মধ্যে পড়ে এবং এর বাইরে, আপনি অনেক অনুপস্থিত এন্ট্রি লক্ষ্য করতে পারেন।

সংগ্রহের সময়কাল

CrUX History API-এ firstDate এবং endDate ক্ষেত্রগুলির একটি অ্যারে সহ একটি collectionPeriods অবজেক্ট রয়েছে যা প্রতিটি একত্রীকরণ উইন্ডোর শুরু এবং শেষ তারিখগুলিকে উপস্থাপন করে। যেমন:

    "collectionPeriods": [{
        "firstDate": { "year": 2022, "month": 7, "day": 10 },
        "lastDate": { "year": 2022, "month": 8, "day": 6 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 17 },
        "lastDate": { "year": 2022, "month": 8, "day": 13 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 24 },
        "lastDate": { "year": 2022, "month": 8, "day": 20 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 31 },
        "lastDate": { "year": 2022, "month": 8, "day": 27 }
      }, {
        "firstDate": { "year": 2022, "month": 8, "day": 7 },
        "lastDate": { "year": 2022, "month": 9, "day": 3 }
      }, {
        "firstDate": { "year": 2022, "month": 8, "day": 14 },
        "lastDate": { "year": 2022, "month": 9, "day": 10 }
      }
    ]

এই সংগ্রহের সময়কাল ক্রমবর্ধমান ক্রমে এবং প্রতিক্রিয়ার অন্যান্য বিভাগে প্রতিটি ডেটা পয়েন্টের তারিখ স্প্যান উপস্থাপন করে।

ইতিহাস API প্রতি সোমবার আপডেট করা হয় এবং আগের শনিবার পর্যন্ত ডেটা ধারণ করে (স্ট্যান্ডার্ড 2-দিনের ব্যবধান অনুযায়ী)। এটিতে আগের 25-সপ্তাহের ডেটা রয়েছে—প্রতি সপ্তাহে একটি সংগ্রহের সময়কাল।

যেহেতু প্রতিটি সংগ্রহের সময়কাল পূর্ববর্তী 28-দিনের সমষ্টিগত ডেটা ধারণ করে, এবং সংগ্রহের সময়কাল প্রতি সপ্তাহে, এর অর্থ সংগ্রহের সময়গুলি ওভারল্যাপ হবে। এগুলি ডেটার চলমান গড়ের মতো, প্রতিটি পরবর্তী সময়ের মধ্যে তিন সপ্তাহের মূল্যের ডেটা অন্তর্ভুক্ত করা হয় এবং এক সপ্তাহ আলাদা।

উদাহরণ প্রশ্ন

POST বডিতে JSON অবজেক্ট হিসেবে ক্যোয়ারী ডেটা সহ https://chromeuxreport.googleapis.com/v1/records:queryHistoryRecord?key=[YOUR_API_KEY]" এ পোস্ট অনুরোধ ব্যবহার করে JSON অবজেক্ট হিসেবে প্রশ্নগুলি জমা দেওয়া হয়।

দৈনিক CrUX API-এর queryRecord প্রতিস্থাপন করে queryHistoryRecord এর ব্যবহার লক্ষ্য করুন।

একটি উদাহরণ শরীর হল:

{
  "origin": "https://example.com",
  "formFactor": "PHONE",
  "metrics": [
    "largest_contentful_paint",
    "experimental_time_to_first_byte"
  ]
}

উদাহরণস্বরূপ, এটিকে নিম্নলিখিত কমান্ড লাইনের সাহায্যে curl থেকে কল করা যেতে পারে (আপনার কী দিয়ে API_KEY প্রতিস্থাপন করা):

curl -s --request POST 'https://chromeuxreport.googleapis.com/v1/records:queryHistoryRecord?key=API_KEY' \
    --header 'Accept: application/json' \
    --header 'Content-Type: application/json' \
    --data '{"formFactor":"PHONE","origin":"https://www.example.com","metrics":["largest_contentful_paint", "experimental_time_to_first_byte"]}'

পৃষ্ঠা-স্তরের ডেটা origin পরিবর্তে কোয়েরিতে একটি url সম্পত্তি পাস করে API-এর মাধ্যমে পাওয়া যায়:

{
  "url": "https://example.com/page",
  "formFactor": "PHONE",
  "metrics": [
    "largest_contentful_paint",
    "experimental_time_to_first_byte"
  ]
}

যদি metrics প্রপার্টি সেট করা না থাকে তাহলে সমস্ত উপলব্ধ মেট্রিক ফেরত দেওয়া হবে:

  • cumulative_layout_shift
  • first_contentful_paint
  • interaction_to_next_paint
  • largest_contentful_paint
  • experimental_time_to_first_byte
  • navigation_types
  • round_trip_time
  • form_factors (অনুরোধে কোনো formFactor উল্লেখ না থাকলে শুধুমাত্র রিপোর্ট করা হয়)

যদি কোন formFactor মান প্রদান করা না হয় তাহলে মানগুলি সমস্ত ফর্ম ফ্যাক্টর জুড়ে একত্রিত হবে।

আরও উদাহরণের জন্য CrUX History API নির্দেশিকা ব্যবহার করা দেখুন।

ডেটা পাইপলাইন

CrUX ডেটাসেট API-এর মাধ্যমে উপলব্ধ হওয়ার আগে ডেটা একত্রীকরণ, একত্রিত এবং ফিল্টার করার জন্য একটি পাইপলাইনের মাধ্যমে প্রক্রিয়া করা হয়।

রোলিং গড়

ক্রোম ইউএক্স রিপোর্টের ডেটা হল একত্রিত মেট্রিক্সের 28-দিনের রোলিং গড়৷ এর মানে হল যে কোনও নির্দিষ্ট সময়ে Chrome UX রিপোর্টে উপস্থাপিত ডেটা আসলে গত 28 দিনের একত্রিত ডেটা।

হিস্ট্রি এপিআই-এ অনেকগুলি সংগ্রহের সময়কাল রয়েছে, প্রতিটি এই 28 দিনের মধ্যে বিস্তৃত। যেহেতু প্রতিটি সংগ্রহের সময়কাল পূর্ববর্তী 28-দিনের সমষ্টিগত ডেটা ধারণ করে, এবং সংগ্রহের সময়কাল প্রতি সপ্তাহে, এর অর্থ সংগ্রহের সময়গুলি ওভারল্যাপ হবে। এগুলি ডেটার চলমান গড়ের মতো, প্রতিটি পরবর্তী সময়ের মধ্যে তিন সপ্তাহের মূল্যের ডেটা অন্তর্ভুক্ত করা হয় এবং এক সপ্তাহ আলাদা।

সাপ্তাহিক আপডেট

ইতিহাস API প্রতি সোমবার 04:00 UTC এর কাছাকাছি আপডেট করা হয় এবং এতে আগের শনিবার পর্যন্ত ডেটা থাকে (স্ট্যান্ডার্ড 2-দিনের ব্যবধান অনুযায়ী)। এতে আগের 25 সপ্তাহ (প্রায় 6 মাস) মূল্যের ডেটা রয়েছে, প্রতি সপ্তাহে একটি সংগ্রহের সময়কাল।

আপডেট সময়ের জন্য কোন পরিষেবা স্তর চুক্তি নেই; এটি প্রতিদিন সর্বোত্তম প্রচেষ্টার ভিত্তিতে পরিচালিত হয়।

স্কিমা

CrUX History API-এর জন্য একটি একক এন্ডপয়েন্ট রয়েছে যা POST HTTP অনুরোধ গ্রহণ করে। এপিআই এমন একটি record ফেরত দেয় যাতে অনুরোধ করা উৎস বা পৃষ্ঠা সম্পর্কে কর্মক্ষমতা ডেটার সাথে সম্পর্কিত এক বা একাধিক metrics থাকে।

HTTP অনুরোধ

POST https://chromeuxreport.googleapis.com/v1/records:queryHistoryRecord

URL gRPC ট্রান্সকোডিং সিনট্যাক্স ব্যবহার করে।

শরীরের অনুরোধ

CrUX History API দৈনিক CrUX API হিসাবে একই অনুরোধ সংস্থাগুলি ব্যবহার করে, effectiveConnectionType অনুরোধ ক্ষেত্রটিকে সমর্থন না করার ব্যতিক্রম।

উদাহরণস্বরূপ, web.dev হোমপেজের জন্য ডেস্কটপের সবচেয়ে বড় বিষয়বস্তুযুক্ত পেইন্ট মানগুলির অনুরোধ করতে:

{
  "origin": "https://web.dev/",
  "formFactor": "DESKTOP",
  "metrics": [
    "largest_contentful_paint"
  ]
}

প্রতিক্রিয়া শরীর

সফল অনুরোধগুলি নিম্নলিখিত কাঠামোতে একটি record অবজেক্ট এবং urlNormalizationDetails সহ প্রতিক্রিয়া ফেরত দেয়:

{
  "record": {
    "key": {
      object (Key)
    },
    "metrics": [
      string: {
        object (Metric)
      }
    ]
  },
  "urlNormalizationDetails": {
    object (UrlNormalization)
  }
}

উদাহরণস্বরূপ, পূর্ববর্তী অনুরোধে অনুরোধের বডির প্রতিক্রিয়া হতে পারে:

{
  "record": {
    "key": {
      "origin": "https://web.dev"
    },
    "metrics": {
      "largest_contentful_paint": {
        "histogramTimeseries": [{
            "start": 0, "end": 2500, "densities": [
              0.9190, 0.9203, 0.9194, 0.9195, 0.9183, 0.9187, ...
            ]
          }, {
            "start": 2500, "end": 4000, "densities": [
              0.0521, 0.0513, 0.0518, 0.0518, 0.0526, 0.0527, ...
            ]
          },  {
            "start": 4000, "densities": [
              0.0288, 0.0282, 0.0286, 0.0285, 0.0290, 0.0285, ...
            ]
          }
        ],
        "percentilesTimeseries": {
          "p75s": [
            1362, 1352, 1344, 1356, 1366, 1377, ...
          ]
        }
      }
    },
    "collectionPeriods": [{
        "firstDate": { "year": 2022, "month": 7, "day": 10 },
        "lastDate": { "year": 2022, "month": 8, "day": 6 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 17 },
        "lastDate": { "year": 2022, "month": 8, "day": 13 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 24 },
        "lastDate": { "year": 2022, "month": 8, "day": 20 }
      }, {
        "firstDate": { "year": 2022, "month": 7, "day": 31 },
        "lastDate": { "year": 2022, "month": 8, "day": 27 }
      }, {
        "firstDate": { "year": 2022, "month": 8, "day": 7 },
        "lastDate": { "year": 2022, "month": 9, "day": 3 }
      }, {
        "firstDate": { "year": 2022, "month": 8, "day": 14 },
        "lastDate": { "year": 2022, "month": 9, "day": 10 }
      }, {
        ...
      }
    ]
  }
}

চাবি

Key এই রেকর্ডটিকে অনন্য হিসাবে চিহ্নিত করে এমন সমস্ত মাত্রা সংজ্ঞায়িত করে।

{
  "formFactor": enum (FormFactor),

  // Union field url_pattern can be only one of the following:
  "origin": string,
  "url": string
  // End of list of possible types for union field url_pattern.
}
ক্ষেত্র
formFactor

enum ( FormFactor )

ফর্ম ফ্যাক্টর হল ডিভাইস ক্লাস যা সমস্ত ব্যবহারকারী এই রেকর্ডের জন্য সাইট অ্যাক্সেস করতে ব্যবহার করে।

যদি ফর্ম ফ্যাক্টর অনির্দিষ্ট হয়, তাহলে সমস্ত ফর্ম ফ্যাক্টরগুলির সমষ্টিগত ডেটা ফেরত দেওয়া হবে।

ইউনিয়ন ক্ষেত্র url_ pattern । URL প্যাটার্ন হল সেই URL যা রেকর্ড প্রযোজ্য। url_ pattern নিম্নলিখিতগুলির মধ্যে একটি হতে পারে:
origin

string

অরিজিন নির্দিষ্ট করে যে এই রেকর্ডের জন্য।

দ্রষ্টব্য: একটি উত্স নির্দিষ্ট করার সময়, সমস্ত পৃষ্ঠাগুলিতে এই উত্সের অধীনে লোডের জন্য ডেটা মূল স্তরের ব্যবহারকারীর অভিজ্ঞতা ডেটাতে একত্রিত হয়৷

url

string

url একটি নির্দিষ্ট URL উল্লেখ করে যার জন্য এই রেকর্ড।

দ্রষ্টব্য: একটি url নির্দিষ্ট করার সময় শুধুমাত্র সেই নির্দিষ্ট URL-এর জন্য ডেটা একত্রিত করা হবে।

মেট্রিক্স

একটি metric হল একটি একক ওয়েব পারফরম্যান্স মেট্রিকের জন্য ব্যবহারকারীর অভিজ্ঞতার ডেটার একটি সেট, যেমন প্রথম বিষয়বস্তুপূর্ণ পেইন্ট। এটি bins একটি সিরিজ হিসাবে বাস্তব বিশ্বের Chrome ব্যবহারের একটি সারাংশ হিস্টোগ্রাম রয়েছে৷

{
  "histogramTimeseries": [
    {
      object (Bin)
    }
  ],
  "percentilesTimeseries": {
    object (Percentiles)
  }
}

বা

"fractionTimeseries": {
  object (Fractions)
}
ক্ষেত্র
histogramTimeseries[]

object ( Bin )

একটি মেট্রিকের জন্য ব্যবহারকারীর অভিজ্ঞতার টাইমসিরিজ হিস্টোগ্রাম। টাইমসিরিজ হিস্টোগ্রামে কমপক্ষে একটি বিন থাকবে এবং সমস্ত বিনের ঘনত্ব ~1 পর্যন্ত যোগ হবে।

সেই নির্দিষ্ট সংগ্রহের সময়ের জন্য অনুপস্থিত মানগুলিকে "NaN" হিসাবে চিহ্নিত করা হবে৷

percentilesTimeseries

object ( Percentiles )

মেট্রিকের সাধারণ উপযোগী পার্সেন্টাইল। পারসেন্টাইলের মান প্রকার হিস্টোগ্রাম বিনের জন্য প্রদত্ত মান প্রকারের মতোই হবে।

সেই নির্দিষ্ট সংগ্রহের সময়ের জন্য অনুপস্থিত মানগুলিকে null হিসাবে চিহ্নিত করা হবে।

fractionTimeseries

object ( Fractions )

এই বস্তুটিতে লেবেলযুক্ত ভগ্নাংশের টাইমসিরিজ রয়েছে, যা প্রতি এন্ট্রিতে ~1 পর্যন্ত যোগ করে।

ভগ্নাংশগুলিকে 4 দশমিক স্থানে বৃত্তাকার করা হয়।

অনুপস্থিত এন্ট্রিগুলি সমস্ত ভগ্নাংশ জুড়ে `"NaN"` হিসাবে প্রকাশ করা হয়৷

বিন

একটি bin হল ডেটার একটি বিচ্ছিন্ন অংশ যা শুরু থেকে শেষ পর্যন্ত বিস্তৃত হয়, অথবা যদি শুরু থেকে ধনাত্মক অসীম পর্যন্ত কোন শেষ না দেওয়া হয়।

একটি বিনের শুরু এবং শেষের মানগুলি মেট্রিকের মান প্রকারে দেওয়া হয় যা এটি প্রতিনিধিত্ব করে। উদাহরণস্বরূপ, প্রথম কনটেন্টফুল পেইন্টটি মিলিসেকেন্ডে পরিমাপ করা হয় এবং ints হিসাবে প্রকাশ করা হয়, তাই এর মেট্রিক বিনগুলি এর শুরু এবং শেষ প্রকারের জন্য int32s ব্যবহার করবে। তবে ক্রমবর্ধমান বিন্যাস স্থানান্তর ইউনিটহীন দশমিকে পরিমাপ করা হয় এবং একটি স্ট্রিং হিসাবে এনকোড করা দশমিক হিসাবে উন্মুক্ত করা হয়, তাই এর মেট্রিক বিনগুলি এর মান প্রকারের জন্য স্ট্রিং ব্যবহার করবে।

{
  "start": value,
  "end": value,
  "densities": [number, number, number...etc.]
}
ক্ষেত্র
start

(integer | string)

স্টার্ট হল ডাটা বিনের শুরু।

end

(integer | string)

শেষ হল ডাটা বিনের শেষ। যদি শেষ জনবহুল না হয়, তাহলে বিনের কোন শেষ নেই এবং এটি শুরু থেকে +inf পর্যন্ত বৈধ।

densities

array[number]

প্রদত্ত মেট্রিকের জন্য এই বিনের মান অভিজ্ঞ ব্যবহারকারীদের অনুপাতের একটি টাইমসিরিজ৷

ঘনত্ব 4 দশমিক স্থানে বৃত্তাকার।

শতকরা

Percentiles একটি প্রদত্ত পরিসংখ্যানগত শতাংশে একটি মেট্রিকের সিন্থেটিক মান রয়েছে। মোট ব্যবহারকারীর সংখ্যার মধ্যে শতকরা শতাংশ ব্যবহারকারীর দ্বারা অভিজ্ঞ মেট্রিকের মান অনুমান করার জন্য এগুলি ব্যবহার করা হয়।

{
  "P75": value
}
ক্ষেত্র
p75s

array[(integer | string)]

75% পৃষ্ঠা লোড হওয়া মানগুলির টাইমসিরিজ প্রদত্ত মেট্রিকটি এই মানের বা তার চেয়ে কম অনুভব করেছে৷

ভগ্নাংশ

Fractions লেবেলযুক্ত ভগ্নাংশের টাইমসিরিজ রয়েছে যা প্রতি এন্ট্রিতে ~1 পর্যন্ত যোগ করে। প্রতিটি লেবেল কোনো না কোনোভাবে একটি পৃষ্ঠা লোডকে বর্ণনা করে, তাই এইভাবে উপস্থাপিত মেট্রিকগুলিকে সংখ্যাসূচক মানের পরিবর্তে স্বতন্ত্র মান তৈরি করার কথা ভাবা যেতে পারে এবং ভগ্নাংশগুলি প্রকাশ করে যে একটি নির্দিষ্ট স্বতন্ত্র মান কত ঘন ঘন পরিমাপ করা হয়েছিল।

{
  "label_1": { "fractions": array[fraction]},
  "label_1": { "fractions": array[fraction]},
  ...
  "label_n": { "fractions": array[fraction]}
}

অনেকটা হিস্টোগ্রাম বিনের ঘনত্বের মানের মতো, প্রতিটি fraction একটি সংখ্যা 0.0 <= value <= 1.0 , এবং তারা ~1.0 পর্যন্ত যোগ করে। যখন একটি নির্দিষ্ট সংগ্রহের সময়ের জন্য মেট্রিক উপলব্ধ না হয়, তখন সংশ্লিষ্ট এন্ট্রিটি ভগ্নাংশের সমস্ত অ্যারেতে "NaN" হবে৷

ক্ষেত্র
p75s

array[(integer | string)]

75% পৃষ্ঠা লোড হওয়া মানগুলির টাইমসিরিজ প্রদত্ত মেট্রিকটি এই মানের বা তার চেয়ে কম অনুভব করেছে৷

ইউআরএল স্বাভাবিককরণ

সফল লুকআপের একটি উচ্চতর সম্ভাবনা অর্জনের জন্য একটি URL স্বাভাবিক করার জন্য নেওয়া স্বাভাবিককরণের ক্রিয়াগুলিকে প্রতিনিধিত্ব করে। এইগুলি হল সহজ স্বয়ংক্রিয় পরিবর্তন যা প্রদত্ত url_pattern সন্ধান করার সময় নেওয়া হয় ব্যর্থ বলে জানা যাবে৷ নিম্নোক্ত পুনঃনির্দেশের মতো জটিল ক্রিয়াগুলি পরিচালনা করা হয় না।

{
  "originalUrl": string,
  "normalizedUrl": string
}
ক্ষেত্র
originalUrl

string

যেকোন স্বাভাবিকীকরণ কর্মের আগে মূল অনুরোধ করা URL।

normalizedUrl

string

যেকোন স্বাভাবিকীকরণ কর্মের পরে URL। এটি একটি বৈধ ব্যবহারকারীর অভিজ্ঞতা URL যা যুক্তিসঙ্গতভাবে দেখা যেতে পারে৷

হারের সীমা

CrUX History API CrUX API- এর সাথে একই সীমা ভাগ করে প্রতি মিনিটে Google ক্লাউড প্রকল্পে প্রতি মিনিটে 150টি প্রশ্নের জন্য, যেটি কোনো চার্জ ছাড়াই দেওয়া হয়। এই সীমা, এবং আপনার বর্তমান ব্যবহার, Google ক্লাউড কনসোলে দেখা যাবে। এই উদার কোটা বেশিরভাগ ব্যবহারের ক্ষেত্রে যথেষ্ট হওয়া উচিত এবং বর্ধিত কোটার জন্য অর্থ প্রদান করা সম্ভব নয়।