Subscribe Twitter

Wednesday, August 18, 2010

මොනවද මේ Web Servers

වෙබ් ‍සර්වර් එකක් කියන්නේ සරලවම කිව්වොත්, සේවාදායකයන්(Clients) හට වෙබ් පිටු ලබා දෙන වැඩසටහනක්. මේ වෙබ් ‍සර්වර් පරිගණකයක් ඇතුළේ වෙබ් අඩවියක් හෝ කීපයක් තියෙන්න පුළුවන්. අන්තර්ජාලය ඔස්සේ මෙවැනි ‍වෙබ් පිටු සේවාදායකයන් හට ලබාදීම සඳහා HTTP නැතහොත් Hyper Text Transfer Protocol නැමති ‍ප්‍රොටෝකෝලය භාවිතා වෙනවා.

සාමාන්‍ය කුඩා ප්‍රමාණයේ වෙබ් අඩවි ස්ථාපනය(Host) කිරීම සඳහා  හවුල්(Shared) වෙබ් සර්වරස් භාවිතා වෙනවා. ඒ කියන්නේ එක වෙබ් සර්වර් එකක් තුළ වෙබ් අඩවි කිහිපයක් තැන්පත් කිරීමයි. මේ සඳහා Virtual Hosting නැමති ක්‍රමය භාවිතා වෙනවා. මෙහි ද ප්‍රචලිත උපක්‍රම දෙකක් තිබෙනවා.
  • Name Based Virtual Hosting
    මෙම ක්‍රමයේදී සිදුවන්නේ එක් Server පරිගණකයක විවිධ ‍ඩොමෙයින් නාම(Domain Name) සහිත වෙබ් අඩවි තැන්පත් කිරීමයි.
  • IP Based Virtual Hosting
    මෙම ක්‍රමයේදී  එක් Server පරිගණකයකට විවිධ IP Address සහිත වෙබ් අඩවි තැන්පත් කිරීමයි. මෙහිදී එකම පරිගණකය විවිධ IP Address සඳහා වෙබ් සේවාව සපයයි.
එනමුත් විශාල පරිමාණයේ වෙබ් අඩවි ස්ථාපනය කිරීම සඳහා වෙන්කරන ලද(Dedicated) Server පරිගණක භාවිතා කරනවා. ඒවාගේම ඒවායේ සර්වර් ධාරිතාව ඉතා අධික වන අතර අන්තරජාල සබඳතා වේගය(Bandwidth) ද අධික වෙනවා. මෙවැනි ‍අධික Traffic එකක් සහිත වෙබ් අඩවි සඳහා එක් ‍Server පරිගණකයක් පමණක් භාවිතා කිරීමෙන් එහි  ප්‍රොසෙසින් ධාරිතාව(Processing Power), මතක ධාරිතාව(Ram Capacity), දත්ත ගබඩා පරිශ්‍රීලන(Database Access) හැකියාව වැනි දෑ ඉක්මවා යාමෙන් සේවාදායකයන් සඳහා නිසි පරිදි සේවාව සැපයීම කළ නොහැකි විය හැකි අතරම එම වෙබ් අඩවිය අකර්මණ්‍ය(Down) විමේ අවදානම වැඩි වෙනවා.

එබැවින් එවැනි වෙබ් අඩවි පවත්වාගෙන යාමේදී තවත් කරුණු කිහිපයක් ගැන සලකා බලනවා.
  • උපරිම උපයෝජ්‍යතාව(High Availability)
    මෙහිදී වෙබ් සර්වරයේ  ක්‍රියාකාරීත්වය  ගැන විශේෂව සලකා බලනවා. සේවාදායකයන්ට එක දිගටම වෙබ් අඩවිය අකර්මණ්‍ය(Down) නොවී සේවාව ලබාදීම මෙහි අරමුණයි. මෙහිදී වෙබ් සර්වරස් කිහිපයක්, අන්තර්ජාල සබඳතා කිහිපයක් යොදා ගනිමින් එකක් අඩාල වුවහෙත් අනෙක ස්වයංක්‍රීයව හාවිතා වන පරිදි සකස් කර තියෙන්වා.
  • භාරය තුලනය(Load Balancing)
    මෙහිදී  මුළු කාර්යභාරය Server පරිගණක කිහිපයකට භාර දෙනවා. ‍මේ Server පරිගණක කිහිපයම එකවර ක්‍රියාත්මක වන අතර ලැ‍බෙන සේවාදායක ඉල්ලීම් (Requests) කිසියම් ඇල්ගොරිතමයකට අනුව මාරුවෙන් මාරුවට Server පරිගණක කිහිපයටම ලබාදෙනවා. ඒ නිසා එක් පරිගණකයකට ලැබෙන භාරය(Load) අඩු වීමෙන් ඒවා අකර්මණ්‍ය වීමේ අවදානම අඩු වෙනවා.
