1. ভূমিকা
কনটেন্ট ডেলিভারি নেটওয়ার্ক (CDNs) ব্যবহারকারীর কর্মক্ষমতা উন্নত করে প্রায়শই অ্যাক্সেস করা বিষয়বস্তু শেষ ব্যবহারকারীদের কাছাকাছি ক্যাশ করে, ক্লায়েন্টের কাছাকাছি সংযোগ বন্ধ করে, মূলের সাথে সংযোগ পুনরায় ব্যবহার করে এবং আধুনিক নেটওয়ার্কিং প্রোটোকল এবং কাস্টমাইজেশন গ্রহণের মাধ্যমে। ব্যবহারকারীদের (এবং আমাদের গ্রাহকদের) জন্য, এর অর্থ হল কম বিলম্বিতা, আরও নির্ভরযোগ্যতা এবং কম খরচ - যা উন্নত বিক্রয়, ওয়েব অভিজ্ঞতা এবং ব্যবহারকারীর অভিজ্ঞতায় নিট বৃদ্ধির দিকে পরিচালিত করে৷ খুব কম আধুনিক সাইট এবং ভিডিও স্ট্রিমিং প্ল্যাটফর্ম আজকাল CDN ছাড়াই কাজ করে।
আপনি কি শিখবেন
এই ল্যাবটি মিডিয়া সিডিএন (সিডিএন) + ক্লাউড মিডিয়া লাইভ স্ট্রিমিং এপিআই (লাইভ ভিডিও ট্রান্সকোডিং) + ক্লাউড স্টোরেজ (ভিডিওগুলির জন্য স্টোরেজ) + ভিডিও প্লেয়ার (ভিএলসি, গুগল শাকা প্লেয়ার) সহ একটি লাইভ স্ট্রিমিং ওয়ার্কফ্লো পরিবেশ স্থাপনের পদক্ষেপগুলির মাধ্যমে আমাদের গাইড করবে , ইত্যাদি - HLS + MPEG-DASH প্রস্তুত প্লেয়ার)।
আমরা লাইভ স্ট্রিমিং এপিআই উপাদানগুলি সেট আপ করব - ইনপুট, চ্যানেল - এবং FFmpeg দিয়ে ইনপুট/চ্যানেলে একটি লাইভ ফিড শুরু করব (FFmpeg একটি লাইভ পরীক্ষার সংকেত তৈরি করতে পারে)। লাইভ স্ট্রিমিং API লাইভ ফিডকে ট্রান্সকোড করবে। ট্রান্সকোড করা ভিডিও ম্যানিফেস্ট এবং সেগমেন্টগুলি একটি ক্লাউড স্টোরেজ বালতিতে সংরক্ষণ করা হবে৷ তারপরে আমরা লাইভ ভিডিও ক্লাউড স্টোরেজ বাকেটের মাধ্যমে মিডিয়া CDN সেট আপ করব। অবশেষে, মিডিয়া CDN এর মাধ্যমে ক্যাশে করা লাইভ কন্টেন্ট চালানোর জন্য VLC প্লেয়ার ব্যবহার করা হবে। আমরা মিডিয়া CDN-এর কার্যকলাপকে কল্পনা করার জন্য একটি ক্লাউড মনিটরিং ড্যাশবোর্ডও সেট আপ করব।
আপনি কি নির্মাণ করবেন
এই ল্যাবে আমরা নিম্নলিখিত আর্কিটেকচারের উপর ভিত্তি করে পরিবেশ সেটআপ করব:

আমরা নিম্নলিখিত উপাদানগুলি সেটআপ করব এবং ল্যাবের অংশ হিসাবে নিম্নলিখিত কাজগুলি সম্পাদন করব:
- লাইভ ট্রান্সকোড করা ভিডিওগুলি সংরক্ষণ করার জন্য একটি Google ক্লাউড স্টোরেজ (GCS) বালতি তৈরি করুন৷
- ভিডিওটিকে একাধিক ফর্ম্যাটে ট্রান্সকোড করতে লাইভ স্ট্রিমিং API কনফিগার করুন: HLS + MPEG DASH, SD এবং HD
- লাইভ স্ট্রিমিং উপাদান সেট আপ করুন: ইনপুট/চ্যানেল
- লাইভ স্ট্রিম চ্যানেল শুরু করুন
- GCS বাকেটের সাথে অরিজিন হিসেবে মিডিয়া CDN সেটআপ করুন
- লাইভ চ্যানেল ফিড করতে FFmpeg সেট আপ করুন
- একটি ভিডিও প্লেয়ার দিয়ে ট্রান্সকোড করা লাইভ ফিড স্ট্রিম করুন
- মিডিয়া CDN কার্যকলাপ নিরীক্ষণ করতে একটি ক্লাউড মনিটরিং ড্যাশবোর্ড সেটআপ করুন (লেটেন্সি, ক্যাশে হিট, ক্যাশে মিস, ইত্যাদি)
দ্রষ্টব্য : এই ল্যাবের জন্য, আমরা অনুমান করি যে ব্যবহারকারীদের Google ক্লাউড কনসোলে অ্যাক্সেস আছে এবং ইতিমধ্যেই একটি প্রকল্প সেটআপ রয়েছে৷ আমরা এটাও অনুমান করি যে ব্যবহারকারীরা একটি নতুন পরিবেশ দিয়ে শুরু করেন এবং এই ডেমোর জন্য কিছুই সেটআপ করেননি৷
সমস্ত কনফিগারেশন ক্রিয়াগুলি ক্লাউড শেলের কমান্ড লাইনের মাধ্যমে করা হবে। আমরা সর্বদা কনসোলে কমান্ড লাইনের মাধ্যমে কনফিগার করা উপাদানগুলি পরীক্ষা করতে পারি। আমরা ল্যাব জুড়ে পয়েন্টার দেখতে পাব যা Google ক্লাউড কনসোলের দিকে নির্দেশ করবে।
2. আপনি শুরু করার আগে
মিডিয়া CDN অ্যাক্সেস সীমাবদ্ধ। মিডিয়া CDN-এ অ্যাক্সেস পেতে, আপনার অ্যাকাউন্ট টিমের সাথে যোগাযোগ করুন। তারা আপনার পক্ষে একটি অ্যাক্সেস অনুরোধ তৈরি করতে পারে। আপনি যদি Google-এর অংশ হন এবং মিডিয়া CDN-এর সাথে লাইভ স্ট্রিমিং পরীক্ষা করতে চান, তাহলে মিডিয়া CDN-এ অ্যাক্সেসের অনুরোধ করতে PM for Media CDN-এর সাথে যোগাযোগ করুন।
3. সেটআপ এবং প্রয়োজনীয়তা
ক্লাউড শেল শুরু করুন
যদিও Google ক্লাউড আপনার ল্যাপটপ থেকে দূরবর্তীভাবে পরিচালিত হতে পারে, এই কোডল্যাবে আপনি Google ক্লাউড শেল ব্যবহার করবেন, একটি কমান্ড লাইন পরিবেশ যা ক্লাউডে চলছে।
Google ক্লাউড কনসোল থেকে, উপরের ডানদিকে টুলবারে ক্লাউড শেল আইকনে ক্লিক করুন:

পরিবেশের ব্যবস্থা করতে এবং সংযোগ করতে এটি শুধুমাত্র কয়েক মুহূর্ত নিতে হবে। এটি সমাপ্ত হলে, আপনি এই মত কিছু দেখতে হবে:

