BigQuery-এ পারফরম্যান্স মনিটরিং ডেটা এক্সপোর্ট করুন

You can export Performance Monitoring data from Apple and Android apps into BigQuery for further analysis. BigQuery আপনাকে BigQuery SQL ব্যবহার করে ডেটা বিশ্লেষণ করতে, অন্য ক্লাউড প্রদানকারীর কাছে রপ্তানি করতে এবং এমনকি আপনার কাস্টম ML মডেলের জন্য ডেটা ব্যবহার করতে দেয়।

BigQuery রফতানি সক্ষম করুন

  1. Firebase কনসোলে ইন্টিগ্রেশন পৃষ্ঠায় যান, তারপর BigQuery কার্ডে লিঙ্কে ক্লিক করুন।

  2. BigQuery সক্ষম করতে অন-স্ক্রীন নির্দেশাবলী অনুসরণ করুন।

    আপনি যখন Performance Monitoring জন্য BigQuery রপ্তানি সক্ষম করেন, তখন নিম্নলিখিতগুলি ঘটে:

BigQuery এক্সপোর্ট নিষ্ক্রিয় করতে, Firebase কনসোলে আপনার প্রোজেক্ট আনলিঙ্ক করুন

BigQuery এ কোন ডেটা রপ্তানি করা হয়?

প্রকল্পের প্রতিটি অ্যাপের জন্য, রপ্তানি একটি টেবিল তৈরি করে যাতে সমস্ত ক্যাপচার করা কর্মক্ষমতা ইভেন্ট অন্তর্ভুক্ত থাকে। টেবিলের প্রতিটি সারি একটি একক পারফরম্যান্স ইভেন্ট যা নিম্নলিখিতগুলির মধ্যে একটি হতে পারে:

  • সময়কাল ট্রেস — যে ট্রেসগুলি ডিফল্টভাবে, "সময়কাল" এর মেট্রিক সংগ্রহ করে, যার মধ্যে অ্যাপ শুরু, অ্যাপ-ইন-ফোরগ্রাউন্ড এবং অ্যাপ-ইন-ব্যাকগ্রাউন্ড, সেইসাথে যেকোন ডেভেলপার-ইনস্ট্রুমেন্টেড কাস্টম কোড ট্রেস অন্তর্ভুক্ত থাকে

    • event_type হল DURATION_TRACE
    • event_name ট্রেস নামের মতোই
  • ট্রেস মেট্রিক — কাস্টম মেট্রিক যা ডেভেলপার-ইনস্ট্রুমেন্টেড কাস্টম কোড ট্রেসের সাথে যুক্ত

    • event_type হল TRACE_METRIC
    • event_name হল মেট্রিকের নাম
    • parent_trace_name is the trace name that contains this metric
  • স্ক্রিন ট্রেস - একটি স্ক্রিনের আজীবন বিস্তৃত ট্রেস (স্ক্রিন রেন্ডারিং ট্রেস)

    • event_type হল SCREEN_TRACE
    • event_name হল প্রিফিক্স _st_ প্লাস আসল স্ক্রীন নাম
  • নেটওয়ার্ক অনুরোধ — একটি নেটওয়ার্ক অনুরোধের জীবনকাল বিস্তৃত ট্রেস (HTTP নেটওয়ার্ক অনুরোধ ট্রেস)

    • event_type হল NETWORK_REQUEST
    • event_name হল নেটওয়ার্ক অনুরোধ URL এর শ্রেণীবদ্ধ প্যাটার্ন

প্রতিটি পারফরম্যান্স ইভেন্টে ইভেন্টের বৈশিষ্ট্য রয়েছে (যেমন ক্লায়েন্ট ডিভাইসের দেশ এবং ক্যারিয়ার), সেইসাথে ইভেন্ট-নির্দিষ্ট তথ্য:

  • সময়কাল ট্রেস, ট্রেস মেট্রিক্স এবং স্ক্রীন ট্রেসে trace_info থাকে
  • ট্রেস মেট্রিক্সে trace_info.metric_info থাকে
  • স্ক্রীন ট্রেসে trace_info.screen_info থাকে
  • নেটওয়ার্ক ট্রেসে network_info রয়েছে

