هر چند وقت یکبار، فناوريهای جدیدی ظاهر ميشوند که شما را به شدت تحتتأثیر قرار ميدهند.
در این مواقع معمولاً فکر ميکنید چنین چیزی باید زودتر معرفی ميشد و حال که معرفی شده، گامی مهم و سرآغاز تحولاتی شگرف خواهد بود.
آخرین باری که این اتفاق برای من افتاد، زمانی بود که درباره پروژهای بهنام Node.JS یا Node (همانطور که باینری آن با این نام خوانده ميشود) کنجکاوی کردم و به کسب اطلاعات پرداختم.
اگر یک توسعهدهنده وب هستید و بهویژه اگر با جاوا اسکریپت سروکار دارید، باید نود را بهشدت جدی گرفته و اخبار توسعه آن را پیگیری کنید.
با اینکه کمتر از دو سال از معرفی این پلتفرم ميگذرد، توجه بسیاری از کاربران را به خود جلب کرده و ابزارهای بسیاری براساس آن یا برای آن توسعه داده شده است.
پلتفرم نود، یک گام بسیار بزرگ و تأثیرگذار به عقب (زمانی که نت اسکیپ به معرفی جاوا اسکریپت سمت سرور پرداخت) است که آینده را به شدت متحول خواهد کرد.
Node.js چیست: بازگشت به جاوا اسکریپت
نود، یک سیستم نرمافزاری است که برای نوشتن برنامههاي اینترنتی (بهخصوص وب سرورهای جدید و پیشرفته) با توجه ویژه به قابلیت مقیاس پذیری بالا توسعهداده شده است.
در این پلتفرم، برنامهها با زبان جاوا اسکریپت نوشته ميشوند که در آن، با استفاده از سیستم ورودی/خروجی ناهمزمان (Asynchronous) و رویداد محور، سعی در کاهش سربار و افزایش مقیاس پذیری پلتفرم شده است.
این پلتفرم در ابتدا توسط رايان داهل (Ryan Dahl) در سال ۲۰۰۹ نوشته شد و رشد و توسعه آن مرهون پشتیبانی Joynet، شرکت متبوع رایان داهل است.
این پلتفرم با استفاده از زبان C و همچنین خود جاوا اسکریپت نوشتهشده و حاوی موتور جاوا اسکریپت V۸ گوگل کروم و سیستم ماجولی Common JS به همراه برخی دیگر از کتابخانههاي دیگر است و برخلاف آنچه تاکنون مرسوم بود، نه روي مرورگر که در سمت سرور اجرا میشود.
با استفاده از این پلتفرم، به سادگی ميتوان وبسرورهای همزمان (Concurrent) بسیاری ایجاد کرد تا عملیات ورودی و خروجی را به روشی پر بازده (که با نام روش non-blocking شناخته ميشود) مدیریت کرد.
چنین امکاناتی برای TCP، DNS و HTTP در این پلتفرم درنظر گرفتهشده است.
این پلتفرم به طور کامل حاوی API جاوا اسکریپت بوده و همچنين، بخشهاي اضافهاي را نیز برای انجام عملیاتهایی مانند کار با سیستمفایلي ارائه ميکند.
توجه داشته باشید که Node.js باید بهصورت جدا دانلود شده و پس از کامپایل در سرور مورد نظر، برای اجرای کدهای جاوااسکریپت مورد استفاده قرار گیرد
چرا پلتفرم نود مهم است؟
با اینکه تاکنون پلتفرمهاي مشابهی با زبانهاي مختلف در این زمینه معرفی شدهاند، اهمیت Node.js در این است که رایان داهل و همکاران وی با استفاده از جاوا اسکريپت چنین پلتفرم سمت سروری را تولید کردهاند که بیاغراق، مورد استفاده تمام توسعهدهندگان وب تاکنون بوده است زيرا همه آنها برای انجام امور سمت کلاینت باید از جاوا اسکریپت استفاده ميکردند و معرفی نود باعث شد تا بسیاری به این فکر بیفتند که دیگر به زبان سمت سرور اختصاصی خود نیاز نداشته و با استفاده از جاوا اسکریپت، بسیاری از دردسرها کاهش خواهد یافت.
از طرف دیگر، پارادایم خاص جاوا اسکریپت برای کار با Callbackها و انجام امور ورودی/خروجی بهصورت non-blocking نیز در توجه توسعهدهندگان و گرایش بسیاری به سمت آن تأثیر بهسزایی داشته است.
برای روشنشدن میزان سودمندی نود، مثالي ذکر ميکنيم.
تصور کنید در یک سایت اینترنتی، هزاران کاربر با واردکردن URL سایت وارد آن شده و بسیاری دیگر، درخواستهاي AJAX بی شماری به وب سرور سایت مذکور ارسال ميکنند.
در این شرایط، هر درخواست یک رشته یا thread جدید در برنامه وب سرور مورد استفاده (که عموماً آپاچی خواهد بود) ایجاد کرده تا اسکریپتی را، براي نمونه PHP که به احتمال، حاوی پرسوجو از پایگاهداده یا چیزی شبیه به آن است، اجرا کند و نتیجه این اجرا را برای مرورگر درخواستکننده ارسال کند.
در این کاربرد دو مفهوم اصلی از اهمیت ویژهاي برخوردار هستند: یکی حافظه و دیگری ورودی/خروجی بلوکهکننده. زيرا هر thread اجرایی، حافظه بسیار زیادی را اشغالکرده و تعدد کاربران، امکان پرشدن حافظه سیستم و از کار افتادن خدمات مربوط را پیشميآورد.
همچنين، هر کدام از این رشتههاي پردازشی به عملیات ورودی/خروجی مانند دسترسی به پایگاهداده نیاز دارند که هرکدام به زمانی مشخص برای تکمیلشدن نیازمند است.
در بيشتر موارد نیز به دلیل بزرگبودن جدولهاي دادهاي و نتایج پرسوجوهای انجام شده، اسکریپت اجراکننده مجبور است تا بازگردانی دادهها از طرف پایگاهداده منتظرمانده و پس از دریافت، به اجرای بقیه دستورها بپردازد.
به همین دلیل، این عملیات، عملیات ورودی/خروجی بلوکه کننده نامیده ميشود و تأثیری بسیار منفی روی عملکرد کلی سرور خواهد داشت. نکته منفی این رویداد علاوه بر انتظار اسکریپت برای بازگردانی دادههاي درخواست شده، مصرف توانپردازشی و حافظه درحین انتظار است که در صورتی که در مقیاس بالا اتفاق بیفتد، باعث ناکارآمدی کلی سیستم خواهد شد.
حال اگر راهی باشد که بتوان این رشتههاي پردازشی را حذف کرده و همه را در یک انباره بزرگ قرار داد، مشکل مصرف حافظه برطرف خواهد شد.
همچنين، در صورتی که بتوان تا زمانی که برای بازگردانی نتایج ورودی/خروجی (پرسوجو از پایگاهداده) منتظر هستیم، به انجام امور دیگر در اسکریپت خود بپردازیم مشکل بلوکه شدن نیز حذف شده و سرعت عملکرد به طور قابل توجهی افزایش خواهد یافت.
این دو مورد دقیقاً کارهایی است که Node.js به انجام آنها مبادرت ورزیده و به همین دلیل، اهميت بالایی در آینده برنامههاي کاربردی وب خواهد داشت.
یک سرور مبتنی بر Node.js، تمام اتصالهاي ورودی را در یک انباره مدیریت کرده و فریمورک پس زمینه نود، ميتواند حالات و شرایط این اتصالها را مدیریت کرده و براي نمونه، یک اتصال را به حالت «در حال انتظار» تبدیل کند.
همچنين، در پلتفرم نود از پارادیم حلقه رویداد و Callback برای انجام امور پرسوجو از پایگاه داده استفاده شده است تا انتظار برای پاسخ از پایگاه داده، منابع ارزشمند سیستم را بلوکه نکند.
در این حالت، فرآیند Callback به دادههاي بازگشتی از پایگاهداده تخصیص داده شده وهمزمان، نود به انجام امور دیگر ميپردازد که خود از هدر رفتن سیکلهای CPU بیشتری جلوگیری ميکند.
با استفاده از این روش، مرورگر سمت کلاینت تا فراهمشدن نتایج در حالت انتظار باقیميماند و با حالت درخواست دادهها از سرور threaded سنتی، هیچ تفاوتی احساس نمیکند.
پس از آماده شدن نتایج پرسوجو از پایگاهداده، کد مشخص شده بهعنوان Callback اجرا شده، اتصال مربوط را از انباره انتخابکرده و حالت آن را از وضعیت «درحال انتظار» خارج کرده و با استفاده از آن، دادههاي لازم را به مرورگر ارسال میکند. استفاده از چنین ساختاری علاوه بر کاهش مصرف حافظه، سرعت اجرای بالایی را نیز به ارمغان ميآورد.
همانطور که ميدانید، برنامههاي تحت وب امروزی که بر مبنای AJAX کار ميکنند، بار کاری سنگینی را به سرورهای خود تحمیل ميکنند.
در صورتی که به برنامههاي گفتوگو یا بازیهاي تحت مرورگر چند بازیکنی توجه کنیم، متوجه خواهیم شد که آنها اتصالهاي همزمان بسیاری را ایجاد ميکنند که زمان کم پاسخگویی به هر کدام از آنها بسیار مهم و حیاتی است.
در چنین کاربردهایی است که قوت Node.js مشخص شده و روش مورد استفاده آن برای مدیریت امور بسیار پر اهمیتتر از گذشته بهنظر ميآید.
اگرچه تلاشهاي انجام شده برای استفاده از AJAX و Comet برای بهترکردن تجربه وب بسیار ارزنده بوده و سوکتهاي HTML5 نیز تلاش قابل تقدیری برای توسعه و ایجاد سهولت در پاسخ به این نیازمندیها بودند، اما تکمیلکننده این حلقه، استفاده از فناوريهاي جدید در سمت سرور بود که با معرفی و توسعه روزافزون Node.js به خوبی در حال شکلگیری است.
در هر صورت، برای مقبولیت و گسترش روزافزون Node.js به اندکی زمان نیاز است تا توسعهدهندگانی که در چند سال اخیر و تاکنون بر مبنای پارادایمهاي سنتی AJAX به توسعه کد ميپرداختند، با روش جدید تطبیق پیدا کرده و به سوی آن گرایش پیدا کنند.
زمانی که سایتهاي معروف و برنامههاي وب مبتنی بر AJAX هر کدام سرور اختصاصی خود را داشته باشند، چندان دور نیست.
در صورتی که تجربه کار با AJAX، COMET یا جاوااسکریپت را داشتهاید، تجربه کار با Node.js را از دست ندهید.
مطمئن باشید که پس از آن، هیچ علاقهاي برای بازگشت به استفاده از PHP نخواهید داشت.
Node.js در یک نگاه
توسعه وب با استفاده از یک زبان داینامیک (جاوااسکریپت) که روي یک ماشین مجازی خیلی سریع با نام V۸ اجرا ميشود.
سرعت اجرای آن از Ruby ،Python و Perl بسیار بیشتر است. توانایی مدیریتکردن هزاران اتصال همزمان، با کمترین سربار و با استفاده از یک نرمافزار.
شایستگی ذاتی جاوااسکریپت در کار با event loopها با داشتن اشیاي درجه یک، قابل استفاده در توابع و همچنین نحوه بستنآنها که سالها توسط برنامهنویسان مختلف روي مرورگرها تمرین شده است.
تعدد افرادی که برنامهنویسی با استفاده از جاوااسکریپت را ميدانند یا در آن حرفهاي هستند. به جرأت ميتوان جاوااسکریپت را محبوبترین زبان برنامهنویسی حال حاضر دانست.
استفاده از جاوااسکریپت در سمت سرور به همراه استفاده از آن در سمت کلاینت، احتمال ناهمخوانی و بروز مشکلات و معضلات محیطهای ناهمگون برنامهنویسی را کاهشداده و امکان برقراری ارتباط دادهاي با استفاده از JSON میان هر دو طرف را فراهم ميسازد. استفاده از یک کد اعتبارسنجی فرم چه در سمت سرور و چه در سمت کلاینت واقعاً لذتبخش است.
مزایا
- مقیاسپذیر به هزاران اتصال فعال
- بسیار سریع (به خصوص در مقایسه با PHP و Ruby)
- امنیت بیشتر در مقابل بار اضافی اعمال شده به سرور (به خصوص در زمان وقوع حملههاي DDOS که بقیه نرمافزارهاي سرور مانند SSH قابل دسترسی و پاسخ دهنده باقی ميمانند)
- پارادایم ناهمزمان بسیار ساده، جذاب و آشنا
- نیاز نداشتن به درگیری با مسائلی مانند thread-safety
- عدم استفاده از Multithreading و به تبع آن، مواجه نشدن با باگهای قفلکننده
- جامعه توسعهدهندگان بسیار عظیم و کتابخانهها و ابزارهای توسعهداده شده غنی به همراه یک Package Manager قوی برای مدیریت ملحقات!
معایب
- پیچیدگی کد برنامه ناهمزمان (Asyncronous) و مشکل بودن یادگیری مفاهیم اولیه برای برنامهنویسان ناآشنا با مدل برنامهنویسی موازی.
- تأخیر بسیار بالا در صورت نیاز وظایف داخلی به اتمام عملیات محوله. به دلیل اینکه برنامه بهصورت تک رشتهاي اجرا ميشود، یک تابع با زمان اجرای طولانی ميتواند سرعت پاسخدهی کلی سیستم را به شدت کاهش دهد.
- نبود یک کتابخانه استاندارد جاوااسکریپت. برنامهنویسان جاوااسکریپت به شدت به استفاده آسان از آن عادت کردهاند، بدون اینکه به وارد کردن کتابخانه خاصی نیاز داشته باشند. بههمین دلیل، از هر چیزی در برنامهها پنج مدل مختلف وجود خواهد داشت که سردرگمی خاصی را ایجاد ميکند. حتی ماجولهاي قرارداده شده در هسته Node.js نیز هر کدام پنج نوع مختلف دارند که به تکامل سریعتر ميانجامد، اما درجه ابهام بالایی را نیز در پیخواهد داشت.
- سیستمهاي نهایی نوشتهشده با این فناوري بهشدت نسبت به مدل CGI، یعنی Apache+PHP یا Perl یا Ruby و... پیچیدهتر بوده و استثناهای مدیریتنشده ميتوانند کل فرآيند را متوقفکرده و نیاز به راهاندازی دوباره فرآيندهاي درحال کار روي کلاستر را الزامی سازند. یک کد باگ دار نیز ميتواند باعث خرابی فرآيند اجرایی مربوط شده و هر فرآيند درحال کار خراب، درخواستهاي بسیاری را بیپاسخ خواهدگذاشت که به تبع آن مقاومت کل سیستم در مقابل خرابی را کاهش داده و باعث کاهش کیفیت خدمات خواهد شد.