وبسرور (Web Server) نرمافزار و سختافزاری است که از پروتکل HTTP (Hypertext Transfer Protocol) و پروتکلهای دیگر برای پاسخ به درخواستهای مشتری از طریق شبکه جهانی وب استفاده میکند. وظیفهی اصلی وبسرور نمایش محتوای وبسایت از طریق ذخیرهسازی، پردازش و ارائه صفحات وب به کاربران است. وبسرورها علاوه بر HTTP، از پروتکل SMTP (Simple Mail Transfer Protocol) و FTP (File Transfer Protocol) که برای ایمیل، انتقال فایل و ذخیرهسازی استفاده میشود نیز پشتیبانی میکنند.
آنچه در این مقاله میخوانید:
نمونههایی از استفاده از وبسرور
وبسرورهای رایج و برتر موجود در بازار
سختافزار یک وبسرور به اینترنت متصل است و امکان تبادل داده با سایر دستگاههای متصل را فراهم مینماید. در حالی که نرمافزار وبسرور نحوه دسترسی کاربر به فایلهای میزبانی شده را کنترل میکند. فرآیند وبسرور نمونهای از مدل مشتری/ سرور است. تمامی رایانههایی که میزبان وبسایتها هستند باید دارای نرمافزار وبسرور باشند. وبسرورها در میزبانی وب یا میزبانی دادهها برای وبسایتهای و برنامههای مبتنی بر وب (اپلیکیشنها) استفاده میشوند.
وبسرورها چگونه کار میکنند؟
نرمافزار وبسرور از طریق نام دامنه وبسایتها قابل دسترسی است و اطمینان میدهد که محتوای درخواستی از وبسایت به کاربر تحویل داده میشود. نرمافزار وبسرور نیز از چندین مولفه تشکیل شده است که حداقل یک از آنها سرور HTTP است. سرور HTTP قادر به درک HTTP (پروتکلی که مرورگر وب برای بازدید از صفحات یک وبسایت استفاده میکند.) و URLها (آدرس صفحات وب) است. وبسرور به عنوان سختافزار، رایانهای است که نرمافزار وبسرور و سایر فایلهای مربوط به یک وبسایت، مانند اسناد HTML،تصاویر و فایلهای جاوااسکریپت را ذخیره میکند.
هنگامی که یک مرورگر وب، مانند گوگل کروم یا فایرفاکس، به فایلی نیاز دارد که روی سرور وب میزبانی شده باشد، مرورگر فایل را از طریق پروتکل HTTP درخواست میکند. هنگامی که درخواست توسط وبسرور دریافت میشود، سرور HTTP درخواست را میپذیرد، محتوا را پیدا میکند و آن را از طریق HTTP به مرورگر ارسال میکند.
به طور دقیقتر، هنگامی که یک مرورگر صفحهای را از یک وبسرور درخواست میکند، این فرآیند یک سری مراحل را دنبال میکند. ابتدا، شخص یک URL را در نوار آدرس مرورگر وب مشخص میکند. سپس مرورگر وب آدرس IP نام دامنه را به دست میآورد (یا از طریق DNS (سیستم نام دامنه) آن را ترجمه میکند یا اگر قبلا به این آدرس مراجعه کرده آن را در حافظه پنهان جستجو میکند). با این کار مرورگر به یک وبسرور منتقل میشود. سپس مرورگر با درخواست HTTP فایل خاصی را از وبسرور درخواست میکند. وبسرور پاسخ میدهد و صفحه درخواستی را دوباره از طریق HTTP به مرورگر می فرستد. اگر صفحه درخواستی وجود نداشته باشد یا مشکلی پیش بیاید، وبسرور با یک پیام خطا به مرورگر پاسخ خواهد داد. سپس مرورگر قادر به نمایش صفحه وب خواهد بود. دامنههای متعددی نیز میتوانند بر روی یک وبسرور میزبانی شوند.
نمونههایی از استفاده از وبسرور
وبسرورها اغلب به عنوان بخشی از یک مجموعه از برنامههای مرتبط با اینترنت هستند که برای موارد زیر استفاده میشوند:
- ارسال و دریافت ایمیل
- دانلود درخواست برای پروتکل انتقال فایل (FTP)
- ساخت و انتشار صفحات وب
بسیاری از وبسرورهای پایه از برنامهنویسی سمت سرور پشتیبانی میکنند. این زبانهای برنامهنویسی بر روی وبسرور برای سفارشیسازی پاسخ به کار میروند. برنامهنویسی سمت سرور بر روی ماشین سرور اجرا میشود و معمولا دارای مجموعهای از ویژگیهاست که شامل دسترسی به پایگاه داده نیز میشود. فرآیند اسکریپتنویسی سمت سرور از زبانهای برنامهنویسی ASP (Active Server Pages)، PHP (Hypertext Preprocessor) و زبانهای برنامهنویسی دیگر استفاده میکند. این فرآیند همچنین به اسناد HTML اجازه میدهد تا به صورت پویا ایجاد شوند.
وبسرورهای پویا و استاتیک
یک وبسرور میتواند برای ارائه محتوای ثابت یا پویا استفاده شود. محتوای استاتیک یک محتوای ثابت است که همیشه به یک شکل نمایش داده میشود. در حالی که محتوای پویا را میتوان تغییر داده و به روزرسانی کرد. یک وبسرور استاتیک از یک کامپیوتر و یک نرمافزار HTTP تشکیل شده است. یک محتوا زمانی استاتیک در نظر گرفته میشود که سرور فایلهای میزبانی شده را همانطور که هست به مرورگر ارسال میکند.
مرورگرهای وب پویا از یک وبسرور و نرم افزارهای دیگری مانند اپلیکیشن سرور و پایگاه داده تشکیل شدهاند. یک محتوا به این دلیل پویا در نظر گرفته میشود که اپلیکیشن سرور میتواند برای بهروزرسانی هر فایل میزبانی شده قبل از ارسال به مرورگر استفاده شود. وبسرور میتواند محتوا را زمانی که از یک پایگاه داده درخواست میشود، ایجاد کند. اگرچه این فرآیند انعطافپذیرتر است، اما پیچیدگیهای خاص خود را نیز دارد.
وبسرورهای رایج و برتر موجود در بازار
وبسرورهای مختلفی با کاربردها و ویژگیهای خاص خود وجود دارند که در ادامه تعدادی از معروفترین آنها را معرفی میکنیم:
سرور HTTP آپاچی (Apache)
آپاچی یک وبسرور رایگان و متنباز (open source) برای ویندوز، Mac OS X، Unix، Linux، Solaris و سایر سیستم عاملهاست که توسط بنیاد نرمافزار آپاچی توسعه یافته است. متنباز بودن یک برنامه بدین معنی است که کدهای آن به صورت رایگان در دسترس همگان قرار دارد و برنامهنویسان در سراسر دنیا میتوانند به توسعه آن کمک کنند. آپاچی یکی از وبسرورهای مورد علاقه برنامهنویسان است که میتواند با کمترین پیکرهبندی حجم ترافیک بالایی را مدیریت کند.
IIS(Microsoft Internet Information Services)
IIS توسط شرکت مایکروسافت و برای پلتفرمهای مختلف توسعه یافته است. این وبسرور متنباز نیست؛ ولی با توجه به انعطافپذیری در پشتیبانی از انواع فریمورکها به طور گسترده استفاده میشود.
وبسرور Nginx
Nginx یک وبسرور متنباز محبوب است که به دلیل معماری رویداد محور، با استفاده از میزان رم کمتر میتواند بسیاری از نشستها (sessions) را به صورت همزمان مدیریت کند. Nginx همچنین میتواند به عنوان یک سرور پروکسی (proxy server) و متعادلکننده بار (load balancer) استفاده شود.
لایت اسپید (Litespeed)
لایت اسپید یک وبسرور رایگان و متنباز است که با سیستم عامل FreeBSD ارائه میشود. این وبسرور با مصرف CPU کمتر میتواند درخواستهای بیشتری را مدیریت کند. لایت اسپید عملکرد مناسب، امنیت و انعطافپذیری بالایی دارد.
وبسرورهای مجبوب و پیشروی امروزی شامل آپاچی، IIS و Nginx میشوند. از سایر وبسرورها میتوان به سرور Novell’s Netware، GWS (Google Web Server) و خانواده IBM از سرورهای Domino اشاره کرد.
برای انتخاب یک وبسرور مناسب باید به مواردی مانند سازگاری آن با سیستم عاملهای مختلف، توانایی آن برای به کار بردن برنامهنویسی سمت سرور، مشخصات امنیتی، انتشار، موتور جستجو و ابزراهای ساخت وبسایت همراه آن توجه کرد. برخی وبسرورها تنظیمات مختلفی نیز دارند که به طور معمول بر روی مقادیر پیشفرض تنظیم شدهاند. برای ایجاد عملکرد بالا در یک وبسرور عواملی مانند توان عملیاتی بالا و تاخیر کم می توانند کمککننده خواهند بود.
شیوههای امنیتی وبسرور
شیوههای امنیتی زیادی وجود دارند که افراد میتوانند برای ایجاد امنیت بیشتر در استفاده از وبسرور آنها را تنظیم کنند. چند نمونه از اقدامات امنیتی میتوانند شامل فرایندهای زیر باشند:
- یک پروکسی معکوس، که برای مخفی کردن یک سرور داخلی طراحی شده است و به عنوان یک واسطه برای ترافیک منشا در یک سرور داخلی عمل می کند.
- محدود کردن دسترسیها از طریق فرآیندهایی مانند محدود کردن دسترسی میزبان وب به ماشینهای زیرساخت یا استفاده از SSH (Secure Socket Shell).
- سرورهای وب را به روز نگه دارید تا بتوانید اطمینان حاصل کنید که سرور وب در معرض آسیبپذیری قرار نداشته باشد.
- به طور منظم بر روی شبکه نظارت داشته باشید تا از عدم وجود فعالیت غیرمجاز مطمئن باشید.
- استفاده از فایروال و SSL به عنوان فایروال میتواند بر روی ترافیک HTTP نظارت کند، در حالی که داشتن یک SSL (Secure Sockets Layer) میتواند به امن نگه داشتن دادهها کمک کند.
سوالات متداول
وبسرور چیست؟
وب سرور (Web Server) نرمافزار و سختافزاری است که از پروتکل HTTP (Hypertext Transfer Protocol) و پروتکلهای دیگر برای پاسخ به درخواستهای مشتری از طریق شبکه جهانی وب استفاده میکند.
وبسرور چگونه کار میکند؟
وبسرورها ترکیبی از سختافزارها و نرمافزارهای کامپیوتری هستند که درخواستهای کاربران را از طریق مرورگر وب و تحت پروتکل HTTP دریافت میکنند و پس از پردازش این درخواست، پاسخ آنها به سمت مرورگر وب ارسال میشود.
وبسرورهای مختلف چه تفاوتی با یکدیگر دارند؟
وبسرورهای مختلف از نظر سیستم عامل، پشتیبانی از زبانهای برنامهنویسی مختلف، موارد امنیتی و … با یکدیگر تفاوت دارند و شما باید بهترین وبسرور را با توجه به نیازهای خود و کاربرد مورد نظر انتخاب کنید.