Detailed data schema

ক্ষেত্রের নাম টাইপ বর্ণনা
event_timestamp টাইমস্ট্যাম্প ক্লায়েন্ট ডিভাইসে ইভেন্ট শুরু হওয়ার পর থেকে টাইমস্ট্যাম্প (ট্রেস স্টার্ট, নেটওয়ার্ক স্টার্ট ইত্যাদি)
app_display_version স্ট্রিং অ্যাপ্লিকেশনটির প্রদর্শন সংস্করণ (উদাহরণস্বরূপ, "4.1.7")
  • অ্যান্ড্রয়েডের জন্য - VersionName
  • iOS এর জন্য — CFBundleShortVersionString
app_build_version স্ট্রিং অ্যাপ্লিকেশনটির বিল্ড সংস্করণ (উদাহরণস্বরূপ, "1523456")
  • অ্যান্ড্রয়েডের জন্য — VersionCode
  • iOS - CFBundleVersion জন্য
os_version স্ট্রিং ক্লায়েন্ট ডিভাইসের OS সংস্করণ
  • Android এর জন্য — Android API স্তর (উদাহরণস্বরূপ "26")
  • iOS এর জন্য — iOS সংস্করণ (উদাহরণস্বরূপ "11.4")
device_name স্ট্রিং ক্লায়েন্ট ডিভাইসের নাম (উদাহরণস্বরূপ, "গুগল পিক্সেল")
দেশ স্ট্রিং যে দেশ থেকে ইভেন্টটি হয়েছিল তার দুই-অক্ষরের কান্ট্রি কোড (উদাহরণস্বরূপ, "US", বা অজানা দেশের জন্য "ZZ")
বাহক স্ট্রিং ক্লায়েন্ট ডিভাইসের বাহক
রেডিও_টাইপ স্ট্রিং ইভেন্টটি হওয়ার সময় সক্রিয় রেডিও প্রকার (উদাহরণস্বরূপ, "WIFI")
custom_attributes ARRAY<RECORD> এই ইভেন্টের সাথে সংযুক্ত সমস্ত কাস্টম বৈশিষ্ট্য
custom_attributes.key স্ট্রিং Key of the custom attribute
custom_attributes.value স্ট্রিং Value of the custom attribute
ঘটনা_প্রকার স্ট্রিং Type of the event; possible values:
  • DURATION_TRACE — যে ট্রেসগুলি, ডিফল্টভাবে, "সময়কাল" এর মেট্রিক সংগ্রহ করে, যার মধ্যে অ্যাপ শুরু, অ্যাপ-ইন-ফোরগ্রাউন্ড এবং অ্যাপ-ইন-ব্যাকগ্রাউন্ড, সেইসাথে ডেভেলপার-ইনস্ট্রুমেন্টেড কাস্টম কোড ট্রেস অন্তর্ভুক্ত থাকে
  • SCREEN_TRACE — একটি স্ক্রিনের জীবনকাল বিস্তৃত ট্রেস (স্ক্রিন রেন্ডারিং ট্রেস)
  • TRACE_METRIC -কাস্টম মেট্রিকগুলি যা বিকাশকারী-ইনস্ট্রুমেন্টেড কাস্টম কোড ট্রেসগুলির সাথে সম্পর্কিত
  • NETWORK_REQUEST - একটি নেটওয়ার্ক অনুরোধের আজীবন বিস্তৃত ট্রেস (এইচটিটিপি নেটওয়ার্ক অনুরোধ ট্রেস)
ঘটনা_নাম স্ট্রিং অনুষ্ঠানের নাম
  • For DURATION_TRACE — trace name
  • For TRACE_METRIC — custom metric name
  • SCREEN_TRACE জন্য - _st_ এর পরে ট্রেস নামটি রয়েছে
  • NETWORK_REQUEST জন্য - নেটওয়ার্ক অনুরোধ ইউআরএল প্যাটার্ন
