ফুলস্ট্যাক মার্ন (MERN) ডেভেলপার ক্যারিয়ার গাইডলাইন

বর্তমান যুগে ফুলস্ট্যাক ওয়েব ডেভেলপমেন্ট একটি জনপ্রিয় ওয়েব ডেভেলপমেন্ট টেকনোলোজি। কিন্তু এই ফুলস্ট্যাক ডেভেলপমেন্ট আসলে কি তার কোন সঠিক ধারণা আমাদের অনেকেরই নেই। আজ আমি আপনাদের বল্ব এই ফুলস্ট্যাক ডেভেলপমেন্ট আসলে কি এবং কীভাবে আমরা এই ফুলস্ট্যাক ওয়েব ডেভেলপমেন্ট শিখতে পারি।

ফুলস্ট্যাক ওয়েব ডেভেলপমেন্ট আসলে কি?

আমরা তো সবাই ওয়েবসাইট দেখেছি তাই না? আমি যদি একদম সহজ ভাষায় বলি, যে ডেভেলপার একটা ওয়েবসাইটের এ টু জেড সব কাজ করে থাকেন তাদেরকে বলা হয় ফুলস্ট্যাক ডেভেলপার। তো বুঝতেই পারছেন একজন ডেভেলপারের কতোদিক মাথায় রাখতে হয়।
আমি চেষ্টা করবো এই আর্টিক্যালে একজন সফল ফুলস্ট্যাক ডেভেলপার হতে যা যা স্টেপ ফলো করা দরকার তা আপনাদের সামনে তুলে ধরতে।
ওয়েব ডেভেলপমেন্টকে সাধারণত ২টি ভাগে ভাগ করা হয়ঃ

১। ফ্রন্ট এন্ড
২। ব্যাক এন্ড

ফ্রন্ড এন্ডঃ

ফ্রন্ট এন্ড এ আমরা মূলত ইউজার যে ইন্টারফেজ দেখতে পায় সেই কাজ গুলো করে থাকি আপনি  একটি ওয়েব সাইটে ঢুকলে যা যা দেখতে পান তার সবই করা হয় ফ্রন্টএন্ড এর ভেতরে মানে একটি ওয়েবসাইটের ডিজাইনই হচ্ছে ফ্রন্ট এন্ডের কাজ।

ব্যাক এন্ডঃ

অপর দিকে ব্যাক এন্ডে থাকে সব লজিক্যাল কোড। অর্থাৎ আপনার ওয়েবসাইটে কোথায় কি কাজ হবে, কোন বাটনে ক্লিক করলে কোন লিঙ্কে নিয়ে যাবে এইসব থেকে শুরু করে যত বিজন্যাস লজিক আছে তার সবই থাকে এই ব্যাক এন্ড পার্ট এ।

একজন সফল ফুলস্ট্যাক ডেভেলপার হতে হলে আপনাকে এই ২টি পার্ট এই সমান ভাবে দক্ষ হতে হবে। একজন ফুলস্ট্যাক ডেভেলপার হিসেবে আপনার কাজ হবে সফল ভাবে একটি ওয়েবসাইট বিল্ড করতে শিখা।বর্তমানে ডেভেলপার ওয়ার্ল্ডে  বিভিন্ন টেকনোলোজি স্ট্যাক আছে ফুলস্ট্যাক ডেভেলপারের জন্য। শুরুতে আপনাকে ঠিক করতে হবে আপনি কোনটা শিখবেন এবং কেনো শিখবেন?

নিচের ইমেইজটি একটু লক্ষ্য করুনঃ

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

ল্যাংগুয়েজ তো ঠিক হয়ে গেলো, কিন্তু কোন স্ট্যাকে শিখবেন কাজ? MERN নাকি MEAN?

এই MERN আর MEAN আসলে কি?

MERN- MongoDB, Express.JS, React.JS, Node.JS - এই ৪টা টপিক নিয়ে আসলে বুঝায় MERN অপরদিকে

MEAN- MongoDB, Expree.JS, Angular.JS, Node.JS - এই ৪টা টপিক নিয়ে আসলে বুঝায় MEAN

