কীভাবে Google Analytics 4 প্রপার্টিতে ওয়েব ভাইটাল ডেটা পাঠাতে হয় এবং BigQuery এবং লুকার স্টুডিওতে বিশ্লেষণের জন্য ডেটা এক্সপোর্ট করতে হয় তা জানুন।
Google অনেকগুলি টুল সরবরাহ করে — সার্চ কনসোল , পেজস্পিড ইনসাইটস (PSI), এবং Chrome ব্যবহারকারীর অভিজ্ঞতা রিপোর্ট (CrUX)—যা ডেভেলপারদের দেখতে দেয় যে তাদের সাইটগুলি ক্ষেত্রে তাদের প্রকৃত ব্যবহারকারীদের জন্য কোর ওয়েব ভাইটাল মেট্রিক্সের বিপরীতে কীভাবে পারফর্ম করে।
এই সরঞ্জামগুলি দুর্দান্ত যে এগুলি আপনাকে আপনার সাইটের আসল-ব্যবহারকারীর কার্যক্ষমতার একটি উচ্চ-স্তরের ভিউ দেয় এবং ব্যবহার শুরু করার জন্য তাদের একেবারে কোনও সেটআপের প্রয়োজন হয় না।
যাইহোক, আপনার সাইটের পারফরম্যান্স পরিমাপ করার জন্য আপনি কেন এই টুলগুলির উপর নির্ভর করতে চান না তার কয়েকটি জটিল কারণ রয়েছে:
- CrUX-ভিত্তিক সরঞ্জামগুলি হয় মাসিক বা পূর্ববর্তী 28-দিনের সময়ের দ্বারা ডেটা রিপোর্ট করে। এর মানে হল আপনি ফলাফলগুলি দেখতে পাওয়ার আগে কোনও পরিবর্তন করার পরে আপনাকে দীর্ঘ সময় অপেক্ষা করতে হবে।
- CrUX-ভিত্তিক সরঞ্জামগুলি শুধুমাত্র দেশ, সংযোগের ধরন এবং ডিভাইসের বিভাগ (ডেস্কটপ বা মোবাইল) এর মতো সীমিত সংখ্যক মাত্রা দ্বারা ভাগ করা যেতে পারে। আপনি আপনার ব্যবসার জন্য নির্দিষ্ট মাত্রার দ্বারা ডেটা স্লাইস করতে পারবেন না (উদাহরণস্বরূপ: নিযুক্ত ব্যবহারকারী, একটি নির্দিষ্ট পরীক্ষা গোষ্ঠীর ব্যবহারকারী, ইত্যাদি)।
- CrUX-ভিত্তিক সরঞ্জামগুলি আপনাকে বলতে পারে আপনার কার্যক্ষমতা কী , কিন্তু কেন তা তারা আপনাকে বলতে পারে না৷ বিশ্লেষণের সরঞ্জামগুলির সাহায্যে আপনি সমস্যাগুলি ট্র্যাক এবং ডিবাগ করতে সহায়তা করার জন্য অতিরিক্ত ডেটা পাঠাতে পারেন৷
এই কারণে, আমরা সমস্ত সাইটের মালিকদের তাদের বিদ্যমান বিশ্লেষণ টুল ব্যবহার করে কোর ওয়েব ভাইটাল মেট্রিক্স নিরীক্ষণ করার পরামর্শ দিই। এই পোস্টটি ব্যাখ্যা করে যে আপনি কীভাবে Google দ্বারা অফার করা বিনামূল্যের সরঞ্জামগুলি ব্যবহার করতে পারেন।
একবার আপনার সবকিছু সেট আপ হয়ে গেলে, আপনি এই মত ড্যাশবোর্ড তৈরি করতে সক্ষম হবেন:
এবং আপনি যদি এখানে বর্ণিত সমস্ত পদক্ষেপের একটি ভিজ্যুয়াল ওভারভিউ চান, তাহলে Google I/O '21 থেকে আমাদের আলোচনা দেখুন :
পরিমাপ
কাস্টম মেট্রিক্স ব্যবহার করে Google অ্যানালিটিক্সের মাধ্যমে কার্যক্ষমতা পরিমাপ করা সবসময়ই সম্ভব হয়েছে, কিন্তু Google Analytics 4 (GA4) এ কিছু নতুন বৈশিষ্ট্য রয়েছে যা বিশেষ করে ডেভেলপারদের উত্তেজিত হওয়া উচিত।
- জিরো-কনফিগ, কাস্টম ইভেন্ট প্যারামিটার
- বিনামূল্যে BigQuery রপ্তানি , যাতে আপনি SQL ব্যবহার করে আপনার ডেটা জিজ্ঞাসা করতে পারেন৷
যদিও Google Analytics ওয়েব ইন্টারফেসে শক্তিশালী বিশ্লেষণের সরঞ্জাম রয়েছে, আপনি সম্ভবত ইতিমধ্যেই জানেন এমন একটি প্রশ্নের ভাষা ব্যবহার করে কাঁচা ইভেন্ট ডেটা অ্যাক্সেসের শক্তি এবং নমনীয়তাকে হারানো কঠিন।
Google Analytics 4 এবং BigQuery ব্যবহার করে কোর ওয়েব ভাইটাল পরিমাপ করা শুরু করতে, আপনাকে তিনটি জিনিস করতে হবে:
- একটি Google Analytics 4 সম্পত্তি এবং একটি BigQuery প্রকল্প তৈরি করুন।
- আপনার Google Analytics প্রপার্টি কনফিগারেশনে BigQuery এক্সপোর্ট সক্ষম করুন, যাতে আপনি প্রাপ্ত সমস্ত ডেটা আপনার BigQuery প্রোজেক্ট টেবিলে স্বয়ংক্রিয়ভাবে জমা হয়ে যাবে।
- আপনার সাইটে ওয়েব-ভাইটাল জাভাস্ক্রিপ্ট লাইব্রেরি যোগ করুন, যাতে আপনি কোর ওয়েব ভাইটাল মেট্রিক্স পরিমাপ করতে পারেন এবং অ্যাট্রিবিউশন ডেটা সহ Google Analytics 4-এ ডেটা পাঠাতে পারেন ।
বিশ্লেষণ করুন
আপনি একবার সেট আপ হয়ে গেলে, আপনি BigQuery ইন্টারফেসে ইভেন্ট ডেটা জমা হওয়া দেখতে পাবেন এবং আপনি এইভাবে ডেটা জিজ্ঞাসা করতে সক্ষম হবেন:
SELECT * FROM `my_project_id.analytics_XXXXX.events_*`
WHERE event_name IN ('LCP', 'INP', 'CLS')
এখানে সেই ক্যোয়ারী থেকে ফলাফলের একটি পূর্বরূপ:
ওয়েব ভাইটাল ডেটা কোয়েরি করুন
আপনি আপনার ওয়েব ভাইটালস ইভেন্ট ডেটা অনুসন্ধান শুরু করার আগে, ডেটা কীভাবে একত্রিত হয় তা বোঝা গুরুত্বপূর্ণ৷
বোঝার সবচেয়ে গুরুত্বপূর্ণ বিষয় হল, কিছু ক্ষেত্রে, একই পৃষ্ঠায় একই মেট্রিকের জন্য একাধিক ইভেন্ট প্রাপ্ত হতে পারে । এটি ঘটতে পারে যদি মেট্রিক মান পরিবর্তন হয় এবং একটি আপডেট করা মান রিপোর্ট করা হয় (CLS-এর সাথে একটি সাধারণ ঘটনা)।
ওয়েব ভাইটাল ইভেন্টগুলির জন্য, প্রেরিত সর্বশেষ মানটি সর্বদা সবচেয়ে সঠিক, তাই কোনো বিশ্লেষণ করার আগে, শুধুমাত্র সেই মানগুলির জন্য ফিল্টার করা গুরুত্বপূর্ণ৷ Google Analytics 4-এ ডেটা পাঠানোর জন্য ওয়েব-ভিটালস জাভাস্ক্রিপ্ট লাইব্রেরি দ্বারা প্রদত্ত কোড স্নিপেটে প্রতি মেট্রিক একটি অনন্য আইডি পাঠানো অন্তর্ভুক্ত, তাই আপনি প্রতিটি মেট্রিক আইডির জন্য আপনার ফলাফলগুলিকে শুধুমাত্র শেষ-প্রাপ্ত মানের মধ্যে সীমাবদ্ধ করতে নিম্নলিখিত ক্যোয়ারী ব্যবহার করতে পারেন:
# Subquery all Web Vitals events from the last 28 days
WITH web_vitals_events AS (
SELECT event_name as metric_name, * EXCEPT(event_name, is_last_received_value) FROM (
SELECT *, IF (ROW_NUMBER() OVER (
PARTITION BY (SELECT value.string_value FROM UNNEST(event_params) WHERE key = 'metric_id')
ORDER BY (SELECT COALESCE(value.double_value, value.int_value) FROM UNNEST(event_params) WHERE key = 'metric_value') DESC
) = 1, true, false) AS is_last_received_value
FROM `bigquery_project_id.analytics_XXXXX.events_*`
WHERE event_name in ('CLS', 'INP', 'LCP') AND
_TABLE_SUFFIX BETWEEN FORMAT_DATE('%Y%m%d', DATE_SUB(CURRENT_DATE, INTERVAL 28 DAY)) AND FORMAT_DATE('%Y%m%d', DATE_SUB(CURRENT_DATE, INTERVAL 1 DAY))
) WHERE is_last_received_value
)
মনে রাখবেন যে এই পোস্টে উল্লেখ করা অন্যান্য সমস্ত প্রশ্ন এই সাবকোয়েরি দিয়ে শুরু হবে।
উদাহরণ প্রশ্ন
পরবর্তী কয়েকটি বিভাগে সাধারণ ওয়েব ভাইটাল কোয়েরির কয়েকটি উদাহরণ দেখায় যা আপনি চালাতে চান।
LCP, INP, এবং CLS সমগ্র সাইট জুড়ে 75% শতাংশে (p75)
# Subquery all Web Vitals events from the last 28 days
WITH web_vitals_events AS (
SELECT event_name as metric_name, * EXCEPT(event_name, is_last_received_value) FROM (
SELECT *, IF (ROW_NUMBER() OVER (
PARTITION BY (SELECT value.string_value FROM UNNEST(event_params) WHERE key = 'metric_id')
ORDER BY (SELECT COALESCE(value.double_value, value.int_value) FROM UNNEST(event_params) WHERE key = 'metric_value') DESC
) = 1, true, false) AS is_last_received_value
FROM `bigquery_project_id.analytics_XXXXX.events_*`
WHERE event_name in ('CLS', 'INP', 'LCP') AND
_TABLE_SUFFIX BETWEEN FORMAT_DATE('%Y%m%d', DATE_SUB(CURRENT_DATE, INTERVAL 28 DAY)) AND FORMAT_DATE('%Y%m%d', DATE_SUB(CURRENT_DATE, INTERVAL 1 DAY))
) WHERE is_last_received_value
)
# Main query logic
SELECT
metric_name,
APPROX_QUANTILES(metric_value, 100)[OFFSET(75)] AS p75,
COUNT(1) as count
FROM (
SELECT
metric_name,
ROUND((SELECT COALESCE(value.double_value, value.int_value) FROM UNNEST(event_params) WHERE key = "metric_value"), 3) AS metric_value,
FROM web_vitals_events
)
GROUP BY 1
সর্বোচ্চ থেকে সর্বনিম্ন পর্যন্ত সমস্ত পৃথক LCP মান
# Subquery all Web Vitals events from the last 28 days
WITH web_vitals_events AS (
SELECT event_name as metric_name, * EXCEPT(event_name, is_last_received_value) FROM (
SELECT *, IF (ROW_NUMBER() OVER (
PARTITION BY (SELECT value.string_value FROM UNNEST(event_params) WHERE key = 'metric_id')
ORDER BY (SELECT COALESCE(value.double_value, value.int_value) FROM UNNEST(event_params) WHERE key = 'metric_value') DESC
) = 1, true, false) AS is_last_received_value
FROM `bigquery_project_id.analytics_XXXXX.events_*`
WHERE event_name in ('CLS', 'INP', 'LCP') AND
_TABLE_SUFFIX BETWEEN FORMAT_DATE('%Y%m%d', DATE_SUB(CURRENT_DATE, INTERVAL 28 DAY)) AND FORMAT_DATE('%Y%m%d', DATE_SUB(CURRENT_DATE, INTERVAL 1 DAY))
) WHERE is_last_received_value
)
# Main query logic
SELECT
ROUND((SELECT COALESCE(value.double_value, value.int_value) FROM UNNEST(event_params) WHERE key = "metric_value"), 3) AS metric_value,
FROM web_vitals_events
WHERE metric_name = 'LCP'
ORDER BY metric_value DESC
সবচেয়ে জনপ্রিয় ১০টি পৃষ্ঠার LCP স্কোর (p75)
# Subquery all Web Vitals events from the last 28 days
WITH web_vitals_events AS (
SELECT event_name as metric_name, * EXCEPT(event_name, is_last_received_value) FROM (
SELECT *, IF (ROW_NUMBER() OVER (
PARTITION BY (SELECT value.string_value FROM UNNEST(event_params) WHERE key = 'metric_id')
ORDER BY (SELECT COALESCE(value.double_value, value.int_value) FROM UNNEST(event_params) WHERE key = 'metric_value') DESC
) = 1, true, false) AS is_last_received_value
FROM `bigquery_project_id.analytics_XXXXX.events_*`
WHERE event_name in ('CLS', 'INP', 'LCP') AND
_TABLE_SUFFIX BETWEEN FORMAT_DATE('%Y%m%d', DATE_SUB(CURRENT_DATE, INTERVAL 28 DAY)) AND FORMAT_DATE('%Y%m%d', DATE_SUB(CURRENT_DATE, INTERVAL 1 DAY))
) WHERE is_last_received_value
)
# Main query logic
SELECT
page_path,
APPROX_QUANTILES(metric_value, 100)[OFFSET(75)] AS LCP,
COUNT(1) as count
FROM (
SELECT
REGEXP_SUBSTR((SELECT value.string_value FROM UNNEST(event_params) WHERE key = "page_location"), r'\.com(\/[^?]*)') AS page_path,
ROUND((SELECT COALESCE(value.double_value, value.int_value) FROM UNNEST(event_params) WHERE key = "metric_value"), 3) AS metric_value,
FROM web_vitals_events
WHERE metric_name = 'LCP'
)
GROUP BY 1
ORDER BY count DESC
LIMIT 10
সবচেয়ে খারাপ CLS সহ শীর্ষ 10 পৃষ্ঠা (p75)
# Subquery all Web Vitals events from the last 28 days
WITH web_vitals_events AS (
SELECT event_name as metric_name, * EXCEPT(event_name, is_last_received_value) FROM (
SELECT *, IF (ROW_NUMBER() OVER (
PARTITION BY (SELECT value.string_value FROM UNNEST(event_params) WHERE key = 'metric_id')
ORDER BY (SELECT COALESCE(value.double_value, value.int_value) FROM UNNEST(event_params) WHERE key = 'metric_value') DESC
) = 1, true, false) AS is_last_received_value
FROM `bigquery_project_id.analytics_XXXXX.events_*`
WHERE event_name in ('CLS', 'INP', 'LCP') AND
_TABLE_SUFFIX BETWEEN FORMAT_DATE('%Y%m%d', DATE_SUB(CURRENT_DATE, INTERVAL 28 DAY)) AND FORMAT_DATE('%Y%m%d', DATE_SUB(CURRENT_DATE, INTERVAL 1 DAY))
) WHERE is_last_received_value
)
# Main query logic
SELECT
page_path,
APPROX_QUANTILES(metric_value, 100)[OFFSET(75)] AS CLS,
COUNT(1) as count
FROM (
SELECT
REGEXP_SUBSTR((SELECT value.string_value FROM UNNEST(event_params) WHERE key = "page_location"), r'\.com(\/[^?]*)') AS page_path,
ROUND((SELECT COALESCE(value.double_value, value.int_value) FROM UNNEST(event_params) WHERE key = "metric_value"), 3) AS metric_value,
FROM web_vitals_events
WHERE metric_name = 'CLS'
)
GROUP BY 1
HAVING count > 50 # Limit to relatively popular pages
ORDER BY CLS DESC
LIMIT 10
ডিবাগ
পূর্ববর্তী প্রশ্নগুলি দেখায় কিভাবে ওয়েব ভাইটাল মেট্রিক ডেটা জিজ্ঞাসা করতে হয়, যা আপনার বর্তমান কার্যক্ষমতা এবং সময়ের সাথে সাথে এটি কীভাবে প্রবণতা রয়েছে তা বোঝার জন্য সহায়ক। কিন্তু আপনি কি করতে পারেন যদি আপনার কর্মক্ষমতা প্রত্যাশার চেয়ে খারাপ হয় কিন্তু আপনি নিশ্চিত না কেন?
আপনার স্কোর কী তা জানা সহায়ক নয় যদি আপনি পদক্ষেপ নিতে এবং সমস্যার সমাধান করতে না পারেন।
ক্ষেত্রের ডিবাগ কর্মক্ষমতা ব্যাখ্যা করে কিভাবে আপনি আপনার বিশ্লেষণ ডেটার সাথে অতিরিক্ত ডিবাগ তথ্য পাঠাতে পারেন। আপনি যদি সেই পোস্টে বিশদ নির্দেশাবলী অনুসরণ করেন, তাহলে আপনি সেই ডিবাগ তথ্যটি BigQuery-এও উপস্থিত দেখতে পাবেন।
উদাহরণ প্রশ্ন
কর্মক্ষমতা সমস্যাগুলির মূল কারণ সনাক্ত করতে সাহায্য করার জন্য কীভাবে debug_target
ইভেন্ট প্যারামিটার ব্যবহার করতে হয় তা নিম্নলিখিত প্রশ্নগুলি দেখায়৷
CLS এ অবদানকারী শীর্ষ উপাদান
debug_target
হল একটি CSS নির্বাচক স্ট্রিং যা মেট্রিক মানের সাথে সবচেয়ে প্রাসঙ্গিক পৃষ্ঠার উপাদানের সাথে মিলে যায়।
CLS-এর সাথে, debug_target
বৃহত্তম লেআউট শিফট থেকে সবচেয়ে বড় উপাদানের প্রতিনিধিত্ব করে যা CLS মানতে অবদান রাখে। যদি কোনো উপাদান স্থানান্তরিত না হয় তাহলে debug_target
মান null
হবে।
নিম্নোক্ত ক্যোয়ারীটি তাদের CLS দ্বারা 75 তম পার্সেন্টাইলে সবচেয়ে খারাপ থেকে সেরা পৃষ্ঠাগুলিকে তালিকাভুক্ত করবে, debug_target
দ্বারা গোষ্ঠীবদ্ধ:
# Subquery all Web Vitals events from the last 28 days
WITH web_vitals_events AS (
SELECT event_name as metric_name, * EXCEPT(event_name, is_last_received_value) FROM (
SELECT *, IF (ROW_NUMBER() OVER (
PARTITION BY (SELECT value.string_value FROM UNNEST(event_params) WHERE key = 'metric_id')
ORDER BY (SELECT COALESCE(value.double_value, value.int_value) FROM UNNEST(event_params) WHERE key = 'metric_value') DESC
) = 1, true, false) AS is_last_received_value
FROM `bigquery_project_id.analytics_XXXXX.events_*`
WHERE event_name in ('CLS', 'INP', 'LCP') AND
_TABLE_SUFFIX BETWEEN FORMAT_DATE('%Y%m%d', DATE_SUB(CURRENT_DATE, INTERVAL 28 DAY)) AND FORMAT_DATE('%Y%m%d', DATE_SUB(CURRENT_DATE, INTERVAL 1 DAY))
) WHERE is_last_received_value
)
# Main query logic
SELECT
page_path,
debug_target,
APPROX_QUANTILES(metric_value, 100)[OFFSET(75)] AS CLS,
COUNT(1) as count
FROM (
SELECT
REGEXP_SUBSTR((SELECT value.string_value FROM UNNEST(event_params) WHERE key = "page_location"), r'\.com(\/[^?]*)') AS page_path,
(SELECT value.string_value FROM UNNEST(event_params) WHERE key = "debug_target") as debug_target,
ROUND((SELECT COALESCE(value.double_value, value.int_value) FROM UNNEST(event_params) WHERE key = "metric_value"), 3) AS metric_value,
*
FROM web_vitals_events
WHERE metric_name = 'CLS'
)
GROUP BY 1, 2
HAVING count > 50 # Limit to relatively popular pages
ORDER BY CLS DESC
পৃষ্ঠার কোন উপাদানগুলি স্থানান্তরিত হচ্ছে তা জানা থাকলে সমস্যার মূল কারণ সনাক্ত করা এবং সমাধান করা আরও সহজ করা উচিত৷
মনে রাখবেন যে এখানে রিপোর্ট করা উপাদানগুলি একই উপাদান নাও হতে পারে যেগুলি আপনি যখন আপনার পৃষ্ঠাগুলিকে স্থানীয়ভাবে ডিবাগ করার সময় স্থানান্তরিত হতে দেখেন, তাই প্রথম স্থানে এই ডেটা ক্যাপচার করা খুবই গুরুত্বপূর্ণ৷ আপনি যে সমস্যাগুলি বুঝতে পারেন না তা ঠিক করা খুব কঠিন!
অন্যান্য মেট্রিক্স ডিবাগ করুন
পূর্ববর্তী ক্যোয়ারী CLS মেট্রিকের ফলাফল দেখায়, কিন্তু LCP এবং INP-এর জন্য ডিবাগ টার্গেট রিপোর্ট করতে ঠিক একই কৌশল ব্যবহার করা যেতে পারে। ডিবাগ করার জন্য প্রাসঙ্গিক মেট্রিকের সাথে যেখানে ক্লজটি প্রতিস্থাপন করুন:
WHERE metric_name = 'INP'
WHERE metric_name = 'LCP'
আবার, প্রতিটি কোর ওয়েব ভাইটাল মেট্রিক্সের জন্য ডিবাগ তথ্য সংগ্রহ এবং পাঠাতে নির্দেশাবলীর জন্য আপনি ক্ষেত্রের ডিবাগ কর্মক্ষমতা উল্লেখ করতে পারেন।
ভিজ্যুয়ালাইজ করুন
শুধুমাত্র প্রশ্নের ফলাফল দেখেই অন্তর্দৃষ্টি পাওয়া চ্যালেঞ্জিং হতে পারে। উদাহরণস্বরূপ, নিম্নলিখিত ক্যোয়ারীটি ডেটাসেটে LCP-এর জন্য দৈনিক 75তম পার্সেন্টাইল মান তালিকাভুক্ত করে।
# Subquery all Web Vitals events from the last 28 days
WITH web_vitals_events AS (
SELECT event_name as metric_name, * EXCEPT(event_name, is_last_received_value) FROM (
SELECT *, IF (ROW_NUMBER() OVER (
PARTITION BY (SELECT value.string_value FROM UNNEST(event_params) WHERE key = 'metric_id')
ORDER BY (SELECT COALESCE(value.double_value, value.int_value) FROM UNNEST(event_params) WHERE key = 'metric_value') DESC
) = 1, true, false) AS is_last_received_value
FROM `bigquery_project_id.analytics_XXXXX.events_*`
WHERE event_name in ('CLS', 'INP', 'LCP') AND
_TABLE_SUFFIX BETWEEN FORMAT_DATE('%Y%m%d', DATE_SUB(CURRENT_DATE, INTERVAL 28 DAY)) AND FORMAT_DATE('%Y%m%d', DATE_SUB(CURRENT_DATE, INTERVAL 1 DAY))
) WHERE is_last_received_value
)
# Main query logic
SELECT
event_date,
metric_name,
APPROX_QUANTILES(ROUND(metric_value, 2), 100)[OFFSET(75)] AS p75
FROM
(
SELECT
event_date,
metric_name,
ROUND((SELECT COALESCE(value.double_value, value.int_value) FROM UNNEST(event_params) WHERE key = 'metric_value'), 3) AS metric_value
FROM web_vitals_events
WHERE
metric_name = 'LCP'
)
GROUP BY
1, 2
ORDER BY event_date
এই ক্যোয়ারী ফলাফলগুলি থেকে, শুধুমাত্র ডেটা দেখে প্রবণতা বা বহিরাগতদের সনাক্ত করা কঠিন।
এই ধরনের ক্ষেত্রে, ডেটা ভিজ্যুয়ালাইজ করা আপনাকে আরও দ্রুত অন্তর্দৃষ্টি পেতে সাহায্য করতে পারে।
লুকার স্টুডিওতে ক্যোয়ারী ফলাফল ভিজ্যুয়ালাইজ করুন
BigQuery ডেটা স্টুডিওর মাধ্যমে যেকোন প্রশ্নের ফলাফল কল্পনা করার একটি দ্রুত উপায় প্রদান করে। লুকার স্টুডিও একটি ডেটা ভিজ্যুয়ালাইজেশন এবং ড্যাশবোর্ডিং টুল যা বিনামূল্যে ব্যবহার করা যায়। আপনার ক্যোয়ারী ফলাফল দেখতে, BigQuery UI-তে আপনার ক্যোয়ারী চালানোর পরে, এক্সপ্লোর ডেটা বোতামে ক্লিক করুন এবং লুকার স্টুডিও দিয়ে এক্সপ্লোর নির্বাচন করুন।
এটি এক্সপ্লোর ভিউতে BigQuery থেকে Looker Studio-তে একটি সরাসরি লিঙ্ক তৈরি করবে। এই দৃশ্যে, আপনি যে ক্ষেত্রগুলিকে কল্পনা করতে চান তা নির্বাচন করতে পারেন, চার্টের ধরনগুলি, সেটআপ ফিল্টারগুলি চয়ন করতে পারেন এবং দ্রুত ভিজ্যুয়াল বিশ্লেষণের জন্য অ্যাডহক চার্ট তৈরি করতে পারেন৷ পূর্ববর্তী ক্যোয়ারী ফলাফল থেকে, আপনি সময়ের সাথে LCP মানগুলির প্রবণতা দেখতে এই লাইন চার্ট তৈরি করতে পারেন:
BigQuery এবং লুকার স্টুডিওর মধ্যে এই সরাসরি লিঙ্কের সাহায্যে, আপনি আপনার যেকোনো প্রশ্ন থেকে দ্রুত চার্ট তৈরি করতে এবং ভিজ্যুয়াল বিশ্লেষণ করতে পারেন। যাইহোক, আপনি যদি অতিরিক্ত বিশ্লেষণ করতে চান, তাহলে আপনি একটি ইন্টারেক্টিভ ড্যাশবোর্ডে আরও সামগ্রিক দৃশ্য পেতে বা ডেটাতে ড্রিল ডাউন করতে সক্ষম হওয়ার জন্য বেশ কয়েকটি চার্ট দেখতে চাইতে পারেন। একটি সহজ ড্যাশবোর্ড থাকার অর্থ হল আপনি যখনই আপনার মেট্রিক্স বিশ্লেষণ করতে চান তখন আপনাকে প্রশ্নগুলি লিখতে এবং ম্যানুয়ালি চার্ট তৈরি করতে হবে না।
আপনি স্থানীয় BigQuery সংযোগকারী ব্যবহার করে Looker Studio-তে একটি ড্যাশবোর্ড তৈরি করতে পারেন। এটি করতে, datastudio.google.com- এ নেভিগেট করুন, একটি নতুন ডেটা উত্স তৈরি করুন, BigQuery সংযোগকারী নির্বাচন করুন এবং আপনি যে ডেটাসেটটির সাথে কাজ করতে চান তা চয়ন করুন:
ওয়েব ভাইটাল ডেটা বস্তুগত করুন
পূর্বে বর্ণিত ওয়েব ভাইটালস ইভেন্ট ডেটার ড্যাশবোর্ড তৈরি করার সময়, Google Analytics 4 এক্সপোর্ট ডেটাসেট সরাসরি ব্যবহার করা কার্যকর নয়। GA4 ডেটার গঠন এবং ওয়েব ভাইটাল মেট্রিক্সের জন্য প্রয়োজনীয় প্রি-প্রসেসিংয়ের কারণে, আপনার ক্যোয়ারীটির কিছু অংশ একাধিকবার শেষ হবে। এটি দুটি সমস্যা তৈরি করে: ড্যাশবোর্ডের কার্যক্ষমতা এবং BigQuery খরচ।
আপনি কোন চার্জ ছাড়াই BigQuery স্যান্ডবক্স মোড ব্যবহার করতে পারেন। BigQuery-এর বিনামূল্যে ব্যবহারের স্তরের সাথে, প্রতি মাসে প্রক্রিয়া করা প্রথম 1 TB কোয়েরি ডেটা বিনামূল্যে। এই পোস্টে আলোচনা করা বিশ্লেষণ পদ্ধতির জন্য, যদি না আপনি একটি উল্লেখযোগ্যভাবে বড় ডেটাসেট ব্যবহার করছেন বা নিয়মিতভাবে ডেটাসেট নিয়ে অনুসন্ধান করছেন, আপনি প্রতি মাসে এই বিনামূল্যের সীমার মধ্যে থাকতে পারবেন। কিন্তু যদি আপনার একটি উচ্চ ট্রাফিক ওয়েবসাইট থাকে এবং আপনি একটি দ্রুত ইন্টারেক্টিভ ড্যাশবোর্ড ব্যবহার করে নিয়মিতভাবে বিভিন্ন মেট্রিক নিরীক্ষণ করতে চান, তাহলে আমরা বিগকুয়েরি কার্যকারিতা বৈশিষ্ট্য যেমন পার্টিশনিং, ক্লাস্টারিং এবং ক্যাশিং ব্যবহার করার সময় আপনার ওয়েব ভিটালস ডেটা প্রিপ্রসেসিং এবং বাস্তবায়িত করার পরামর্শ দিই।
নিম্নলিখিত স্ক্রিপ্টটি আপনার BigQuery ডেটা (উৎস সারণী) প্রিপ্রসেস করবে এবং একটি বস্তুগত টেবিল (টার্গেট টেবিল) তৈরি করবে। আপনার নিজের ডেটাসেটের জন্য এই ক্যোয়ারীটি ব্যবহার করার সময়, আপনি প্রক্রিয়াকৃত ডেটার পরিমাণ কম করার জন্য উত্স টেবিলের জন্য একটি তারিখ পরিসীমা নির্ধারণ করতে চাইতে পারেন।
# Materialize Web Vitals metrics from GA4 event export data
# Replace target table name
CREATE OR REPLACE TABLE bigquery_project_id.ga4_demo_dev.web_vitals_summary
PARTITION BY DATE(event_timestamp)
CLUSTER BY metric_name
AS
SELECT
ga_session_id,
IF(
EXISTS(SELECT 1 FROM UNNEST(events) AS e WHERE e.event_name = 'first_visit'),
'New user',
'Returning user') AS user_type,
IF(
(SELECT MAX(session_engaged) FROM UNNEST(events)) > 0, 'Engaged', 'Not engaged')
AS session_engagement,
evt.* EXCEPT (session_engaged, event_name),
event_name AS metric_name,
FORMAT_TIMESTAMP('%Y%m%d', event_timestamp) AS event_date
FROM
(
SELECT
ga_session_id,
ARRAY_AGG(custom_event) AS events
FROM
(
SELECT
ga_session_id,
STRUCT(
country,
device_category,
device_os,
traffic_medium,
traffic_name,
traffic_source,
page_path,
debug_target,
event_timestamp,
event_name,
metric_id,
IF(event_name = 'LCP', metric_value / 1000, metric_value) AS metric_value,
user_pseudo_id,
session_engaged,
session_revenue) AS custom_event
FROM
(
SELECT
(SELECT value.int_value FROM UNNEST(event_params) WHERE key = 'ga_session_id')
AS ga_session_id,
(SELECT value.string_value FROM UNNEST(event_params) WHERE key = 'metric_id')
AS metric_id,
ANY_VALUE(device.category) AS device_category,
ANY_VALUE(device.operating_system) AS device_os,
ANY_VALUE(traffic_source.medium) AS traffic_medium,
ANY_VALUE(traffic_source.name) AS traffic_name,
ANY_VALUE(traffic_source.source) AS traffic_source,
ANY_VALUE(
REGEXP_SUBSTR(
(SELECT value.string_value FROM UNNEST(event_params) WHERE key = 'page_location'),
r'^[^?]+')) AS page_path,
ANY_VALUE(
(SELECT value.string_value FROM UNNEST(event_params) WHERE key = 'debug_target'))
AS debug_target,
ANY_VALUE(user_pseudo_id) AS user_pseudo_id,
ANY_VALUE(geo.country) AS country,
ANY_VALUE(event_name) AS event_name,
SUM(ecommerce.purchase_revenue) AS session_revenue,
MAX(
(
SELECT
COALESCE(
value.double_value, value.int_value, CAST(value.string_value AS NUMERIC))
FROM UNNEST(event_params)
WHERE key = 'session_engaged'
)) AS session_engaged,
TIMESTAMP_MICROS(MAX(event_timestamp)) AS event_timestamp,
MAX(
(
SELECT COALESCE(value.double_value, value.int_value)
FROM UNNEST(event_params)
WHERE key = 'metric_value'
)) AS metric_value,
FROM
# Replace source table name
`bigquery_project_id.analytics_XXXXX.events_*`
WHERE
event_name IN ('LCP', 'INP', 'CLS', 'first_visit', 'purchase')
GROUP BY
1, 2
)
)
WHERE
ga_session_id IS NOT NULL
GROUP BY ga_session_id
)
CROSS JOIN UNNEST(events) AS evt
WHERE evt.event_name NOT IN ('first_visit', 'purchase');
এই বস্তুগত ডেটাসেটের বিভিন্ন সুবিধা রয়েছে:
- ডেটা স্ট্রাকচার চ্যাপ্টা এবং কোয়েরি করা সহজ।
- এটি মূল GA4 ডেটাসেট থেকে শুধুমাত্র ওয়েব ভাইটাল ইভেন্টগুলি ধরে রাখে।
- সেশন আইডি, ব্যবহারকারীর ধরন (নতুন বনাম রিটার্নিং), এবং সেশনের ব্যস্ততার তথ্য সরাসরি কলামে পাওয়া যায়।
- টেবিলটি তারিখ অনুসারে বিভাজিত এবং মেট্রিক নামের দ্বারা ক্লাস্টার করা হয়েছে । এটি সাধারণত প্রতিটি প্রশ্নের জন্য প্রক্রিয়াকৃত ডেটার পরিমাণ হ্রাস করে।
- যেহেতু এই টেবিলটি জিজ্ঞাসা করার জন্য আপনাকে ওয়াইল্ডকার্ড ব্যবহার করার দরকার নেই, তাই কোয়েরির ফলাফলগুলি 24 ঘন্টা পর্যন্ত ক্যাশে করা যেতে পারে। এটি একই প্রশ্নের পুনরাবৃত্তি থেকে খরচ হ্রাস করে।
- আপনি BigQuery BI ইঞ্জিন ব্যবহার করলে, আপনি এই টেবিলে অপ্টিমাইজ করা SQL ফাংশন এবং অপারেটর চালাতে পারেন।
আপনি BigQuery UI এর মধ্যে থেকে সরাসরি এই বস্তুগত সারণীটি অনুসন্ধান করতে পারেন বা BigQuery সংযোগকারী ব্যবহার করে Looker Studio-তে এটি ব্যবহার করতে পারেন।
ওয়েব ভাইটালস কানেক্টর ব্যবহার করুন
যেহেতু স্ক্র্যাচ থেকে একটি ড্যাশবোর্ড তৈরি করা সময়সাপেক্ষ, তাই আমরা একটি প্যাকেজড সমাধান তৈরি করেছি যা আপনার জন্য একটি টেমপ্লেট ড্যাশবোর্ড তৈরি করবে৷ প্রথমে নিশ্চিত করুন যে আপনি পূর্ববর্তী ক্যোয়ারী ব্যবহার করে আপনার ওয়েব ভাইটাল টেবিলটি বাস্তবায়িত করেছেন। তারপর এই লিঙ্কটি ব্যবহার করে লুকার স্টুডিওর জন্য ওয়েব ভাইটালস সংযোগকারী অ্যাক্সেস করুন: goo.gle/web-vitals-connector
একবার অনুমোদন দেওয়ার পরে, আপনাকে নিম্নলিখিত কনফিগারেশন স্ক্রীনটি দেখতে হবে:
বাস্তবায়িত BigQuery টেবিল আইডি (যেমন টার্গেট টেবিল) এবং আপনার BigQuery বিলিং প্রকল্প আইডি প্রদান করুন। কানেক্ট ক্লিক করার পরে, লুকার স্টুডিও একটি নতুন টেমপ্লেটেড ড্যাশবোর্ড তৈরি করবে এবং এটির সাথে আপনার ডেটা সংযুক্ত করবে। আপনি আপনার পছন্দ মতো ড্যাশবোর্ড সম্পাদনা, পরিবর্তন এবং ভাগ করতে পারেন। আপনি যদি একবার একটি ড্যাশবোর্ড তৈরি করেন, তাহলে আপনাকে আবার সংযোগকারী লিঙ্কে যেতে হবে না, যদি না আপনি বিভিন্ন ডেটাসেট থেকে একাধিক ড্যাশবোর্ড তৈরি করতে চান।
ড্যাশবোর্ড নেভিগেট করুন
আপনি ড্যাশবোর্ডে নেভিগেট করার সাথে সাথে, আপনি সারাংশ ট্যাবে ওয়েব ভাইটাল মেট্রিক্সের দৈনিক প্রবণতা এবং আপনার ওয়েবসাইটের ব্যবহারকারী এবং সেশনের মতো কিছু ব্যবহারের তথ্য দেখতে পাবেন।
ব্যবহারকারী বিশ্লেষণ ট্যাবে, আপনি একটি মেট্রিক নির্বাচন করতে পারেন এবং তারপরে বিভিন্ন ব্যবহার এবং ব্যবসায়িক মেট্রিক্স দ্বারা মেট্রিক্স শতাংশের পাশাপাশি ব্যবহারকারীর সংখ্যার ভাঙ্গন পেতে পারেন।
পৃষ্ঠা পাথ বিশ্লেষণ ট্যাব আপনাকে আপনার ওয়েবসাইটে সমস্যা ক্ষেত্র চিহ্নিত করতে সাহায্য করবে। এখানে, আপনি ওভারভিউ দেখতে একটি মেট্রিক বাছাই করতে পারেন। কিন্তু আপনি y অক্ষের শতকরা মান সহ সমস্ত পৃষ্ঠা পথের স্ক্যাটার-ম্যাপ এবং x অক্ষে রেকর্ড গণনাও দেখতে পাচ্ছেন। স্ক্যাটার ম্যাপ প্রত্যাশিত মেট্রিক মানগুলির চেয়ে কম পৃষ্ঠাগুলি সনাক্ত করতে সাহায্য করতে পারে। একবার আপনি পেজ পাথ টেবিলের স্ক্যাটার চার্ট ব্যবহার করে পৃষ্ঠাগুলি নির্বাচন করলে, আপনি ডিবাগ টার্গেট টেবিলটি দেখে সমস্যাটি আরও ড্রিল করতে পারেন।
আপনি কিভাবে একই জায়গায় আপনার ব্যবসা এবং কর্মক্ষমতা মেট্রিক্স নিরীক্ষণ করতে পারেন তার একটি উদাহরণ হল রাজস্ব বিশ্লেষণ ট্যাব। এই বিভাগটি সমস্ত সেশন প্লট করে যেখানে ব্যবহারকারী একটি ক্রয় করেছেন৷ আপনি একটি নির্দিষ্ট সেশন চলাকালীন ব্যবহারকারীর অভিজ্ঞতার সাথে অর্জিত আয়ের তুলনা করতে পারেন৷
উন্নত ব্যবহার
আপনি ডেটাসেটের সাথে আরও পরিচিত হওয়ার সাথে সাথে আপনি ড্যাশবোর্ড সম্পাদনা করতে পারেন এবং সমৃদ্ধ এবং লক্ষ্যযুক্ত বিশ্লেষণের জন্য আপনার নিজস্ব চার্ট যোগ করতে পারেন। ড্যাশবোর্ডটিকে আরও উপযোগী করতে, আপনি নিম্নলিখিত পদক্ষেপগুলি নিতে পারেন:
- আপডেট করা ডেটা পেতে BigQuery-এ নির্ধারিত কোয়েরি সেট-আপ করুন। আমরা পূর্বে যে বস্তুগতকরণ ক্যোয়ারী চালিয়েছিলাম তা সেই মুহূর্তে আপনার ডেটার একটি স্ন্যাপশট নেয়। আপনি যদি আপনার ড্যাশবোর্ডকে নতুন ডেটার সাথে আপডেট রাখতে চান, তাহলে আপনি একটি নির্ধারিত ক্যোয়ারী চালাতে পারেন যা প্রতিদিন চলবে এবং নতুন ডেটার সাথে আপনার বস্তুগত সারণী যুক্ত করবে৷
- ব্যবসার অন্তর্দৃষ্টির জন্য প্রথম পক্ষের ডেটা (যেমন CRM) যোগ দিন। বস্তুগত সারণীতে, আপনি একটি পৃথক কলাম হিসাবে
user_id
যোগ করতে পারেন। এটি আপনাকে আপনার প্রথম পক্ষের ডেটাতে যোগ দিতে দেবে। যদি আপনার প্রথম পক্ষের ডেটা ইতিমধ্যেই BigQuery-এ না থাকে, আপনি হয় ডেটা লোড করতে পারেন বা একটি ফেডারেটেড ডেটা উৎস ব্যবহার করতে পারেন। - আপনি Google Analytics-এ যে ডেটা পাঠান তার একটি প্যারামিটার হিসাবে আপনার সাইট বা অ্যাপ সংস্করণের প্রতিবেদন করুন এবং এটিকে বস্তুগত সারণীতে একটি কলাম হিসাবে যোগ করুন। তারপরে আপনি সেই সংস্করণের ডেটা আপনার চার্টে একটি মাত্রা হিসাবে যোগ করতে পারেন যাতে সংস্করণ পরিবর্তনগুলি কার্যক্ষমতাকে প্রভাবিত করে তা দেখতে সহজ করে।
- আপনি যদি সরাসরি ক্যোয়ারী বা ড্যাশবোর্ডের মাধ্যমে ডেটাসেটের উল্লেখযোগ্যভাবে ভারী ব্যবহারের আশা করেন, তাহলে আপনি BigQuery BI ইঞ্জিনের অর্থপ্রদানের সংস্করণ ব্যবহার করে দেখতে পারেন।
সারাংশ
এই পোস্টে ক্ষেত্রটিতে সংগৃহীত বাস্তব-ব্যবহারকারীর ডেটা দিয়ে কার্যক্ষমতা পরিমাপ এবং ডিবাগ করার জন্য Google Analytics 4 এবং BigQuery কীভাবে ব্যবহার করতে হয় তার মূল বিষয়গুলি কভার করা হয়েছে৷ লুকার স্টুডিও এবং ওয়েব ভাইটালস কানেক্টর ব্যবহার করে কীভাবে স্বয়ংক্রিয় রিপোর্ট এবং ড্যাশবোর্ড তৈরি করা যায় তা ব্যাখ্যা করা হয়েছে যাতে ডেটা ভিজ্যুয়ালাইজ করা যতটা সম্ভব সহজ হয়।
এই পোস্ট থেকে কিছু গুরুত্বপূর্ণ গ্রহণ:
- আপনার সাইটকে বোঝার, ডিবাগ করার জন্য এবং অপ্টিমাইজ করার জন্য বাস্তব ব্যবহারকারীর ডেটা দিয়ে কর্মক্ষমতা পরিমাপ করা গুরুত্বপূর্ণ।
- আপনার কর্মক্ষমতা মেট্রিক্স এবং আপনার ব্যবসার মেট্রিক্স একই সিস্টেমে থাকলে আপনি গভীর অন্তর্দৃষ্টি পেতে পারেন। Google Analytics এবং BigQuery এটি সম্ভব করে।
- BigQuery কাঁচা Google Analytics ডেটা রপ্তানি করে আপনি সম্ভবত ইতিমধ্যেই জানেন এমন একটি কোয়েরি ভাষা ব্যবহার করে গভীরভাবে, কাস্টম বিশ্লেষণের সীমাহীন সম্ভাবনা।
- গুগলের অনেকগুলি API এবং ভিজ্যুয়ালাইজেশন টুল রয়েছে যেমন লুকার স্টুডিও যা আপনাকে আপনার প্রতিবেদনগুলিকে ঠিক যেভাবে তৈরি করতে চান সেভাবে তৈরি করার স্বাধীনতা দেয়৷