পিতামাতার_ট্রেস_নাম স্ট্রিং প্যারেন্ট ট্রেসের নাম যা ট্রেস মেট্রিক বহন করে
শুধুমাত্র TRACE_METRIC এর জন্য উপস্থিত
ট্রেস_তথ্য রেকর্ড শুধুমাত্র DURATION_TRACE , SCREEN_TRACE , এবং TRACE_METRIC এর জন্য উপস্থিত
trace_info.duration_us int64
  • For DURATION_TRACE and SCREEN_TRACE — Length of time ("duration") from the beginning to the end of the trace
  • TRACE_METRIC জন্য - সময়কালের দৈর্ঘ্য ("সময়কাল") শুরু থেকে পিতামাতার ট্রেসের শেষ পর্যন্ত
Unit: microsecond
trace_info.screen_info রেকর্ড Only present for SCREEN_TRACE
trace_info.screen_info.slow_frame_ratio float64 এই স্ক্রীন ট্রেসের জন্য ধীরগতির ফ্রেমের অনুপাত, 0 এবং 1 এর মধ্যে (উদাহরণস্বরূপ, 0.05 এর মান মানে এই স্ক্রীন উদাহরণের জন্য 5% ফ্রেম রেন্ডার করতে 16ms এর বেশি সময় নেয়)
trace_info.screen_info.frozen_frame_ratio float64 এই স্ক্রীন ট্রেসের জন্য হিমায়িত ফ্রেমের অনুপাত, 0 এবং 1 এর মধ্যে (উদাহরণস্বরূপ, 0.05 এর মান মানে এই স্ক্রীন উদাহরণের জন্য ফ্রেমের 5% রেন্ডার করতে 700ms এর বেশি সময় নেয়)
trace_info.metric_info রেকর্ড কেবল TRACE_METRIC জন্য উপস্থিত
trace_info.metric_info.metric_value int64 ট্রেস মেট্রিকের মান
network_info রেকর্ড শুধুমাত্র NETWORK_REQUEST এর জন্য উপস্থিত৷
network_info.response_code int64 নেটওয়ার্ক প্রতিক্রিয়ার জন্য এইচটিটিপি প্রতিক্রিয়া কোড (উদাহরণস্বরূপ, 200, 404)
network_info.response_mime_type স্ট্রিং নেটওয়ার্ক প্রতিক্রিয়ার MIME প্রকার (উদাহরণস্বরূপ, "টেক্সট/এইচটিএমএল")
network_info.request_http_method স্ট্রিং নেটওয়ার্ক অনুরোধের HTTP পদ্ধতি (উদাহরণস্বরূপ, "GET" বা "POST")
network_info.request_payload_bytes int64 Size of the network request payload
Unit: byte
network_info.response_payload_bytes int64 নেটওয়ার্ক প্রতিক্রিয়া পেলোডের আকার
ইউনিট: বাইট
network_info.request_completed_time_us int64 event_timestamp পরে মাইক্রোসেকেন্ড যখন নেটওয়ার্ক অনুরোধ পাঠানো সম্পূর্ণ হয়
একক: মাইক্রোসেকেন্ড
network_info.response_initiated_time_us int64 event_timestamp পরে মাইক্রোসেকেন্ড যখন নেটওয়ার্ক প্রতিক্রিয়া শুরু হয়
একক: মাইক্রোসেকেন্ড
network_info.response_completed_time_us int64 নেটওয়ার্ক প্রতিক্রিয়া সম্পূর্ণ হলে event_timestamp পরে মাইক্রোসেকেন্ড
একক: মাইক্রোসেকেন্ড

রপ্তানি করা ডেটা দিয়ে আপনি কী করতে পারেন?

নিম্নলিখিত বিভাগগুলি আপনার এক্সপোর্ট করা Performance Monitoring ডেটার বিপরীতে আপনি BigQuery এ চালাতে পারেন এমন প্রশ্নের উদাহরণগুলি অফার করে৷

গড় অ্যাপটি দেশ অনুসারে লেটেন্সি ব্রেক-ডাউন শুরু করুন

SELECT AVG(trace_info.duration_us), country
FROM `TABLE_NAME`
WHERE _PARTITIONTIME > TIMESTAMP("YYYY-MM-DD")
AND event_type = "DURATION_TRACE"
AND event_name = "_app_start"
GROUP BY 2;

বিভিন্ন অবস্থার বিপরীতে হিমায়িত ফ্রেমের অনুপাত পরীক্ষা করুন