অর্থাৎ ২টি টেক স্ট্যাক এর ভেতর পার্থক্য হচ্ছে রিএক্ট এবং এঙ্গুলারে। এই দুটি হচ্ছে জাভাস্ক্রিপ্টের ফ্রন্ট-এন্ড এর ফ্রেমওয়ার্ক/ লাইব্রেরী। এখন আপনাকে বুঝতে হবে আপনি কোনটা শিখবেন।

Angular vs React Image:

তো দেখতেই পাচ্ছেন ২টির ভেতরে অনেক পার্থক্য। কিন্তু পারফর্মেন্স এবং পপুলারিটির দিক বিবেচনা করলে রিএক্ট এঙ্গুলার থেকে অনেক এগিয়ে থাকবে। আপনি জব মার্কেটেও এখন অনেক রিএক্টের সার্কুলার দেখতে পাবেন। সুতরাং ২০২১ এ এসে রিএক্ট হবে সবচেয়ে উপযোগী একটি ফ্রন্ট এন্ড লাইব্রেরী।
তো আর কিছু না ভেবেই শুরু করে দিতে পারেন MERN স্ট্যাক ডেভেলপমেন্টের যাত্রা। কিন্তু শিখবেন কীভাবে?
কোনটা আসলে কি কাজ করে? আপনার এইসব প্রশ্নের উত্তর এবং সঠিক একটা গাইড লাইন দেয়ার চেষ্টা করবো এই ব্লগেই।

Pre-Requisite to start the journey as a MERN stack developer:

1. HTML
ওয়েব ডেভেলপমেন্টের শুরুতে অবশ্যই আপনাকে জানতে হবে HTML, HTML একটি মার্কআপ ল্যাংগুয়েজ যেখানে আমরা লিখে থাকি যে আমাদের ওয়েবসাইটের স্ট্রাকচারটা কীভাবে হবে। অর্থাৎ আমরা বলি যে একটা বাটন কোথায় থাকবে, ইমেইজ কোথায় থাকবে এসব। আপনারা এই HTML শিখতে খুব বেশী সময় লাগবে না। খুবই সহজ একটি জিনি.

2.CSS
HTML কে CSS দিয়েই ডিজাইন করা হয়। অর্থাৎ একটা ওয়েবসাইটের বাটন কি রঙের হবে, ফ্রন্ট সাইজ কি রঙের হবে এইসব আমরা লিখে থাকি CSS দিয়ে। CSS এর বেসিক জ্ঞান থাকলেই আপনি পারবেন একটা ওয়েবসাইট ডিজাইন করতে। HTML এবং CSS শেখার পর আপনার কাজ হবে ২-৩টা ওয়েবসাইট ডিজাইন করে ফেলা।যেমন-

১। পার্সোনাল পোর্টফোলিও
২। ব্লগ
৩। রেস্টরেন্ট ওয়েবসাইট ইত্যাদি

3.Bootstrap

আপনি HTML CSS দিয়ে অলরেডি যে ওয়েবসাইট ডিজাইন করেছেন, সেগুলো কিন্তু রেস্পনসিভ না। অর্থাৎ এই ওয়েবসাইটটা আপনার ডিভাইসে যেমন দেখাবে অন্য আরেকটি ডিভাইসে কিন্তু সেরকম দেখাবে না। পুরো ডিজাইনটাই সেখানে পরিবর্তন হয়ে যাবে এই সমস্যা সমাধান করতে আমরা ব্যবহার করবো বুটস্ট্রেপ। যা একটি CSS ফ্রেমওয়ার্ক। বুটস্ট্রেপের সাহায্যে আপনি খুব সহজেই একটি ওয়েবসাইটকে রেস্পন্সিভ করতে পারবেন। আপনাকে শুধু ব্যবহার করতে হবে বুটস্ট্রেপের ডিফাইন করা অল্প কিছু রুলস। বুটস্ট্রেপ শেখার পর আপনার কাজ হবে HTML এবং CSS দিয়ে যে ওয়েবসাইট গুলো ক্রিয়েট করেছিলেন সেগুলো বুটস্ট্রেপ দিয়ে রেস্পন্সিভ করা।

4.JavaScript

