من مدتهاست که می خواستم با راه اندازی یک وب سرور از ابتدا و انتشار آن در اینترنت، در خدمات اینترنتی "دست هایم را لمس کنم". در این مقاله می خواهم تجربه خود را در تبدیل یک روتر خانگی از یک دستگاه بسیار کاربردی به یک سرور تقریباً کامل به اشتراک بگذارم.
همه چیز با این واقعیت شروع شد که روتر TP-Link TL-WR1043ND که به طور صادقانه کار می کرد، دیگر نیازهای یک شبکه خانگی را برآورده نمی کرد؛ من یک باند 5 گیگاهرتز و دسترسی سریع به فایل ها در یک دستگاه ذخیره سازی متصل به روتر می خواستم. . پس از نگاهی به انجمن های تخصصی (4pda، ixbt)، سایت هایی با بررسی و مشاهده مجموعه ای از فروشگاه های محلی، تصمیم گرفتم Keenetic Ultra را خریداری کنم.
نظرات خوب صاحبان به نفع این دستگاه خاص بود:
هیچ مشکلی با گرمای بیش از حد (در اینجا مجبور شدیم محصولات Asus را رها کنیم)؛
قابلیت اطمینان عملیاتی (در اینجا من TP-Link را خط زدم)؛
راه اندازی آسان (می ترسیدم نتوانم با آن کنار بیایم و Microtik را خط زدم).
باید با معایب کنار می آمدم:
بدون WiFi6، من می خواستم تجهیزاتی را با ذخیره برای آینده بگیرم.
4 پورت LAN، من بیشتر می خواستم، اما این دیگر یک دسته خانگی نیست.
در نتیجه، ما این "سرور" را دریافت کردیم:
در سمت چپ ترمینال نوری Rostelecom است.
در سمت راست روتر آزمایشی ما قرار دارد.
یک SSD 2 گیگابایتی m.128 در اطراف، که در جعبه USB3 از Aliexpress قرار گرفته است، با سیم به روتر متصل شده است، اکنون به زیبایی روی دیوار نصب شده است.
در پیش زمینه یک سیم پسوند با سوکت های جدا شده به طور مستقل است، سیم از آن به یک UPS ارزان قیمت می رود.
در پس زمینه یک دسته کابل جفت پیچ خورده وجود دارد - در مرحله بازسازی آپارتمان، من بلافاصله سوکت های RJ45 را در مکان هایی که قرار بود تجهیزات قرار بگیرند برنامه ریزی کردم تا به پر شدن وای فای وابسته نباشم.
بنابراین، ما تجهیزات را داریم، باید آن را پیکربندی کنیم:
راه اندازی اولیه روتر حدود 2 دقیقه طول می کشد، ما پارامترهای اتصال را به ارائه دهنده نشان می دهیم (ترمینال نوری من به حالت پل تغییر می کند، اتصال PPPoE روتر را بلند می کند)، نام شبکه WiFi و رمز عبور - اساساً همین است. ، روتر راه اندازی می شود و کار می کند.
ما ارسال پورت های خارجی را به پورت های خود روتر در بخش "قوانین شبکه - حمل و نقل" تنظیم می کنیم:
اکنون میتوانیم به بخش «پیشرفته» برویم، چیزی که از روتر میخواستم:
عملکرد یک NAS کوچک برای یک شبکه خانگی؛
انجام عملکردهای وب سرور برای چندین صفحه خصوصی؛
عملکرد ابر شخصی برای دسترسی به داده های شخصی از هر نقطه از جهان.
اولین مورد با استفاده از ابزارهای داخلی بدون نیاز به تلاش زیاد اجرا می شود:
ما یک درایو در نظر گرفته شده برای این نقش (درایو فلش، کارت حافظه در کارت خوان، هارد دیسک یا SSD در یک جعبه خارجی می گیریم و با استفاده از آن به Ext4 فرمت می کنیم. MiniTool Partition Wizard Edition Free (من کامپیوتری با لینوکس در دست ندارم، با ابزارهای داخلی امکان پذیر است). همانطور که متوجه شدم، در حین کار، سیستم فقط گزارش ها را در درایو فلش می نویسد، بنابراین اگر پس از راه اندازی سیستم آنها را محدود کنید، اگر قصد دارید زیاد و اغلب در درایو بنویسید - یک SSD یا HDD بهتر است.
پس از این کار، درایو را به روتر متصل می کنیم و آن را روی صفحه نمایشگر سیستم مشاهده می کنیم
روی «درایوهای USB و چاپگرها» در بخش «برنامهها» کلیک کنید و سهم را در بخش «شبکه ویندوز» پیکربندی کنید:
و ما یک منبع شبکه داریم که می تواند از رایانه های ویندوز استفاده شود، در صورت لزوم به عنوان یک دیسک متصل می شود: net use y: \192.168.1.1SSD /persistent:yes
سرعت چنین NAS بداههای برای استفاده خانگی کاملاً کافی است؛ از طریق سیم از کل گیگابیت استفاده میکند، از طریق WiFi سرعت آن حدود 400-500 مگابیت است.
راه اندازی فضای ذخیره سازی یکی از مراحل ضروری برای پیکربندی سرور است، پس ما نیاز داریم:
- خرید دامنه و یک آدرس IP ثابت (با استفاده از Dynamic DNS می توانید بدون این کار انجام دهید، اما من قبلاً یک IP ثابت داشتم، بنابراین استفاده از آن راحت تر بود. خدمات رایگان Yandex - با تفویض اختیار دامنه به آنجا، ما میزبانی DNS و نامه را در دامنه خود دریافت می کنیم).
چندین ساعت طول می کشد تا تنظیمات مربوط به دامنه و DNS اعمال شود، بنابراین ما به طور همزمان روتر را راه اندازی می کنیم.
ابتدا باید مخزن Entware را نصب کنیم که از آنجا می توانیم بسته های لازم را روی روتر نصب کنیم. من استفاده کردم با این دستورالعمل، فقط بسته نصب را از طریق FTP آپلود نکرد، بلکه یک پوشه را مستقیماً در درایو شبکه قبلاً متصل ایجاد کرد و فایل را به روش معمول در آنجا کپی کرد.
پس از دسترسی از طریق SSH، رمز عبور را با دستور passwd تغییر دهید و با دستور opkg install [package names] تمامی بسته های لازم را نصب کنید:
در حین راه اندازی، بسته های زیر روی روتر نصب شدند (خروجی دستور opkg list-installed):
شاید چیزی اضافی در اینجا وجود داشت، اما فضای زیادی روی درایو وجود داشت، بنابراین من حوصله نگاه کردن به آن را نداشتم.
بعد از نصب بسته ها، nginx را پیکربندی می کنیم، من آن را با دو دامنه امتحان کردم - دومی با https پیکربندی شده است و فعلاً یک خرد وجود دارد. از پورت های داخلی 81 و 433 به جای 80 و 443 استفاده می شود، زیرا پنل مدیریت روتر روی پورت های معمولی آویزان است.
برای اینکه سایت از طریق https کار کند، از اسکریپت معروف dehydrated استفاده کردم و آن را با استفاده از آن نصب کردم این دستورالعمل. این روند هیچ مشکلی ایجاد نکرد ، من فقط به این واقعیت برخورد کردم که در متن اسکریپت کار روی روتر من شما باید خط موجود در فایل را نظر دهید /opt/etc/ssl/openssl.cnf:
[openssl_conf]
#engines=engines
و توجه دارم که تولید dhparams.pem با دستور "openssl dhparam -out dhparams.pem 2048" در روتر من بیش از 2 ساعت طول می کشد، اگر نشانگر پیشرفت نبود، صبرم را از دست می دادم و راه اندازی مجدد می کردم.
پس از دریافت گواهینامه ها، با دستور “/opt/etc/init.d/S80nginx restart” nginx را مجددا راه اندازی کنید. در اصل، راه اندازی کامل است، اما هنوز وب سایتی وجود ندارد - اگر فایل index.html را در پوشه /share/nginx/html قرار دهیم، یک خرد خواهیم دید.
برای قرار دادن اطلاعات به زیبایی، استفاده از قالبهای آماده برای افراد غیرحرفهای مانند من آسانتر است؛ پس از جستجوی طولانی در کاتالوگهای مختلف، پیدا کردم templatemo.com - انتخاب خوبی از الگوهای رایگان وجود دارد که نیازی به ذکر منبع ندارند (که در اینترنت نادر است؛ بیشتر الگوهای موجود در مجوز از شما می خواهند پیوندی را به منبعی که از آن به دست آمده اند ذخیره کنید).
ما یک الگوی مناسب را انتخاب می کنیم - مواردی برای موارد مختلف وجود دارد، بایگانی را دانلود کرده و آن را در پوشه /share/nginx/html باز کنید، می توانید این کار را از رایانه خود انجام دهید، سپس الگو را ویرایش کنید (در اینجا به حداقل دانش نیاز دارید. از HTML تا ساختارش شکسته نشود) و گرافیک را مطابق شکل زیر جایگزین کنید.
خلاصه: روتر در اصل برای میزبانی یک وب سایت سبک در آن کاملاً مناسب است - اگر بار زیادی انتظار نمی رود، می توانید نصب کنید و php کنیدو پروژه های پیچیده تری را آزمایش کنید (من به nextcloud/owncloud نگاه می کنم، به نظر می رسد نصب های موفقی روی چنین سخت افزاری وجود دارد). قابلیت نصب بسته ها سودمندی آن را افزایش می دهد - به عنوان مثال، زمانی که لازم بود از پورت RDP رایانه شخصی در یک شبکه محلی محافظت کنم، knockd را روی روتر نصب کردم - و ارسال پورت به رایانه شخصی فقط پس از ضربه زدن پورت باز شد.
چرا روتر و نه یک کامپیوتر معمولی؟ روتر یکی از معدود قطعات سخت افزاری کامپیوتری است که در بسیاری از آپارتمان ها به صورت شبانه روزی کار می کند؛ روتر خانگی معمولاً کاملاً بی صدا است و یک سایت سبک با کمتر از صد بازدید در روز اصلاً آن را آزار نمی دهد.