තවද වර්තමානයේ භාවිතා වන ඉහළම කාර්යක්ෂමතාවයක් සහිත වෙබ් සර්වර් තාක්ෂණය NGINX (‍මෙය කියවන්නේ ‘engine X’ ලෙසයි) ලෙස හැඳින්වෙනවා. ‍මෙම තාක්ෂණය සහිත වෙබ් සර්වරයකට දිනකට මිලියන 500 පමණ ඉල්ලීම්(Requests) ප්‍රමාණයකට වෙබ් පිටු ලබාදිය(Serve කල) හැකි යැයි පැවසෙනවා.

සාමාන්‍යයෙන් ඉතා විශාල ප්‍රමාණයේ වෙබ් අඩවි (Facebook,Google), ඒවාට ලැ‍බෙන ඉල්ලීම්(Requests) ප්‍රමාණය අධික නිසාම, තමන්ගේ වෙබ් අඩවිය වෙබ් ‍සර්වර්ස් ගණනාවකම තැන්පත් කර තබා ගන්නවා. එවිට ලැබෙන එක් ඉල්ලීමක්(Request) සඳහා පිළිතුරු සැපයීම සඳහා වෙබ් සර්වරස් ගණනාවක්ම තිබෙන බැවින් සේවාදායකයින්ට ඉහළ සේවාවක් ලබාදිය හැකි වෙනවා.

‍එහෙත් එයද ප්‍රමාණවත් නොවන අවස්ථාවන් වලදී, මෙම වෙබ් අඩවි ලෝකයේ ‍බොහෝ ස්ථාන වල ඇති මෙවැනි වෙබ් සර්වර් ගණනාවකකට ඇතුළත් කරනවා. එය  CDN හෙවත් Content Delivery Network එකකට වෙබ් අඩවි ඇතුළත් කිරීම ලෙස හැඳින්වෙනවා. මෙම CDN පහසුකම තුළින් සේවාදායකයන්ට තමාට ආසන්නයේම ඇති ඇති වෙබ් සර්වරයෙන් පිළිතුරු ලබා දෙන බැවින්, ඉතා විශිෂ්ඨ, වේගවත් සේවාවක් ලබා දීමට හැකි වෙනවා. ඒ වාගේම මේ තුළින් ඒ ඒ කලාපයේ වෙබ් ඉල්ලීම් සලකා බලා, ඒ ඒ කලාපයට සරිලන සේ වෙබ් සර්වර් පිහිටුවීමට ද එම ‍වෙබ් සේවා සපයන සමාගම් වලට හැකි වෙනවා.

මෙ සම්බන්ධව තවත් කියන්න ‍බොහෝ දේ තියනවා. ඒත් ගොඩක් අය වෙබ් සර්වර් වල කතා නොකරන පැත්තක් කථා කරන්න හිතුණු නිසයි මේ දේවල් ලිව්වේ. මීළඟ පෝස්ට් එකත් ඉක්මනටම ලබා දෙන්න බලාපොරොත්තු වෙනවා.

7 comments:

Anonymous said...

good

Anonymous said...

if u can please start to write about how to make UTP cables. what are the difficulties facing on. etc what are the best practice on cabling. i think those kind of ground level stuff is more use full for us.
Thanks You... and keep posting...

ගයන්ත said...

thanx..

vpsupun said...

ස්තූතියි කමෙන්ට්ස් වලට. ඉල්ලීම පරිදි UTP Cable ගැන පෝස්ට් එකක් ඉක්මනින්ම දාන්නම්.

Anonymous said...
This comment has been removed by a blog administrator.
Anonymous said...

Thanks very nice blog!

My web page: random rants blog
My web page :: Splitting My Thoughts into Two

oshan sachinthaka said...

goood

Post a Comment