HTML, CSS, BootStrap এর পর আপনাকে শিখতে হবে জাভাস্ক্রিপ্ট। জাভাস্ক্রিপ্টটি আপনাকে খুব ভালোভাবে শিখতে হবে। কারণ দিন শেষে আপনি কিন্তু একজন জাভাস্ক্রিপ্ট ডেভেলপারই (MERN Stack). JS টা আপনার কাছে যত ক্লিয়ার হবে আপনি JS ডেভেলপার হিসেবে তত ভালো করতে পারবেন। আপনি JS যদি MDN ডকুমেন্টেশনটা পড়ে শিখতে পারেন তাহলে আপনি খুব উপকৃত হবেন।
কি কি শিখতে হবে JS এ?

• Basic JS Syntax+variable
• Operator
• If-Else
• Array
• String
• Function
• Loop
• Object
• JSON
• Class
• Asynchronous JS
• DOM


এই প্রতি টপিকের উপরে আপনার ভালো ধারণা থাকা লাগবে। চেষ্টা করবেন প্রত্যেকটা টপিকের উপরে যেন আপনার কন্সেপ্ট ক্লিয়ার থাকে। এই ৪টি টপিক আপনি ঠিক ভাবে শেখার পরই শুরু করতে পারবেন MERN স্ট্যাক ডেভেলপারের যাত্রা।

Start MERN stack development

MongoDB

আমরা যে ওয়েবসাইট  ক্রিয়েট করবো ডাটা অবশ্যই কোথাও না কোথাও সেইভ করে রাখতে হবে। এই ডাটা হতে পারে ইউজারের ইনফরমেশন, একটা প্রোডাক্টের ডিটেইলস অথবা যে কোনো কিছু।আর এর জন্যই আমরা ব্যবহার করবো MongoDB. MongoDB হচ্ছে একটি নন-রিলেশনাল ডাটাবেজ। বর্তমানের বহুল জনপ্রিয় এই ডাটাবেজটি ব্যবহার করা হয় mem স্ট্যাক ডেভেলপার স্ট্যাকে।

আপনার প্রথম কাজ হবে MongoDB এর সাহায্যে কীভাবে CURD অপারেশন চালাতে হয় সেটা শিখে ফেলা। অর্থাৎ Create-Update-Read-Delete এই চারটি। এই চারটি হচ্ছে বেসিক ডাটাবেজ অপারেশন যার যাহায্যে আপনি অনেক কিছুই করতে পারবেন।

এরপর আপনি শিখবেন একটু এডভান্স টপিক, যেমন-

  • Aggregate Function
  • Operators etc

আপনি MongoDB এর প্রতিটা কমান্ড শিখবেন mongo shell এ। তাহলে পরে MongoDB কে যেকোন ল্যাংগুয়েজ এর সাথেই ব্যবহার করতে পারবেন।

React

MongoDB এর পর চলে আসবেন ফ্রন্ট এন্ড টেকনোলোজিতে, অর্থাৎ রিএক্টে। রিএক্ট কে আমরা ব্যবহার করবো ফ্রন্ট এন্ড টেকনোলোজি হিসেবে। আমরা আগে যে HTML,CSS, BootStrap এবং JS শিখলাম তার সবকটাই লাগবে এই রিএক্টে। রিএক্টের সিনট্যাক্স হিসেবে ব্যবহার করা হয় JSX যা অনেকটা HTML এর মতো দেখতে কিন্তু HTML না।
রিএক্টে আপনার শিখতে হবে-

  • JSX
  • Rendering
  • Components
  • Props
  • State
  • Life cycle
  • Events
  • Conditional
  • Rendering
  • List and Keys
  • Forms
  • Composition VS Inheritance
  • Redux

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

Node.JS+Express.JS

আমাদের কিন্তু ফ্রন্ট এন্ড এবং ডাটাবেজ শিখা শেষ। এখন আমরা শিখবো ব্যাক এন্ড। অর্থাৎ যাকে বলা যেতে পারে একটি ওয়েবসাইটের মেরুদণ্ড। যার উপর একটি ওয়েবসাইট সম্পুর্ন দাঁড়িয়ে থাকে। আমরা ব্যাক এন্ডে ব্যবহার করছি Node.js এবং ফ্রেমওয়ার্ক হিসেবে ব্যবহার করবো Express.js।শুরুতেই আপনার কাজ হবে এটা জেনে ফেলা যে Node.Js কীভাবে কাজ করে। শিখে ফেলবেন কীভাবে Node দিয়ে একটা সার্ভার রান করতে হয়। আমরা যদি সিরিয়াল করে বলি-

  • Server Setup
  • Modules
  • HTTP req Handle/ Routing
  • File
  • URL
  • Database Handle
  • NPM