উদাহরণস্বরূপ, আপনি বিভিন্ন রেডিও ধরনের (WiFi, 4G, ইত্যাদি) ব্যবহার করার সময় ব্যবহারকারীরা আপনার অ্যাপের প্রতিটি স্ক্রিনে কত সময় ব্যয় করেন তার সাথে হিমায়িত ফ্রেমের অনুপাত পরীক্ষা করতে পারেন।

SELECT
  AVG(trace_info.duration_us / 1000000) AS seconds_on_screen,
  AVG(trace_info.screen_info.frozen_frame_ratio) AS frozen_frame_ratio,
  event_name,
  radio_type
FROM `TABLE_NAME`
WHERE _PARTITIONTIME > TIMESTAMP("YYYY-MM-DD")
AND event_type = "SCREEN_TRACE"
GROUP BY event_name, radio_type
ORDER BY event_name, radio_type;

ডিস্ক থেকে নির্দিষ্ট ধরণের ফাইল লোড করার জন্য ক্যাশে হিট রেট গণনা করুন

এই বিশ্লেষণটি অনুমান করে যে আপনি file-extension নামে একটি কাস্টম বৈশিষ্ট্য এবং cache-hit নামের একটি কাস্টম মেট্রিক (একটি TRACE_METRIC ) সহ ডিস্ক থেকে লোড করার জন্য একটি কাস্টম কোড ট্রেস তৈরি করেছেন যা ক্যাশে হিট হলে 1 এবং ক্যাশে মিস হলে 0 সেট করা হয়৷

উদাহরণস্বরূপ, আপনি ডিস্ক থেকে PNG ফাইল লোড করার জন্য ক্যাশে হিট রেট গণনা করতে পারেন:

SELECT AVG(trace_info.metric_info.metric_value) AS cache_hit_rate
FROM `TABLE_NAME`
WHERE _PARTITIONTIME > TIMESTAMP("YYYY-MM-DD")
AND event_type = "TRACE_METRIC"
AND event_name = "cache-hit"
AND parent_trace_name = "loadFromDisk"
AND STRUCT("file-extension", "png") IN UNNEST(custom_attributes);

ব্যবহারকারীরা নেটওয়ার্ক অনুরোধ জারি করে দিনের সময় পরীক্ষা করুন

উদাহরণস্বরূপ, মার্কিন যুক্তরাষ্ট্রের ব্যবহারকারীরা দিনের কোন ঘন্টায় আপনার অ্যাপ থেকে নেটওয়ার্ক অনুরোধ জারি করে তা আপনি পরীক্ষা করতে পারেন:

SELECT
  count(1) AS hourly_count,
  EXTRACT(HOUR FROM event_timestamp) AS hour_of_day
FROM `TABLE_NAME`
WHERE _PARTITIONTIME > TIMESTAMP("YYYY-MM-DD")
AND event_type = "NETWORK_REQUEST"
AND country = "US"
GROUP BY 2 ORDER BY 2;

আপনার Performance Monitoring ডেটা যে কোনো জায়গায় নিয়ে যান

কখনও কখনও আপনি আপনার Performance Monitoring ডেটা সার্ভার-সাইড অ্যাক্সেস করতে চান বা এটিকে অন্য তৃতীয় পক্ষের সমাধানে ঠেলে দিতে চান। ডেটা রপ্তানির জন্য বর্তমানে কোন চার্জ নেই।

আপনি এর মাধ্যমে আপনার ডেটা রপ্তানি করতে পারেন:

  • BigQuery ওয়েব UI ব্যবহার করা

  • CLI কমান্ড bq extract চলমান

  • API বা ক্লায়েন্ট লাইব্রেরির মাধ্যমে একটি এক্সট্রাক্ট কাজ জমা দেওয়া।

মূল্য নির্ধারণ

Performance Monitoring থেকে ডেটা রপ্তানি করার জন্য কোনও চার্জ নেই এবং BigQuery উদার অ-ব্যয় ব্যবহারের সীমা প্রদান করে৷ বিস্তারিত তথ্যের জন্য, BigQuery প্রাইসিং বা BigQuery স্যান্ডবক্সটি দেখুন।