এই ভার্চুয়াল মেশিনটি আপনার প্রয়োজনীয় সমস্ত ডেভেলপমেন্ট টুল দিয়ে লোড করা হয়েছে। এটি একটি ক্রমাগত 5GB হোম ডিরেক্টরি অফার করে এবং Google ক্লাউডে চলে, যা নেটওয়ার্ক কর্মক্ষমতা এবং প্রমাণীকরণকে ব্যাপকভাবে উন্নত করে। এই কোডল্যাবে আপনার সমস্ত কাজ একটি ব্রাউজারে করা যেতে পারে। আপনার কিছু ইন্সটল করার দরকার নেই।
4. Google Cloud SDK সংস্করণ
লেখার সময়, 408.0.0 হল সর্বশেষ Google Cloud SDK সংস্করণ। এই ল্যাবের সমস্ত কমান্ড Google ক্লাউড SDK-এর সর্বশেষ সংস্করণ ব্যবহার করে পরীক্ষা করা হয়েছে৷ এগিয়ে যাওয়ার আগে, দয়া করে নিশ্চিত করুন যে ক্লাউড শেল SDK-এর সর্বশেষ সংস্করণ ব্যবহার করছে।
SDK সংস্করণ পরীক্ষা করা হচ্ছে
আমরা SDK সংস্করণ পরীক্ষা করতে gcloud version কমান্ড ব্যবহার করব।
আদেশ
gcloud version | grep "Google Cloud SDK"
আউটপুট উদাহরণ
Google Cloud SDK 408.0.0
পরবর্তী পদক্ষেপ
- যদি SDK সংস্করণ
408.0.0বা উচ্চতর হয়, তাহলে পরবর্তী বিভাগে যান। - যদি SDK সংস্করণ
408.0.0এর চেয়ে কম হয়, তাহলে SDK আপডেট করতে নীচে তালিকাভুক্ত কমান্ডটি চালান৷
sudo apt-get update && sudo apt-get install google-cloud-sdk
5. পূর্বশর্ত
আমরা GCP সংস্থানগুলি কনফিগার করা শুরু করার আগে, আমাদের নিম্নলিখিতগুলি করতে হবে -
- পরিবেশ ভেরিয়েবল সেটআপ করুন
- প্রয়োজনীয় পরিষেবা API সক্রিয় করুন
1. এনভায়রনমেন্ট ভেরিয়েবল সেটআপ করুন
এই ল্যাব জুড়ে, আমরা কয়েকটি ভেরিয়েবল সহ gcloud এবং curl কমান্ড চালাব। আমাদের নিম্নলিখিত পরিবেশ ভেরিয়েবলগুলি কনফিগার করতে হবে।
- প্রকল্প আইডি
- প্রকল্প নম্বর
- ব্যবহারকারীর নাম
- অঞ্চল
- ইনপুট আইডি
- চ্যানেল আইডি
প্রকল্প আইডি এবং ব্যবহারকারীর নাম
এই পরিবেশ ভেরিয়েবলগুলি সাধারণত ক্লাউডশেলে পূর্ব-কনফিগার করা হয়। আমরা যাচাই করতে env কমান্ড ব্যবহার করব।
আদেশ
env | grep -E 'DEVSHELL_PROJECT_ID=|LOGNAME'
আউটপুট উদাহরণ
DEVSHELL_PROJECT_ID=<YOUR_PROJECT_ID> LOGNAME=<YOUR_USERNAME>
env_variables ফাইল তৈরি করুন
env_variables.txt ফাইল তৈরি করতে cat কমান্ড ব্যবহার করুন। নিচের কমান্ডটি ব্যবহারকারীর হোম ডিরেক্টরিতে env_variables.txt ফাইল তৈরি করবে।
কমান্ড
cat > ~/env_variables.txt << EOF export PROJECT_NUMBER=$(gcloud projects describe $GOOGLE_CLOUD_PROJECT --format="value(projectNumber)") export LOCATION=us-west2 export INPUT_ID=lab-live-input export CHANNEL_ID=lab-live-channel EOF
এনভায়রনমেন্ট ভেরিয়েবল সেটআপ করুন
আমরা এনভায়রনমেন্ট ভেরিয়েবল সেট করতে source কমান্ড ব্যবহার করব
আদেশ
source ~/env_variables.txt
ভেরিয়েবল সেট করা আছে তা যাচাই করুন
আসুন যাচাই করি যে সমস্ত প্রয়োজনীয় পরিবেশ ভেরিয়েবল সেট করা আছে। আমাদের আউটপুটে মোট 6টি পরিবেশের ভেরিয়েবল দেখতে হবে।
আদেশ
env | grep -E 'DEVSHELL_PROJECT_ID=|LOGNAME|PROJECT_NUMBER|LOCATION|INPUT_ID|CHANNEL_ID'
আউটপুট উদাহরণ
LOCATION=us-west2 DEVSHELL_PROJECT_ID=<YOUR_PROJECT_ID> LOGNAME=<YOUR_USERNAME> PROJECT_NUMBER=<YOUR_PROJECT_NUMBER> INPUT_ID=lab-live-input CHANNEL_ID=lab-live-channel
2. প্রয়োজনীয় পরিষেবা API সক্রিয় করুন৷
আমাদের নিশ্চিত করতে হবে যে আমাদের প্রকল্পে নিম্নলিখিত APIগুলি সক্ষম করা আছে।
- নেটওয়ার্ক পরিষেবা API
- সার্টিফিকেট ম্যানেজার API
- লাইভস্ট্রিম API
- মিডিয়া CDN এজ ক্যাশে API
নেটওয়ার্ক পরিষেবা API সক্ষম করুন৷
নেটওয়ার্ক পরিষেবা API সক্ষম করতে, নিম্নলিখিত কমান্ডটি চালান:
আদেশ
gcloud services enable networkservices.googleapis.com
সার্টিফিকেট ম্যানেজার API সক্ষম করুন৷
সার্টিফিকেট ম্যানেজার API সক্ষম করতে, নিম্নলিখিত কমান্ডটি চালান:
আদেশ
gcloud services enable certificatemanager.googleapis.com
লাইভ স্ট্রিম API সক্ষম করুন
লাইভ স্ট্রিম API সক্ষম করতে, নিম্নলিখিত কমান্ডটি চালান:
আদেশ
gcloud services enable livestream.googleapis.com
মিডিয়া CDN এজ ক্যাশে API সক্ষম করুন৷
মিডিয়া সিডিএন এজ ক্যাশে এপিআই সক্ষম করতে, নিম্নলিখিত কমান্ডটি চালান:
আদেশ
gcloud services enable edgecache.googleapis.com
যাচাই করুন যে API গুলি সক্ষম হয়েছে৷
সমস্ত সক্রিয় API তালিকা করতে gcloud services list কমান্ড চালান। আমাদের আউটপুটে 4টি API দেখতে হবে।
আদেশ
gcloud services list | grep -E 'networkservices|certificatemanager|livestream|edgecache'
আউটপুট উদাহরণ
NAME: certificatemanager.googleapis.com NAME: livestream.googleapis.com NAME: networkservices.googleapis.com NAME: edgecache.googleapis.com
6. ক্লাউড স্টোরেজ বালতি তৈরি করুন
এই বিভাগে আমরা নিম্নলিখিত কাজ করব:
- একটি ক্লাউড স্টোরেজ বালতি তৈরি করুন
- বালতিটি সর্বজনীনভাবে অ্যাক্সেসযোগ্য করুন
পরে ল্যাবে, আমরা ট্রান্সকোড করা ভিডিও ফাইল সংরক্ষণ করতে এই বালতি ব্যবহার করব। এই বালতিটি মিডিয়া CDN পরিষেবার জন্য একটি অরিজিন স্টোরেজ হিসাবেও কাজ করবে।
1. বালতি তৈরি করুন
বালতি তৈরি করতে আমরা gsutil mb কমান্ড ব্যবহার করব:
আদেশ
gsutil mb gs://live-streaming-storage-$LOGNAME
2. বালতিটি সর্বজনীনভাবে অ্যাক্সেসযোগ্য করুন৷
ফাইলগুলিকে সর্বজনীনভাবে উপলব্ধ করতে আমরা gsutil iam কমান্ড ব্যবহার করব:
আদেশ
gsutil iam ch allUsers:objectViewer gs://live-streaming-storage-$LOGNAME
7. লাইভ স্ট্রিমিং API পরিবেশ সেট আপ করা হচ্ছে
লাইভ স্ট্রিমিং API চেইনের উপাদানগুলি নিম্নরূপ আর্কিটেকচার করা হয়েছে:

আমরা পূর্ববর্তী বিভাগে ক্লাউড স্টোরেজ বাকেট live-streaming-storage-$LOGNAME তৈরি করেছি। পরবর্তী দুটি বিভাগে, আমরা নিম্নলিখিত সংস্থানগুলি তৈরি করব:
- লাইভ স্ট্রিমিং ইনপুট: একটি ইনপুট এন্ডপয়েন্ট হল একটি এন্ডপয়েন্ট যেখানে আপনার এনকোডার আপনার ইনপুট স্ট্রীম পাঠায়। আপনি আপনার স্ট্রীমের জন্য কনফিগারেশন যেমন ইনপুট রেজোলিউশন, ইনপুট টাইপ এবং ভিডিও ক্রপিং নির্দিষ্ট করতে ইনপুট এন্ডপয়েন্ট ব্যবহার করতে পারেন।
- লাইভ স্ট্রিমিং চ্যানেল: একটি চ্যানেল এমন একটি সংস্থান যা একটি ইনপুট এন্ডপয়েন্টের মাধ্যমে ইনপুট স্ট্রীমকে ইনজেস্ট করে, ইনপুট স্ট্রীমকে একাধিক রেন্ডিশনে ট্রান্সকোড করে এবং নির্দিষ্ট স্থানে নির্দিষ্ট ফরম্যাটে আউটপুট লাইভ স্ট্রিম প্রকাশ করে। আপনি একই চ্যানেলে একটি প্রাথমিক এবং ব্যাকআপ ইনপুট স্ট্রীম অন্তর্ভুক্ত করতে পারেন৷
আমরা পরবর্তীতে ল্যাবে নিম্নলিখিত সংস্থানগুলি তৈরি করব:
- এনকোডার: একটি এনকোডার একটি প্রোগ্রাম যা ইনপুট স্ট্রীম পাঠাতে ব্যবহৃত হয়। এই ল্যাবে, আমরা FFmpeg ব্যবহার করব।
8. ইনপুট এন্ডপয়েন্ট তৈরি এবং কনফিগার করুন
input.json ফাইল তৈরি করুন
লাইভ স্ট্রিম সিগন্যাল টাইপ নির্দিষ্ট করতে আমরা একটি input.json ফাইল তৈরি করব। এই ল্যাবে, আমরা RTMP লাইভ সিগন্যাল ব্যবহার করছি।
আদেশ
cat > input.json << EOF
{
"type": "RTMP_PUSH"
}
EOF
ইনপুট এন্ডপয়েন্ট তৈরি করুন
এই ল্যাবের লেখার মতো, লাইভ স্ট্রিম API-এর জন্য কোন gcloud সমর্থন নেই। API কল করতে আমরা curl কমান্ড ব্যবহার করব।
আদেশ
curl -X POST \ -H "Authorization: Bearer "$(gcloud auth application-default print-access-token) \ -H "Content-Type: application/json; charset=utf-8" \ -d @input.json \ "https://livestream.googleapis.com/v1/projects/$PROJECT_NUMBER/locations/$LOCATION/inputs?inputId=$INPUT_ID"
আউটপুট উদাহরণ
{
"name": "projects/PROJECT_NUMBER/locations/us-west2/operations/operation-1661405972853-5e70a38d6f27f-79100d00-310671b4",
"metadata": {
"@type": "type.googleapis.com/google.cloud.video.livestream.v1.OperationMetadata",
"createTime": "2022-08-25T05:39:32.884030164Z",
"target": "projects/PROJECT_NUMBER/locations/us-west2/inputs/lab-live-input",
"verb": "create",
"requestedCancellation": false,
"apiVersion": "v1"
},
"done": false
}
আউটপুটে প্রচুর দরকারী তথ্য রয়েছে, তবে এই সময়ে, আমাদের দুটি ক্ষেত্রে ফোকাস করতে হবে:
- অপারেশন আইডি: আউটপুট থেকে, অপারেশন আইডিটি কপি করুন এবং নোট করুন। নিচে আউটপুট উদাহরণ থেকে অপারেশন আইডি আছে. এটি
"name"দিয়ে শুরু হওয়া আউটপুট লাইনে পাওয়া যাবে।"operation-1661405972853-5e70a38d6f27f-79100d00-310671b4" - স্ট্যাটাস: আমাদের স্ট্যাটাস
"done": falseথেকে"done": true
স্ট্যাটাস চেক করুন
আমরা আরও এগিয়ে যাওয়ার আগে, আমাদের পরীক্ষা করতে হবে যে ইনপুট এন্ডপয়েন্ট সফলভাবে তৈরি হয়েছে এবং প্রস্তুত।
নীচের কমান্ডে, <OPERATION> পরিবর্তে আমরা উপরে যে অপারেশনটি পেয়েছি তার আইডি দিয়ে। এই উদাহরণে এটি "operation-1661405972853-5e70a38d6f27f-79100d00-310671b4" ।
আদেশ
export OPERATION_ID_1=<OPERATION>
আদেশ
curl -X GET \ -H "Authorization: Bearer "$(gcloud auth application-default print-access-token) \ "https://livestream.googleapis.com/v1/projects/$PROJECT_NUMBER/locations/$LOCATION/operations/$OPERATION_ID_1"
আউটপুট উদাহরণ
{
"name": "projects/PROJECT_NUMBER/locations/us-west2/operations/operation-1661408816982-5e70ae25cea49-617844f0-8fdcb4a1",
"metadata": {
"@type": "type.googleapis.com/google.cloud.video.livestream.v1.OperationMetadata",
"createTime": "2022-08-25T06:26:57.001530499Z",
"endTime": "2022-08-25T06:26:57.043623522Z",
"target": "projects/PROJECT_NUMBER/locations/us-west2/inputs/lab-live-input",
"verb": "create",
"requestedCancellation": false,
"apiVersion": "v1"
},
"done": true,
"response": {
"@type": "type.googleapis.com/google.cloud.video.livestream.v1.Input",
"name": "projects/PROJECT_ID/locations/us-west2/inputs/lab-live-input",
"createTime": "2022-08-25T06:26:56.997623672Z",
"updateTime": "2022-08-25T06:26:56.997623672Z",
"type": "RTMP_PUSH",
"uri": "rtmp://34.94.97.220/live/4b7846a1-4a67-44ed-bfd0-d98281b6464a",
"tier": "HD"
}
}
ইনপুট এন্ডপয়েন্ট তৈরি হয়েছে এবং প্রস্তুত হয়েছে তা নির্দেশ করে আপনি "done:true" দেখতে না হওয়া পর্যন্ত কমান্ডটি পুনরায় চালান।
URI সংরক্ষণ করুন
আমরা পরবর্তীতে ল্যাবে আগের আউটপুট থেকে URI ব্যবহার করব। এই সময়ে, URI এর জন্য একটি পরিবেশ পরিবর্তনশীল সেট করা যাক।
আদেশ
export URI=<uri>
আপনি উপরে উল্লেখিত URI দিয়ে <uri> প্রতিস্থাপন করুন। ঐচ্ছিকভাবে, আপনি URI পুনরুদ্ধার করতে GET পদ্ধতিও ব্যবহার করতে পারেন
আদেশ
curl -s -X GET -H "Authorization: Bearer "$(gcloud auth application-default print-access-token) "https://livestream.googleapis.com/v1/projects/$PROJECT_NUMBER/locations/$LOCATION/inputs/$INPUT_ID" | jq .uri
9. লাইভ স্ট্রিমিং চ্যানেল তৈরি ও কনফিগার করুন
আসুন লাইভ স্ট্রিমিং চ্যানেল তৈরি করি, যে ইনপুট এন্ডপয়েন্টের সাথে যুক্ত আমরা এইমাত্র পূর্ববর্তী বিভাগে তৈরি করেছি। নিম্নলিখিত উদাহরণটি একটি HLS লাইভ স্ট্রিম তৈরি করে এমন একটি চ্যানেল তৈরি করে যা একটি একক, উচ্চ-সংজ্ঞা (1280x720) উপস্থাপনা নিয়ে গঠিত। চ্যানেলটি ইনপুট এন্ডপয়েন্ট এবং স্টোরেজ বাকেটের সাথে যুক্ত হবে যা আমরা আগে তৈরি করেছি।
channel.json ফাইলটি তৈরি করুন
ক্লাউড শেল টার্মিনালে, একটি "channel.json" ফাইল তৈরি করতে নিম্নলিখিত কমান্ডটি টাইপ করুন:
আদেশ
cat > channel.json << EOF
{
"inputAttachments": [
{
"key": "my-input",
"input": "projects/$PROJECT_NUMBER/locations/$LOCATION/inputs/$INPUT_ID"
}
],
"output": {
"uri": "gs://live-streaming-storage-$LOGNAME"
},
"elementaryStreams": [
{
"key": "es_video",
"videoStream": {
"h264": {
"profile": "high",
"widthPixels": 1280,
"heightPixels": 720,
"bitrateBps": 3000000,
"frameRate": 30
}
}
},
{
"key": "es_audio",
"audioStream": {
"codec": "aac",
"channelCount": 2,
"bitrateBps": 160000
}
}
],
"muxStreams": [
{
"key": "mux_video_ts",
"container": "ts",
"elementaryStreams": ["es_video", "es_audio"],
"segmentSettings": { "segmentDuration": "2s" }
}
],
"manifests": [
{
"fileName": "main.m3u8",
"type": "HLS",
"muxStreams": [
"mux_video_ts"
],
"maxSegmentCount": 5
}
]
}
EOF
চ্যানেল তৈরি করুন
চ্যানেল তৈরি করতে নিম্নলিখিত curl কমান্ডটি চালান:
আদেশ
curl -X POST \ -H "Authorization: Bearer "$(gcloud auth application-default print-access-token) \ -H "Content-Type: application/json; charset=utf-8" \ -d @channel.json \ "https://livestream.googleapis.com/v1/projects/$PROJECT_NUMBER/locations/$LOCATION/channels?channelId=$CHANNEL_ID"
আউটপুট উদাহরণ
{
"name": "projects/PROJECT_NUMBER/locations/us-west2/operations/operation-1661405972853-5e70a38d6f27f-79100d00-310671b4",
"metadata": {
"@type": "type.googleapis.com/google.cloud.video.livestream.v1.OperationMetadata",
"createTime": "2022-08-25T05:39:32.884030164Z",
"target": "projects/PROJECT_NUMBER/locations/us-west2/channels/lab-live-channel",
"verb": "create",
"requestedCancellation": false,
"apiVersion": "v1"
},
"done": false
}
অপারেশন আইডি নোট করুন এবং অনুলিপি করুন। আমরা আসন্ন পদক্ষেপ এক এটি প্রয়োজন হবে. এটি "name" দিয়ে শুরু হওয়া আউটপুট লাইনে পাওয়া যাবে।
স্ট্যাটাস চেক করুন
আমরা আরও এগিয়ে যাওয়ার আগে, আমাদের চেক করতে হবে যে চ্যানেলটি সফলভাবে তৈরি হয়েছে এবং প্রস্তুত।
নীচের কমান্ডে, <OPERATION> পরিবর্তে আমরা উপরে যে অপারেশনটি পেয়েছি তার আইডি দিয়ে। এই উদাহরণে এটি operation-1661405972853-5e70a38d6f27f-79100d00-310671b4
আদেশ
export OPERATION_ID_2=<OPERATION>
আদেশ
curl -s -X GET \ -H "Authorization: Bearer "$(gcloud auth application-default print-access-token) \ "https://livestream.googleapis.com/v1/projects/$PROJECT_NUMBER/locations/$LOCATION/operations/$OPERATION_ID_2"
আউটপুট উদাহরণ
"name": "projects/PROJECT_NUMBER/locations/us-west2/operations/operation-1668666801461-5eda4c3f31852-a4d2229f-0efeef9e",
"metadata": {
"@type": "type.googleapis.com/google.cloud.video.livestream.v1.OperationMetadata",
"createTime": "2022-11-17T06:33:21.500841488Z",
"endTime": "2022-11-17T06:33:21.529311112Z",
"target": "projects/PROJECT_NUMBER/locations/us-west2/channels/lab-live-channel",
"verb": "create",
"requestedCancellation": false,
"apiVersion": "v1"
},
"done": true,
"response": {
"@type": "type.googleapis.com/google.cloud.video.livestream.v1.Channel",
"name": "projects/PROJECT_NAME/locations/us-west2/channels/lab-live-channel",
"createTime": "2022-11-17T06:33:21.497818033Z",
"updateTime": "2022-11-17T06:33:21.497818033Z",
"activeInput": "my-input",
"output": {
"uri": "gs://live-streaming-storage-LOGNAME"
},
"elementaryStreams": [
{
"videoStream": {
"h264": {
"widthPixels": 1280,
"heightPixels": 720,
"frameRate": 30,
"bitrateBps": 3000000,
"gopDuration": "2s",
"vbvSizeBits": 3000000,
"vbvFullnessBits": 2700000,
"entropyCoder": "cabac",
"profile": "high"
}
},
"key": "es_video"
},
{
"audioStream": {
"codec": "aac",
"bitrateBps": 160000,
"channelCount": 2,
"sampleRateHertz": 48000
},
"key": "es_audio"
}
],
"muxStreams": [
{
"key": "mux_video_ts",
"container": "ts",
"elementaryStreams": [
"es_video",
"es_audio"
],
"segmentSettings": {
"segmentDuration": "2s"
}
}
],
"manifests": [
{
"fileName": "main.m3u8",
"type": "HLS",
"muxStreams": [
"mux_video_ts"
],
"maxSegmentCount": 5,
"segmentKeepDuration": "60s"
}
],
"streamingState": "STOPPED",
"inputAttachments": [
{
"key": "my-input",
"input": "projects/PROJECT_NUMBER/locations/us-west2/inputs/lab-live-input"
}
],
"logConfig": {
"logSeverity": "OFF"
}
}
}
ইনপুট এন্ডপয়েন্ট তৈরি হয়েছে এবং প্রস্তুত হয়েছে তা নির্দেশ করে আপনি "done:true" দেখতে না হওয়া পর্যন্ত কমান্ডটি পুনরায় চালান।
মনে রাখবেন যে এই মুহূর্তে "streamingState" "STOPPED" ; আমরা পরবর্তী বিভাগে চ্যানেলটি শুরু করব।
10. লাইভ স্ট্রিমিং চ্যানেল শুরু করুন
এখন যেহেতু আমরা আমাদের লাইভ স্ট্রিম চ্যানেল তৈরি করেছি, আসুন চ্যানেলটি শুরু করি। এই বিভাগে, আমরা নিম্নলিখিত কাজ করব:
- লাইভ স্ট্রিমিং চ্যানেল শুরু করুন
- চ্যানেলের স্থিতি পরীক্ষা করুন, আমাদের নিশ্চিত করতে হবে যে
streamingState"AWAITING INPUT"
1. চ্যানেল শুরু করুন
ক্লাউড শেলে, চ্যানেলটি শুরু করতে নিম্নলিখিত curl কমান্ডটি চালান:
আদেশ
curl -X POST \ -H "Authorization: Bearer "$(gcloud auth application-default print-access-token) \ -H "Content-Type: application/json; charset=utf-8" \ -d "" \ "https://livestream.googleapis.com/v1/projects/$PROJECT_NUMBER/locations/$LOCATION/channels/$CHANNEL_ID:start"
আউটপুট উদাহরণ
{
"name": "projects/PROJECT_NUMBER/locations/LOCATION/operations/operation-1661405972853-5e70a38d6f27f-79100d00-310671b4",
"metadata": {
"@type": "type.googleapis.com/google.cloud.video.livestream.v1.OperationMetadata",
"createTime": "2022-08-25T05:39:32.884030164Z",
"target": "projects/PROJECT_NUMBER/locations/us-west2/channels/lab-live-channel",
"verb": "start",
"requestedCancellation": false,
"apiVersion": "v1"
},
"done": false
}
2. চ্যানেলের স্থিতি পরীক্ষা করুন
চ্যানেলের স্থিতি পেতে নিম্নলিখিত curl কমান্ডটি চালান:
আদেশ
curl -s -X GET -H "Authorization: Bearer "$(gcloud auth application-default print-access-token) "https://livestream.googleapis.com/v1/projects/$PROJECT_NUMBER/locations/$LOCATION/channels/$CHANNEL_ID" | grep "streamingState"
আউটপুট উদাহরণ
"streamingState": "AWAITING_INPUT",
কমান্ডটি পুনরায় চালান যতক্ষণ না আপনি " AWAITING_INPUT " দেখতে পাচ্ছেন যে চ্যানেল চলছে এবং একটি সংকেত পাওয়ার জন্য প্রস্তুত।
11. মিডিয়া CDN কনফিগার করুন
এই বিভাগে আমরা মিডিয়া CDN - CDN পরিকাঠামো স্থাপন করব। আমরা নিম্নলিখিত সংস্থান তৈরি করব:
- এজ ক্যাশে অরিজিন
- এজ ক্যাশে পরিষেবা
1. একটি এজ ক্যাশে অরিজিন তৈরি করুন
একটি এজ ক্যাশে অরিজিন একটি বিষয়বস্তুর অবস্থান উপস্থাপন করে, যেমন একটি ক্লাউড স্টোরেজ বালতি, একটি তৃতীয় পক্ষের স্টোরেজ অবস্থান, বা একটি লোড ব্যালেন্সার৷ CDN পরিভাষায়, উৎপত্তি (বা অরিজিন সার্ভার) হল সেই অবস্থান যেখানে আমরা যে সামগ্রী বিতরণ করতে চাই তার উৎসটি অবস্থিত - যেমন সমস্ত CSS, Javascripts, HTML, ছবি ইত্যাদি। এই ল্যাবের জন্য, আমরা একটি অরিজিন তৈরি করব যা ম্যাপ করে ক্লাউড স্টোরেজ বালতিতে যা আমরা ল্যাবের শুরুতে তৈরি করেছি। আমরা এজ ক্যাশে অরিজিনকে cme-origin বলব। একটি CDN এর উৎপত্তি হল যেখানে সমস্ত উৎস বিষয়বস্তু প্রান্ত ক্যাশে সার্ভারে বিতরণ করার আগে সংরক্ষণ করা হয়।
আমরা অরিজিন তৈরি করতে gcloud edge-cache origins create কমান্ড ব্যবহার করব। কমান্ডটি সম্পূর্ণ হতে কয়েক মিনিট সময় লাগবে।
আদেশ
gcloud edge-cache origins create cme-origin \ --origin-address="gs://live-streaming-storage-$LOGNAME"
উদাহরণ আউটপুট
Create request issued for: cme-origin Waiting for operation [projects/my-project/locations/global/operations/operation-1612121774168-5ba3759af1919- 3fdcd7b1-99f59223] to complete...done Created origin cme-origin
2. একটি এজ ক্যাশে পরিষেবা তৈরি করুন৷
এখন যেহেতু আমাদের একটি এজ ক্যাশে অরিজিন সেট আপ আছে, আমরা এজ ক্যাশে পরিষেবা নিজেই তৈরি করতে পারি।
cme-demo.yaml ফাইলটি তৈরি করুন
এজ ক্যাশে পরিষেবা কনফিগারেশন একটি YAML ফাইলের মাধ্যমে সম্পন্ন করা হয়। ক্লাউড শেলে, cme-demo.yaml নামে একটি স্থানীয় ফাইল তৈরি করুন। vi , nano বা অন্য কোন সম্পাদক ব্যবহার করুন এবং YAML ফাইলে নিম্নলিখিত লাইনগুলি পেস্ট করুন:
name: cme-demo
routing:
hostRules:
- hosts:
- demo.cme.com
pathMatcher: routes
pathMatchers:
- name: routes
routeRules:
- headerAction:
responseHeadersToAdd:
- headerName: x-cache-status
headerValue: "{cdn_cache_status}"
matchRules:
- prefixMatch: /
origin: cme-origin
priority: 100
routeAction:
cdnPolicy:
cacheKeyPolicy: {}
cacheMode: FORCE_CACHE_ALL
defaultTtl: 3600s
signedRequestMode: DISABLED
- headerAction:
responseHeadersToAdd:
- headerName: x-cache-status
headerValue: "{cdn_cache_status}"
matchRules:
- pathTemplateMatch: /**.m3u8
origin: cme-origin
priority: 25
routeAction:
cdnPolicy:
cacheKeyPolicy: {}
cacheMode: FORCE_CACHE_ALL
defaultTtl: 1s
signedRequestMode: DISABLED
- headerAction: {}
matchRules:
- pathTemplateMatch: /**.ts
origin: cme-origin
priority: 50
routeAction:
cdnPolicy:
cacheKeyPolicy: {}
cacheMode: FORCE_CACHE_ALL
defaultTtl: 2s
signedRequestMode: DISABLED
আমরা সমস্ত এজ ক্যাশে পরিষেবা কনফিগারেশন ডিফল্ট ছেড়ে দেব। উপরের ফাইলটিতে 3টি ক্ষেত্রের মান রয়েছে যা ব্যবহারকারীরা আপডেট করতে চাইতে পারেন:
-
name: মিডিয়া CDN উদাহরণের নাম - এখানে:cme-demo -
hosts:ডোমেন নামের তালিকা যা এই মিডিয়া CDN পরিষেবা দ্বারা সমাধান করা হবে - এখানে:demo.cme.com। আমরা এই ডেমো সময় এটি ব্যবহার করব. আমরা মিডিয়া সিডিএন ইনস্ট্যান্সের আইপি ঠিকানা ব্যবহার করব। -
Origin:এটি হল এজ ক্যাশে অরিজিন যা আমরা আগের ধাপে তৈরি করেছি। এটিকেcme-originএ সেট করুন - মিডিয়া CDN অরিজিনের নাম।
আপনি YAML ফাইলে ব্যবহার করতে পারেন এমন বিভিন্ন ভেরিয়েবল সম্পর্কে আরও তথ্যের জন্য, এজ ক্যাশে পরিষেবা কনফিগারেশন গাইড দেখুন।
এজ ক্যাশে পরিষেবা তৈরি করুন
আমরা হোস্ট demo.cme.com সহ এজ ক্যাশে অরিজিন cme-origin এ cme-demo নামে একটি এজ ক্যাশে পরিষেবা তৈরি করব। পরিষেবাটি তৈরি করতে ক্লাউড শেলে নিম্নলিখিত কমান্ডটি চালান:
আদেশ
gcloud edge-cache services import cme-demo \
--source=cme-demo.yaml
এজ ক্যাশে পরিষেবা তৈরি করতে কয়েক মিনিট সময় লাগতে পারে।
আউটপুট উদাহরণ
Request issued for: [cme-demo]
Waiting for operation [projects/PROJECT_ID/locations/global/operations/operation-1670476252264-5ef4a0f9f36ce-dd380af5-321be9a0] to complete...done.
createTime: '2022-12-07T18:08:54.403446942Z'
ipv4Addresses:
- 34.104.35.152
ipv6Addresses:
- '2600:1900:4110:d18::'
name: projects/PROJECT_ID/locations/global/edgeCacheServices/cme-demo
routing:
hostRules:
- hosts:
- demo.cme.com
- 34.104.35.152
pathMatcher: routes
pathMatchers:
- name: routes
routeRules:
- headerAction:
responseHeadersToAdd:
- headerName: x-cache-status
headerValue: '{cdn_cache_status}'
matchRules:
- prefixMatch: /
origin: projects/123456789/locations/global/edgeCacheOrigins/cme-origin
priority: '100'
routeAction:
cdnPolicy:
cacheKeyPolicy: {}
cacheMode: FORCE_CACHE_ALL
defaultTtl: 3600s
signedRequestMode: DISABLED
- headerAction:
responseHeadersToAdd:
- headerName: x-cache-status
headerValue: '{cdn_cache_status}'
matchRules:
- pathTemplateMatch: /**.m3u8
origin: projects/123456789/locations/global/edgeCacheOrigins/cme-origin
priority: '25'
routeAction:
cdnPolicy:
cacheKeyPolicy: {}
cacheMode: FORCE_CACHE_ALL
defaultTtl: 1s
signedRequestMode: DISABLED
- headerAction: {}
matchRules:
- pathTemplateMatch: /**.ts
origin: projects/123456789/locations/global/edgeCacheOrigins/cme-origin
priority: '50'
routeAction:
cdnPolicy:
cacheKeyPolicy: {}
cacheMode: FORCE_CACHE_ALL
defaultTtl: 2s
signedRequestMode: DISABLED
updateTime: '2022-12-08T05:11:31.598744308Z'
এজ ক্যাশে সার্ভিস ইনস্ট্যান্সের ipv4Addresses নোট করুন এবং অনুলিপি করুন - এখানে 34.104.36.157 । আমরা cme-demo.yaml ফাইল আপডেট করতে এবং পরে ট্রান্সকোড করা ভিডিও স্ট্রিম করতে এটি ব্যবহার করব।
এজ ক্যাশে পরিষেবা আপডেট করুন
এই মুহুর্তে এজ ক্যাশে পরিষেবা কনফিগারেশন আপডেট করা একটি ভাল ধারণা যাতে পরবর্তীতে ভিডিওটি স্ট্রিম করতে পরিষেবাটির আইপি ব্যবহার করতে সক্ষম হয়৷ এজ ক্যাশে পরিষেবা YAML ফাইলটি আমাদের সমস্ত হোস্টের নাম/আইপি তালিকাভুক্ত করতে দেয় যেগুলি এজ ক্যাশে পরিষেবা থেকে অনুরোধ গ্রহণ করবে। এই মুহুর্তে আমরা শুধুমাত্র একটি হোস্ট হিসাবে demo.cme.com নির্দিষ্ট করেছি। এই ডোমেনের জন্য নাম রেজোলিউশন প্রদান করতে, আপনি একটি DNS জোন ক্লাউড কনফিগার করুন৷ যাইহোক, একটি সহজ সমাধান হল yaml ফাইলের হোস্ট তালিকায় IP ঠিকানা যোগ করা। YAML ফাইলটি আবার সম্পাদনা করুন এবং নীচের মত দেখতে এটি সম্পাদনা করুন:
name: cme-demo
routing:
hostRules:
- hosts:
- demo.cme.com
- IPADDRESS
pathMatcher: routes
pathMatchers:
- name: routes
routeRules:
- headerAction:
responseHeadersToAdd:
- headerName: x-cache-status
headerValue: "{cdn_cache_status}"
matchRules:
- prefixMatch: /
origin: cme-origin
priority: 100
routeAction:
cdnPolicy:
cacheKeyPolicy: {}
cacheMode: FORCE_CACHE_ALL
defaultTtl: 3600s
signedRequestMode: DISABLED
- headerAction:
responseHeadersToAdd:
- headerName: x-cache-status
headerValue: "{cdn_cache_status}"
matchRules:
- pathTemplateMatch: /**.m3u8
origin: cme-origin
priority: 25
routeAction:
cdnPolicy:
cacheKeyPolicy: {}
cacheMode: FORCE_CACHE_ALL
defaultTtl: 1s
signedRequestMode: DISABLED
- headerAction: {}
matchRules:
- pathTemplateMatch: /**.ts
origin: cme-origin
priority: 50
routeAction:
cdnPolicy:
cacheKeyPolicy: {}
cacheMode: FORCE_CACHE_ALL
defaultTtl: 2s
signedRequestMode: DISABLED
পরিবর্তনগুলি প্রতিফলিত করতে আমাদের শুধু YAML ফাইল পুনরায় আমদানি করতে হবে। ক্লাউড শেল টার্মিনালে নিম্নলিখিত কমান্ডটি চালান:
আদেশ
gcloud edge-cache services import cme-demo \
--source=cme-demo.yaml
কমান্ডের আউটপুট পরীক্ষা করুন এবং আইপি হোস্টের তালিকায় উপস্থিত হয়েছে কিনা তা যাচাই করুন।
এই মুহুর্তে এজ ক্যাশে পরিষেবা দৃষ্টান্ত "demo.cme.com" বা হোস্ট হিসাবে IP ঠিকানা সহ অনুরোধগুলি গ্রহণ করবে৷
12. ইনপুট সিগন্যাল তৈরি করুন
এখন যেহেতু আমরা সমস্ত প্রয়োজনীয় পরিষেবাগুলি কনফিগার করেছি, আসুন লাইভ স্ট্রিম ইনপুট সংকেত তৈরি করি৷ এই বিভাগে, আমরা নিম্নলিখিত কাজ করব:
- FFmpeg ইনস্টল করুন, একটি বিনামূল্যের ওপেন সোর্স সফ্টওয়্যার৷
- ইনপুট/চ্যানেলে একটি টেস্ট লাইভ সিগন্যাল পাঠান
1. FFmpeg ইনস্টল করুন
FFmpeg হল একটি বিনামূল্যের এবং ওপেন সোর্স সফ্টওয়্যার প্রকল্প যাতে ভিডিও, অডিও এবং অন্যান্য মাল্টিমিডিয়া ফাইল এবং স্ট্রীম পরিচালনার জন্য লাইব্রেরি এবং প্রোগ্রামগুলির একটি স্যুট থাকে। ক্লাউড শেল টার্মিনালে, FFmpeg ইনস্টল করতে নিম্নলিখিত কমান্ডটি ব্যবহার করুন:
আদেশ
sudo apt install ffmpeg -y
ইন্সটল হয়ে গেলে FFmpeg এর ভার্সন চেক করে সঠিকভাবে ইন্সটল করা হয়েছে তা যাচাই করি:
আদেশ
ffmpeg -version
আউটপুট উদাহরণ
ffmpeg version 4.3.4-0+deb11u1 Copyright (c) 2000-2021 the FFmpeg developers built with gcc 10 (Debian 10.2.1-6) ...
FFmpeg সঠিকভাবে ইনস্টল করা হয়েছিল।
2. ইনপুট/চ্যানেলে লাইভ স্ট্রিম সংকেত শুরু করুন
এখন যেহেতু FFmpeg ইনস্টল করা হয়েছে, আমরা লাইভ স্ট্রিম তৈরি করতে ইনপুট এন্ডপয়েন্টে একটি টেস্ট ইনপুট স্ট্রিম পাঠাব।
ক্লাউড শেল টার্মিনালে নিম্নলিখিত কমান্ডটি চালান, URI এনভায়রনমেন্ট ভেরিয়েবল ব্যবহার করে যা আমরা "ইনপুট এন্ডপয়েন্ট তৈরি এবং কনফিগার করুন" বিভাগে তৈরি করেছি।
আদেশ
ffmpeg -re -f lavfi -i "testsrc=size=1280x720 [out0]; sine=frequency=500 [out1]" \ -acodec aac -vcodec h264 -f flv $URI
আপনি FFmpeg পরীক্ষা লাইভ সংকেত পাঠাতে দেখতে হবে. কমান্ড প্রম্পট ফেরত দেবে না। আপনি এটি বন্ধ না করা পর্যন্ত সংকেত তৈরি করা হবে। ল্যাবের বাকি অংশের জন্য আপনাকে একটি নতুন ক্লাউড শেল উইন্ডো খুলতে হবে।
13. নতুন ক্লাউড শেল খুলুন
এই মুহুর্তে আপনাকে ল্যাবটি চালিয়ে যাওয়ার জন্য একটি নতুন ক্লাউড শেল উইন্ডো খুলতে হবে কারণ FFmpeg স্থায়ীভাবে চলতে চলেছে যতক্ষণ না আপনি <CTRL+C> এটিকে থামানোর নির্দেশ না দেন এবং এইভাবে লাইভ সিগন্যাল জেনারেশন বন্ধ করেন।
বর্তমান ক্লাউড শেল টার্মিনালের নামের পাশে "+" চিহ্নে ক্লিক করুন। এটি একটি অতিরিক্ত ক্লাউড শেল উইন্ডো খুলবে।

নতুন খোলা ক্লাউড শেল উইন্ডোতে ল্যাবের বাকি অংশ চালান।
এনভায়রনমেন্ট ভেরিয়েবল সেটআপ করুন
যেহেতু এটি একটি নতুন CloudShell, আমাদের আবার পরিবেশের ভেরিয়েবল সেট করতে হবে। আমরা এনভায়রনমেন্ট ভেরিয়েবল সেট করতে source কমান্ড ব্যবহার করব।
আদেশ
source ~/env_variables.txt
ভেরিয়েবল সেট করা আছে তা যাচাই করুন
আসুন যাচাই করি যে সমস্ত প্রয়োজনীয় পরিবেশ ভেরিয়েবল সেট করা আছে। আমাদের আউটপুটে মোট 6টি পরিবেশের ভেরিয়েবল দেখতে হবে।
আদেশ
env | grep -E 'DEVSHELL_PROJECT_ID=|LOGNAME|PROJECT_NUMBER|LOCATION|INPUT_ID|CHANNEL_ID'
আউটপুট উদাহরণ
LOCATION=us-west2 DEVSHELL_PROJECT_ID=<YOUR_PROJECT_ID> LOGNAME=<YOUR_USERNAME> PROJECT_NUMBER=<YOUR_PROJECT_NUMBER> INPUT_ID=lab-live-input CHANNEL_ID=lab-live-channel
14. লাইভ সিগন্যাল ট্রান্সকোড হচ্ছে তা যাচাই করুন
আমরা চ্যানেল বর্ণনা করার জন্য একটি curl চালাব। আমাদের আউটপুটে দেখা উচিত যে স্ট্রিমিং স্টেট "AWAITING_INPUT" থেকে "STREAMING" এ পরিবর্তিত হয়েছে
আদেশ
curl -s -X GET -H "Authorization: Bearer "$(gcloud auth application-default print-access-token) "https://livestream.googleapis.com/v1/projects/$PROJECT_NUMBER/locations/$LOCATION/channels/$CHANNEL_ID" | grep "streamingState"
আউটপুট JSON ফাইলের প্রতিক্রিয়াতে আপনি "streamingState": "STREAMING" - ইঙ্গিত করে যে চ্যানেলটি স্ট্রিমিং হচ্ছে এবং লাইভ সিগন্যাল ট্রান্সকোড হচ্ছে।
আসুন বাকেটের বিষয়বস্তুও যাচাই করি যেখানে আমাদের একটি ম্যানিফেস্ট ফাইল এবং বেশ কয়েকটি TS ভিডিও সেগমেন্ট দেখতে হবে। আমরা ল্যাবের শুরুতে যে বালতি তৈরি করেছি এবং ট্রান্সকোড করা লাইভ সিগন্যাল ম্যানিফেস্ট এবং TS ভিডিও সেগমেন্টগুলিকে আউটপুট করতে লাইভ স্ট্রিমিং API দ্বারা ব্যবহৃত বালতিটির বিষয়বস্তু তালিকাভুক্ত করতে ক্লাউড শেল-এ নিম্নলিখিত কমান্ডটি চালান:
আদেশ
gcloud storage ls --recursive gs://live-streaming-storage-$LOGNAME/**
আউটপুট উদাহরণ
gs://live-streaming-storage-$LOGNAME/ gs://live-streaming-storage-$LOGNAME/main.m3u8 gs://live-streaming-storage-$LOGNAME/mux_video_ts/index-1.m3u8 gs://live-streaming-storage-$LOGNAME/mux_video_ts/segment-0000000016.ts gs://live-streaming-storage-$LOGNAME/mux_video_ts/segment-0000000017.ts gs://live-streaming-storage-$LOGNAME/mux_video_ts/segment-0000000018.ts gs://live-streaming-storage-$LOGNAME/mux_video_ts/segment-0000000019.ts gs://live-streaming-storage-$LOGNAME/mux_video_ts/segment-0000000020.ts gs://live-streaming-storage-$LOGNAME/mux_video_ts/segment-0000000021.ts gs://live-streaming-storage-$LOGNAME/mux_video_ts/segment-0000000022.ts ...
আপনি দেখতে হবে:
- HLS ম্যানিফেস্ট ফাইল:
main.m3u8 - সংশ্লিষ্ট TS ভিডিও সেগমেন্ট: সংখ্যাযুক্ত ফাইলের একটি সিরিজ
segment-000000000X.ts
এই মুহুর্তে আমরা নিম্নলিখিতগুলির সাথে সম্পন্ন করেছি:
- লাইভ স্ট্রিমিং এপিআই: লাইভ স্ট্রিমিং এপিআই-এর মাধ্যমে লাইভ সিগন্যাল তৈরি হয় এবং একটি বালতিতে ট্রান্সকোড করা হয়
- মিডিয়া CDN: মিডিয়া CDN এর উত্স হিসাবে লাইভ স্ট্রিমিং স্টোরেজ বাকেট সহ কনফিগার করা মিডিয়া CDN।
পরবর্তী বিভাগগুলিতে, আমরা এজ ক্যাশে পরিষেবাটি যাচাই করব এবং তারপরে আমরা মিডিয়া CDN যেকোনওকাস্ট আইপি ঠিকানা ব্যবহার করে ট্রান্সকোড করা ভিডিওটি স্ট্রিম করব।
15. যাচাই করুন যে এজ ক্যাশে সার্ভিস ইনস্ট্যান্স কাজ করে
এই বিভাগে আমরা যাচাই করব যে এজ ক্যাশে পরিষেবা দৃষ্টান্ত প্রত্যাশিত হিসাবে কাজ করে। এটি করার জন্য, আমরা এজ ক্যাশে পরিষেবা পরিষেবার আইপি ঠিকানা ব্যবহার করে এজ ক্যাশে পরিষেবা উদাহরণ থেকে একটি ফাইল অ্যাক্সেস করার চেষ্টা করব৷ প্রথমবার একটি বস্তু অ্যাক্সেস করা হয়, এটি এখনও ক্যাশে করা হয় না. আমরা একটি ক্যাশে MISS পালন করা উচিত. প্রথম অনুরোধের জন্য, বস্তুটি মূল থেকে পড়া হয় এবং প্রান্তে ক্যাশে করা হয়। একই ফাইল অ্যাক্সেস করার জন্য নিম্নলিখিত সমস্ত প্রচেষ্টা, একটি ক্যাশে HIT ফেরত দেবে যেহেতু অবজেক্টটি এখন প্রান্তে ক্যাশে করা হয়েছে। আসুন এই আচরণটি যাচাই করি:
এজ ক্যাশে অরিজিনে সংরক্ষিত ট্রান্সকোড করা ভিডিও ম্যানিফেস্ট ফাইল অ্যাক্সেস করতে ক্লাউড শেলে নিম্নলিখিত curl কমান্ডটি চালান:
আদেশ
curl -svo /dev/null --resolve demo.cme.com:80:<Replace_With_Edge_Cache_IP> \ "http://demo.cme.com/main.m3u8"
সমাধানের দিকে লক্ষ্য করুন যেখানে আমরা এজ ক্যাশে সার্ভিস ইনস্ট্যান্সের আইপি অ্যাড্রেস ব্যবহার করে এর নাম সমাধান করি। আপনি demo.cme.com:<IP> যেখানে IP হল এজ ক্যাশে পরিষেবার আইপি যা আমরা এইমাত্র তৈরি করেছি।
আউটপুটে x-cache-status হেডারটি দেখুন।
আউটপুট উদাহরণ
Added demo.cme.com:80:34.104.35.152 to DNS cache
* Hostname demo.cme.com was found in DNS cache
* Trying 34.104.35.152:80...
* Connected to demo.cme.com (34.104.35.152) port 80 (#0)
> GET /main.m3u8 HTTP/1.1
> Host: demo.cme.com
> User-Agent: curl/7.74.0
> Accept: */*
>
* Mark bundle as not supporting multiuse
< HTTP/1.1 200 OK
< x-guploader-uploadid: ADPycdtKtflWt4Kha5YxXNNRwO-Eu6fGSPs-T-XY4HJmNMo46VJyWlD4EAk-8a6SegxjWq3o1gTPqZbpkU_sjW__HPAdDw
< date: Wed, 07 Dec 2022 18:23:46 GMT
< last-modified: Wed, 07 Dec 2022 18:23:45 GMT
< etag: "6bff620ccca4a9849ba4e17fa7c521fb"
< x-goog-generation: 1670437425805400
< x-goog-metageneration: 1
< x-goog-stored-content-encoding: identity
< x-goog-stored-content-length: 193
< content-type: application/x-mpegURL
< x-goog-hash: crc32c=sPO3zw==
< x-goog-hash: md5=a/9iDMykqYSbpOF/p8Uh+w==
< x-goog-storage-class: STANDARD
< accept-ranges: bytes
< content-length: 193
< server: Google-Edge-Cache
< x-request-id: fd25285b-fc1a-4fd4-981a-c50ead2c85ed
< x-xss-protection: 0
< x-frame-options: SAMEORIGIN
< x-cache-status: den;miss
< cache-control: public,max-age=3600
<
{ [193 bytes data]
* Connection #0 to host demo.cme.com left intact
ক্যাশে মিস লক্ষ্য করুন কারণ অবজেক্টটি এখনও ক্যাশে করা হয়নি এবং মূল থেকে পড়া হয়েছে।
এখন আমরা m3u8 ফাইলের জন্য একাধিক অনুরোধ করব, এবং সবকিছু সঠিকভাবে কনফিগার করা থাকলে, মিডিয়া CDN এর ক্যাশে থেকে বিষয়বস্তু পরিবেশন করা শুরু করা উচিত। নীচের কমান্ডটি 10টি কার্ল অনুরোধ করবে এবং শুধুমাত্র x-cache-status হেডার প্রিন্ট করবে।
আদেশ
for i in {1..10};do curl -Is --resolve demo.cme.com:80:<Replace_With_Edge_Cache_IP> "http://demo.cme.com/main.m3u8" | grep x-cache-status;done
আউটপুট ক্যাশে hit এবং miss এর মিশ্রণ হওয়া উচিত। আপনি যদি আউটপুটে ক্যাশে হিট দেখতে পান, তাহলে মিডিয়া CDN প্রত্যাশা অনুযায়ী কাজ করছে।
আউটপুট উদাহরণ
x-cache-status: den;miss x-cache-status: den;hit x-cache-status: den;hit x-cache-status: den;hit x-cache-status: den;hit x-cache-status: den;hit x-cache-status: den;hit x-cache-status: den;hit x-cache-status: den;hit x-cache-status: den;hit
ক্যাশে হিট লক্ষ্য করুন যেহেতু বস্তুটি এখন প্রান্তে ক্যাশে করা হয়েছে। ক্লাউড মেডি এজ সার্ভিস প্রত্যাশিতভাবে কাজ করছে।
16. ভিএলসি দিয়ে ট্রান্সকোড করা লাইভ সিগন্যাল ভিডিও স্ট্রিম করুন
এটি সেই অংশ যেখানে আমরা বিন্দুগুলিকে সংযুক্ত করি এবং আমরা এখন পর্যন্ত যে সমস্ত ধাপে কাজ করছি তা লিঙ্ক করি:
- আমরা
live-streaming-storage-$LOGNAMEনামে একটি বালতি তৈরি করেছি যা লাইভ স্ট্রিমিং API দ্বারা HLS সামগ্রীতে ট্রান্সকোড করা লাইভ সিগন্যালের ফলাফল পায়৷ - আমরা লাইভ স্ট্রিমিং API সেট আপ করেছি।
- আমরা FFmpeg এর সাথে একটি RTMP লাইভ সিগন্যাল শুরু করেছি যা লাইভ স্ট্রিমিং API ইনপুট/চ্যানেল ফিড করে।
- আমরা যাচাই করেছি যে চ্যানেলে লাইভ সিগন্যাল দেওয়া হয়েছে এবং চ্যানেলটি
streamingমোডে আছে কিনা তা যাচাই করেছি। - আমরা যাচাই করেছি যে ফলস্বরূপ ট্রান্সকোড করা ফাইলগুলি (মেনিফেস্ট + TS সেগমেন্টগুলি) বালতি
live-streaming-storage-$LOGNAMEএ তৈরি এবং সংরক্ষণ করা হয়েছে। -
cme-originনামক একটি এজ ক্যাশে অরিজিন সেট আপ করা হয়েছিল GCS বাকেটlive-streaming-storage-$LOGNAMEএর সাথে। -
cme-demoনামক একটি এজ ক্যাশে দৃষ্টান্তcme-originএর মূল হিসাবে সেট আপ করা হয়েছিল। - আমরা এজ ক্যাশে সার্ভিস ইনস্ট্যান্সের আচরণ (ক্যাশে মিস, ক্যাশে হিট) যাচাই করেছি।
আমরা এখন এমন এক পর্যায়ে আছি যেখানে আমরা মিডিয়া CDN ক্যাশের মাধ্যমে ট্রান্সকোড করা লাইভ সিগন্যাল স্ট্রিম করতে একটি ভিডিও প্লেয়ার ব্যবহার করতে পারি। এটি করার জন্য আমরা ভিএলসি প্লেয়ার ব্যবহার করব। ভিএলসি প্লেয়ার হল একটি ফ্রি এবং ওপেন সোর্স ক্রস-প্ল্যাটফর্ম মাল্টিমিডিয়া প্লেয়ার এবং ফ্রেমওয়ার্ক যা বেশিরভাগ মাল্টিমিডিয়া ফাইল চালায়। এটি অভিযোজিত মিডিয়া ফর্ম্যাটগুলি (যেমন DASH এবং HLS) চালায়। এটি অ্যাডাপটিভ স্ট্রিমিংয়ের নীতি ব্যবহার করে - আপনার নেটওয়ার্ক সংযোগের গুণমান এবং উপলব্ধ ব্যান্ডউইথ অনুযায়ী, প্লেয়ার প্লে করা ভিডিওর গুণমানকে মানিয়ে নেবে৷ আমরা এইমাত্র ট্রান্সকোডিং কাজটি করেছি, আমরা ডিফল্ট প্রিসেট ব্যবহার করেছি এবং "শুধুমাত্র" দুটি গুণ তৈরি করেছি: SD এবং HD। আমরা প্লেয়ারে ভিডিও চালানো শুরু করার সাথে সাথে আপনি দেখতে পাবেন এটি SD ফর্ম্যাটে বাজানো শুরু করে এবং আপনার নেটওয়ার্ক সংযোগ যথেষ্ট ভাল হলে দ্রুত HD ফর্ম্যাটে স্যুইচ করুন৷
আমরা HLS (ব্যাপকভাবে সমর্থিত অ্যাপল ভিডিও ফরম্যাট) ট্রান্সকোডেড লাইভ সিগন্যাল স্ট্রিম করব। সংশ্লিষ্ট ফাইলটিকে বলা হয় main.m3u8 - যা HLS ম্যানিফেস্ট। ম্যানিফেস্ট TS ভিডিও সেগমেন্টের দিকে নির্দেশ করে।
ভিএলসি প্লেয়ার ব্যবহার করতে, https://www.videolan.org/vlc/ এ যান এবং আপনার ল্যাপটপ অপারেটিং সিস্টেমের জন্য প্লেয়ারটির একটি সংস্করণ ডাউনলোড করুন - ভিএলসি উইন্ডোজ, ম্যাকওএসএক্স, লিনাক্স, অ্যান্ড্রয়েড এবং আইওএসের জন্য উপলব্ধ।

আপনার ল্যাপটপে প্লেয়ারটি ইনস্টল করুন এবং এটি চালু করুন। আমরা পরবর্তী কয়েকটি ধাপের জন্য প্লেয়ারের MacOSX সংস্করণ ব্যবহার করব।
একটি ভিডিও চালানোর জন্য, "ফাইল" / "ওপেন নেটওয়ার্ক" এ যান:

এটি দিয়ে সেট আপ করুন:
- URL: http://<Replace_With_Edge_Cache_IP>/main.m3u8 । এটি সেই ভিডিওটির URL যা আমরা স্ট্রিম করতে চাই৷ বিজ্ঞপ্তি:
- মিডিয়া সিডিএন ইনস্ট্যান্সের আইপি:
34.105.35.246। আপনি যে ক্লাউড মিডিয়া পরিষেবাটি স্থাপন করেছেন তার IP দিয়ে প্রতিস্থাপন করুন৷ - ম্যানিফেস্ট ভিডিও ফাইলের পথ: "
/"। ট্রান্সকোড করা লাইভ সিগন্যাল ফাইলগুলি সঞ্চয় করার জন্য আমরাlive-streaming-storage-$LOGNAMEবাকেট-এ এই পথটি ব্যবহার করেছি। পথটি এখানে মূল পথ: "/"। - ম্যানিফেস্ট ভিডিও ফাইলের নাম: HLS ম্যানিফেস্ট ফাইল,
main.m3u8।
এবং "খুলুন" ক্লিক করুন। আপনার ট্রান্সকোড করা লাইভ ভিডিওটি প্লে হতে দেখা উচিত। ভিডিওটি নিচের স্ক্রিনশটের মত দেখাবে। কাউন্টার অন-স্ক্রীন 1 বৃদ্ধিতে চলবে এবং আপনি একটি অবিচ্ছিন্ন বীপ শুনতে সক্ষম হবেন।
এটি একটি মৌলিক RTMP পরীক্ষা লাইভ সিগন্যাল যা FFmpeg দ্বারা উত্পন্ন হয়, লাইভ স্ট্রিমিং API দ্বারা HLS এ ট্রান্সকোড করা হয় এবং মিডিয়া CDN ক্যাশের মাধ্যমে পরিবেশিত হয়:

আপনি যদি তা করতে চান তাহলে আপনি অন্য যেকোনো HLS এবং MPEG DASH প্লেয়ার ব্যবহার করতে পারেন। এখানে কিছু আপনি বিবেচনা করতে চাইতে পারেন:
- কুইকটাইম প্লেয়ার - Macs-এ ডিফল্টরূপে ইনস্টল করা হয়। এখানেও একই: http://34.104.36.157/main.m3u8- এ একটি নেটওয়ার্ক সংযোগ খুলুন - আপনার এজ ক্যাশে পরিষেবার একটি উদাহরণ দিয়ে IP ঠিকানাটি প্রতিস্থাপন করুন।
17. মিডিয়া CDN মনিটরিং
একটি মিডিয়া CDN ড্যাশবোর্ড টেমপ্লেট SME টিম তৈরি করেছে - https://gist.github.com/elithrar/1c511d00f5cd3736fb2a3897867209c1 ।
এটি ইনস্টল করতে, ক্লাউড শেল উইন্ডোতে নিম্নলিখিত কমান্ডগুলি চালান:
YAML ফাইল ডাউনলোড করুন:
curl https://gist.githubusercontent.com/elithrar/1c511d00f5cd3736fb2a3897867209c1/raw/3cb70855304f29e5c06b8d63063196354db0dec3/media-edge-20210208-dashboard --output media-edge-20210208-dashboard.yaml
ক্লাউড মনিটরিংয়ের জন্য ড্যাশবোর্ড তৈরি করুন:
gcloud monitoring dashboards create --config-from-file media-edge-20210208-dashboard.yaml
সেট আপ হতে কয়েক মিনিট সময় লাগতে পারে। Google ক্লাউড কনসোলে যান এবং 3 বার > অপারেশন > মনিটরিং > ড্যাশবোর্ডে ক্লিক করুন। আপনি "মিডিয়া এজ মেট্রিক্স" নামে একটি ড্যাশবোর্ড দেখতে পাবেন। এটিতে ক্লিক করুন এবং আপনি মেট্রিক্স দেখতে পাবেন:

18. ল্যাব পরিবেশ পরিষ্কার করুন
ল্যাব সম্পূর্ণ করার জন্য অভিনন্দন। এই বিভাগে আমরা ল্যাব জুড়ে তৈরি করা সমস্ত সংস্থান মুছে ফেলব।
FFmpeg সংকেত বন্ধ করুন:
ক্লাউড শেল টার্মিনালে <CTRL+C> টিপুন যেখানে FFmpeg চলছে।
লাইভ স্ট্রিমিং চ্যানেল বন্ধ করুন:
আদেশ
curl -X POST \ -H "Authorization: Bearer "$(gcloud auth application-default print-access-token) \ -H "Content-Type: application/json; charset=utf-8" \ -d "" \ "https://livestream.googleapis.com/v1/projects/$PROJECT_NUMBER/locations/$LOCATION/channels/$CHANNEL_ID:stop"
লাইভ স্ট্রিমিং চ্যানেল মুছুন:
আদেশ
curl -X DELETE -H "Authorization: Bearer "$(gcloud auth application-default print-access-token) "https://livestream.googleapis.com/v1/projects/$PROJECT_NUMBER/locations/$LOCATION/channels/$CHANNEL_ID"
লাইভ স্ট্রিমিং ইনপুট এন্ডপয়েন্ট মুছুন:
আদেশ
curl -X DELETE \ -H "Authorization: Bearer "$(gcloud auth application-default print-access-token) \ "https://livestream.googleapis.com/v1/projects/$PROJECT_NUMBER/locations/$LOCATION/inputs/$INPUT_ID"
GCS বালতি মুছুন:
আদেশ
gsutil rm -r gs://live-streaming-storage-$LOGNAME
এজ ক্যাশে পরিষেবা দৃষ্টান্ত মুছুন:
আদেশ
gcloud edge-cache services delete cme-demo
অনুরোধ করা হলে "Y" লিখে মুছে ফেলা নিশ্চিত করুন
এজ ক্যাশে মূল মুছুন:
আদেশ
gcloud edge-cache origins delete cme-origin
অনুরোধ করা হলে "Y" লিখে মুছে ফেলা নিশ্চিত করুন
কাস্টম ড্যাশবোর্ড মুছুন
আদেশ
gcloud monitoring dashboards delete $(gcloud monitoring dashboards list --filter="displayName:Media Edge Metrics" --format="value(name)")