এই অল্প কটি টপিক জানলেই আপনি বুঝতে পারবেন যে কীভাবে Node.Js কাজ করে। এখন আপনি একটা জিনিস বুঝতে পারবেন যে ১-২টা ফিচারের কাজ যদি  র Node.Js এ করেন তাহলে তা মেন্টেইন করা অনেক কষ্টসাধ্য হয়ে যাচ্ছে।আর এই কাজটিকে একটি ফরমেটে নেয়ার ভালো উপায় হচ্ছে একটা ফ্রেমওয়ার্ক ব্যবহার করা। আমরা এইজন্য একটি ফ্রেমওয়ার্ক ব্যবহার করি Node.Js এর, যেটা হচ্ছে Express.Js।

Express.JS এ আপনি Node.JS এ যা শিখে আসছেন তাই শিখবেন কিন্তু এখন ফরমেটেড ওয়েতে। আপনি একটা কোড ছোট ছোট পার্টে লিখবেন যেন আপনার একটি বড় প্রোজেক্ট হ্যান্ডেল করতে সুবিধা হয়।

   Express Js Learning List:

  • Express Setup
  • Request
  • Response
  • GET/POST method
  • Routing
  • Cookies
  • Database Handle
  • Sessions
  • File Upload
  • Middleware
এইসব গুলো টপিক শেখার পরে আপনার কাজ হবে আপনি রিএক্ট দিয়ে যে যে প্রোজেক্ট গুলো করেছেন তার সবগুলোকে Express.JS এর মাধ্যমে ডায়মাইক করা। অর্থাৎ সম্পুর্ন একটি ওয়েবসাইট বিল্ড করবেন যার ফ্রন্ট এন্ড এ আছে React এবং ব্যাক এন্ডে থাকবে Node+Express+MongoDB.
আপনি যদি সফল ভাবে এই প্রতিটা ধাপ লক্ষ্য করে একটি ওয়েবসাইট বিল্ড করতে পারেন তাহলে আপনাকে MERN স্টেক ডেভেলপারের দুনিয়ায় স্বাগতম। আর এসব কিছু নিয়েই খুব অল্প দিনের মধ্যেই মার্ন স্ট্যাক ডেভেলপমেন্টের উপর সবচেয়ে এডভান্সড এবং রিয়েল লাইফ প্রোজেক্ট বেসড কোর্স নিয়ে আসতে যাচ্ছি ইন শাহ্‌ আল্লাহ্‌। 
 
 
 S.M Sabiul Hajjaj
Full Stack Developer (MERN)

Related Articles

পাইথন এবং জ্যাঙ্গো – ফুলস্ট্যাক ওয়েব ডেভেলপার ক্যারিয়ার গাইডলাইন

পাইথন ফুলস্ট্যাক ওয়েব ডেভেলপমেন্ট গাইডলাইন বর্তমান যুগে ফুলস্ট্যাক ওয়েব ডেভেলপমেন্ট খুবই জনপ্রিয় একটি টপিক । কিন্তু এই ফুলস্ট্যাক ডেভেলপমেন্ট আসলে কি তার কোন সঠিক ধারনা…

সি প্রোগ্রামিং দিয়েই শুরু হোক প্রোগ্রামিং ক্যারিয়ার

একদম বিগিনিং লেভেল এ যদি আপনি কারোর কাছে প্রোগ্রামিং শিখার জন্য পরামর্শ চান তাহলে হয়ত এই কথাটায় সবচেয়ে বেশী শুনে থাকবেন যে, “ সি প্রোগ্রামিং…

Responses

Your email address will not be published. Required fields are marked *

  1. Nice Article. Onek informative. Course ta kobe nagad pabo abong price kemon hobe kindly jante parke upokrito hobo.

  2. Thanks vaia for giving me such an opportunity to learn C Programming