كيفية إعداد تطبيق عقدة Koa.js على Ubuntu 16.04 LTS

في هذا البرنامج التعليمي ، سنتعلم كيفية إعداد تطبيق ويب Koa.js للإنتاج ، باستخدام Node.js. سنقوم أيضًا بربط نطاق عينة ، باستخدام وكيل عكسي ، باستخدام Apache ، وتعلم كيفية إدارته باستخدام مدير عملية مناسب. بدون مزيد من اللغط ، دعنا نبدأ.

وصف موجز لـ Node.js و Koa.js و Apache

Node.js عبارة عن إطار عمل جافا سكريبت سريع وعبر الأنظمة الأساسية يعتمد على محرك V8 في Chrome. يتم استخدامه في كل من تطبيقات سطح المكتب والخادم ويشتهر بمعالجة حلقة الأحداث ذات الخيوط الفردية. يحتوي Node.js على سجل حزمة يسمى Node Package Manager (NPM) ، الذي يستضيف أكثر من نصف مليون حزمة. حزم NPM (أو الوحدات النمطية) هي العمود الفقري الأساسي لـ Node.js ، لأنها رمز مدفوع بالمجتمع يمكن أن تكون مفيدة في تطبيق Node.js الخاص بك. في تطبيق Koa.js ، يعد Node.js هو الجزء الأساسي من وظيفته.

Koa.js هو إطار ويب أضيق الحدود مبني على منصة Node.js. صُنع من قبل نفس الفريق وراء إطار Express.js الشهير ، هدفه هو تقليل إطار Express.js البسيط بالفعل عن طريق استبعاد الوسيطة من جوهره. إحدى السمات الرئيسية لـ Koa.js هي حقيقة عدم وجود استدعاءات. تم بناء Koa.js على المولدات القائمة على ES6 وميزات ES6 ، مثل الوعود.

Apache هو خادم ويب مفتوح المصدر شائع الاستخدام ، يستخدم كنقطة بداية أساسية لخوادم الويب. في هذا البرنامج التعليمي ، سنستخدم أباتشي كوكيل عكسي ، والذي سيسمح لنا بربط تطبيقنا بنطاق عينة. إذا لم يكن لديك نطاق ، فسيظل هذا البرنامج التعليمي مناسبًا لك ، والفرق الوحيد هو أنه سيتم تشغيل موقع الويب على VPS IP الخاص بك ، بدلاً من النطاق.

إعداد Node.js

كما هو الحال مع أي إطار عمل Node.js ، ستحتاج إلى تثبيت Node.js على VPS الخاص بك. من أجل هذا البرنامج التعليمي ، سأفترض أن لديك Node.js مثبتًا بالفعل على نظامك. إذا لم يكن كذلك ، يمكنك ببساطة اتباع التعليمات هنا .

إنشاء دليل التطبيق الخاص بنا

سنحتاج إلى إنشاء مجلد يحتوي على الملفات الأساسية لتطبيقنا.

mkdir site

لا تتردد في استبدال siteأي اسم آخر تريده للدليل. بعد ذلك ، سنحتاج إلى تهيئة ملف حزمة Node.js. التغيير إلى الدليل الذي أنشأته للتو ، وقم بتشغيل npm initواستكمال المطالبات. في النهاية ، يجب أن يبدو شيء مثل هذا:

{
  "name": "site",
  "version": "1.0.0",
  "description": "Koa.js Site",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "yourname",
  "license": "ISC"
}

تثبيت Koa.js

الآن بعد أن تم إعداد دليلنا ، يمكننا متابعة تثبيت Koa.js. في دليل العمل الحالي /site، اكتب ما يلي.

npm install koa

سيؤدي ذلك إلى تنزيل وحدة Koa.js من NPM وتثبيتها في دليل مشروعنا لاستخدامها في المستقبل. بعد ذلك ، سنقوم بإنشاء ملف طلب عينة يحتوي على رمز التطبيق الخاص بنا. للقيام بذلك ، قم بإنشاء index.jsملف.

nano index.js

مرة واحدة داخل الملف ، قم بإنشاء تطبيق عينة.

const Koa = require('koa');
const app = new Koa();

app.use(async ctx => {
     ctx.body = 'Hello World';
 });

app.listen(3000);
console.log('Website is live!')

أحفظ وأغلق الملف. CTRL+ X.

سنريد التأكد من أن تطبيقنا يعمل بشكل صحيح. للبدء ، قم بالتشغيل node index.js، وسترى Website is liveفي وحدة التحكم.

تثبيت أباتشي

الآن بعد أن علمنا أن موقعنا يعمل ، يمكننا المضي قدمًا في تثبيت Apache وتبعياته.

sudo apt install -y libapache2-mod-proxy-html libxml2-dev

لاستخدام ميزة الوكيل العكسي الموجودة في Apache ، سنحتاج إلى تمكين الوحدات الضرورية.

a2enmod proxy
a2enmod proxy_http
a2enmod proxy_ajp
a2enmod rewrite
a2enmod deflate
a2enmod headers
a2enmod proxy_balancer
a2enmod proxy_connect
a2enmod proxy_html

ربما تم تمكين بعض هذه الوحدات بالفعل ، ولكن من الجيد دائمًا التحقق منها جيدًا.

الآن نحن بحاجة إلى تحرير ملف التكوين الافتراضي لـ Apache.

sudo nano /etc/apache2/sites-enabled/000-default.conf

هنا ، سنحتاج إلى إضافة كتلة لتطبيقنا.

<VirtualHost *:*>
    ProxyPreserveHost On
    ProxyPass / http://0.0.0.0:3000/
    ProxyPassReverse / http://0.0.0.0:3000

    ServerName localhost
</VirtualHost>

احفظ الملف CTRL+ X.

قد تلاحظ أننا باستخدام منفذ 3000كمنفذ لدينا ProxyPassو ProxyPassReverseIP. نظرًا لأنه نفس المنفذ الذي نقوم بتشغيل تطبيق Koa.js عليه ، فمن الضروري أن نقوم بإدخال المنفذ الصحيح.

بمجرد إجراء التغييرات ، سنحتاج إلى إعادة تشغيل Apache وإعادة تشغيل تطبيق Koa.js.

sudo systemctl restart apache2

سيضمن هذا أن ملف التكوين لدينا نشط وجاهز للعمل عندما نبدأ تطبيق Koa.js. بمجرد إعادة تشغيل Apache ، انتقل مرة أخرى إلى دليل الموقع الخاص بك ، وابدأ تطبيق Koa.js كما فعلنا سابقًا. من متصفح الويب الخاص بك ، انتقل إلى http://yourdomain، أو http://yourip:، وسترى "Hello World".

إدارة تطبيقنا مع systemd

الآن بعد أن قمنا بتغطية أساسيات إنشاء تطبيق Koa.js عينة ، ندرك أنه في بيئة الإنتاج ، فإن بدء التطبيق كما نحن الآن غير عملي. مدير العمليات هو بالتأكيد مطلب. وهنا يأتي دور systemd. بعبارات بسيطة ، يتكون systemd من برنامج يوفر لبنات بناء لنظام Linux. على غرار "init" ، فإنه يوفر نظامًا لإدارة عمليات المستخدم بعد بدء تشغيل النظام. في حالة تطبيقنا ، يسمح لنا systemd ببدء موقعنا تلقائيًا بعد إعادة تشغيل النظام ، في حالة وجود حدث يعطل وقت تشغيل النظام. كما يوفر مجموعة من الأدوات التي يمكن أن تكون مفيدة عند إدارة تطبيقنا. أفضل جزء هو أنه مدمج في Ubuntu 16.04 LTS ، لذلك لا نحتاج إلى تثبيت أي برامج إضافية.

إنشاء خدمة systemd

سيتم احتواء كل ما نحتاجه لبدء تطبيقنا في ملف يسمى service. يحتوي على تفاصيل حول تطبيقنا ، مثل الاسم والدليل والبيئة والمزيد. لإنشاء ملف نظامنا ، افتح محرر نص.

sudo nano /lib/systemd/system/site.service

قم بتحرير وحفظ الملف مثل هذا.

[Unit]
Description=desc here
Documentation=https://example.com
After=network.target

[Service]
Environment=NODE_PORT=3000
Type=simple
User=youruser
ExecStart=/usr/bin/node /home/[youruser]/site/index.js
Restart=on-failure

[Install]
WantedBy=multi-user.target

استبدل youruserاسم مستخدم الخادم الخاص بك. في ما يلي ملخص سريع للحقول المهمة:

  • After - يقوم هذا بإبلاغ systemd إلى الانتظار حتى تصبح واجهة الشبكة جاهزة قبل بدء تطبيقنا.
  • Environment- هنا يمكننا تحديد متغيرات البيئة لتطبيقنا. منفذ Node.js الخاص بنا واحد منهم.
  • Type - يخطر هذا النظام أن تطبيقنا يمكن تشغيله للتو ، بدون امتياز امتيازات المستخدم وما إلى ذلك.
  • User- هذا يخبر systemd أننا نريد تشغيل التطبيق تحت حساب المستخدم الخاص بنا ، وهو أمر موصى به. يمكن أن يؤدي تشغيل التطبيقات كمستخدم أساسي إلى العديد من التنازلات الأمنية.
  • ExecStart - بشكل أساسي الأمر الذي سيتم تشغيله لبدء تشغيل تطبيقنا ، على غرار الطريقة التي بدأنا بها يدويًا من قبل.
  • Restart- يخبر systemd الظروف التي لإعادة تشغيل التطبيق. في هذه الحالة ، نريد إعادة تشغيل موقعنا في حالة حدوث خطأ.

ابدأ تشغيل خدمة systemd

نحن الآن جاهزون لبدء خدمة systemd.

sudo systemctl daemon-reload

يعد ذلك ضروريًا عندما يتغير ملف خدمة systemd من أجل قيام systemd بتسجيل أي تغييرات جديدة تم إجراؤها.

ثم ابدأ تشغيل التطبيق الخاص بك.

sudo systemctl start site

انتقل إلى الموقع في متصفحك مرة أخرى ، للتحقق من عمل كل شيء.

وظائف إدارة systemd الرئيسية

  • stop - توقف التطبيق بالكامل.
  • restart - يوقف التطبيق ، ويبدأ مرة أخرى في عملية جديدة.
  • enable - يخبر systemd لبدء التطبيق كلما قمت بتشغيل جهاز الكمبيوتر الخاص بك.
  • status - يعرض معلومات حول التطبيق قيد التشغيل حاليًا ، مثل وقت التشغيل وحالة التطبيق والمزيد.

لاستخدام أي من هذه الوظائف ، قم بتشغيل ما يلي.

systemctl <function> site

استنتاج

لقد نجحنا في إعداد تطبيق Koa.js وتعلمنا كيفية عكس الوكيل ، وإدارته باستخدام systemd. أنت الآن جاهز لتوسيع تطبيقك والاستفادة من هذا المثال. إذا كنت ترغب في معرفة المزيد عن Koa.js ، والمزيد من الأشياء التي يمكنك القيام بها ، قم بزيارة موقع الويب الخاص بهم ، لمزيد من المعلومات المفيدة. بالإضافة إلى ذلك ، إذا كنت ترغب في معرفة المزيد عن مدير عمليات النظام ، اقرأ الوثائق الخاصة به هنا . أخيرًا ، إذا كنت ترغب في معرفة المزيد حول وكيل Apache العكسي ، فلا تتردد في التحقق منها هنا .



Leave a Comment

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول

6 أشياء شديدة الجنون حول نينتندو سويتش

6 أشياء شديدة الجنون حول نينتندو سويتش

يعرف الكثير منكم أن Switch سيصدر في مارس 2017 وميزاته الجديدة. بالنسبة لأولئك الذين لا يعرفون ، قمنا بإعداد قائمة بالميزات التي تجعل "التبديل" "أداة لا غنى عنها".

وعود التكنولوجيا التي لم يتم الوفاء بها بعد

وعود التكنولوجيا التي لم يتم الوفاء بها بعد

هل تنتظر عمالقة التكنولوجيا للوفاء بوعودهم؟ تحقق من ما تبقى دون تسليم.

وظائف طبقات معمارية مرجعية للبيانات الضخمة

وظائف طبقات معمارية مرجعية للبيانات الضخمة

اقرأ المدونة لمعرفة الطبقات المختلفة في بنية البيانات الضخمة ووظائفها بأبسط طريقة.

كيف يمكن للذكاء الاصطناعي نقل أتمتة العمليات إلى المستوى التالي؟

كيف يمكن للذكاء الاصطناعي نقل أتمتة العمليات إلى المستوى التالي؟

اقرأ هذا لمعرفة مدى انتشار الذكاء الاصطناعي بين الشركات الصغيرة وكيف أنه يزيد من احتمالات نموها ومنح منافسيها القدرة على التفوق.

CAPTCHA: ما هي المدة التي يمكن أن تظل تقنية قابلة للتطبيق للتميز بين الإنسان والذكاء الاصطناعي؟

CAPTCHA: ما هي المدة التي يمكن أن تظل تقنية قابلة للتطبيق للتميز بين الإنسان والذكاء الاصطناعي؟

لقد أصبح حل CAPTCHA صعبًا جدًا على المستخدمين في السنوات القليلة الماضية. هل ستكون قادرة على أن تظل فعالة في اكتشاف البريد العشوائي والروبوتات في المستقبل القريب؟

التفرد التكنولوجي: مستقبل بعيد للحضارة الإنسانية؟

التفرد التكنولوجي: مستقبل بعيد للحضارة الإنسانية؟

مع تطور العلم بمعدل سريع ، واستلام الكثير من جهودنا ، تزداد أيضًا مخاطر تعريض أنفسنا إلى تفرد غير قابل للتفسير. اقرأ ، ماذا يمكن أن يعني التفرد بالنسبة لنا.

التطبيب عن بعد والرعاية الصحية عن بعد: المستقبل هنا

التطبيب عن بعد والرعاية الصحية عن بعد: المستقبل هنا

ما هو التطبيب عن بعد والرعاية الصحية عن بعد وأثره على الأجيال القادمة؟ هل هو مكان جيد أم لا في حالة الوباء؟ اقرأ المدونة لتجد طريقة عرض!

هل تساءلت يومًا كيف يربح المتسللون الأموال؟

هل تساءلت يومًا كيف يربح المتسللون الأموال؟

ربما سمعت أن المتسللين يكسبون الكثير من المال ، لكن هل تساءلت يومًا كيف يجنون هذا النوع من المال؟ دعنا نناقش.

يتسبب التحديث الإضافي لنظام macOS Catalina 10.15.4 في حدوث مشكلات أكثر من حلها

يتسبب التحديث الإضافي لنظام macOS Catalina 10.15.4 في حدوث مشكلات أكثر من حلها

أصدرت Apple مؤخرًا macOS Catalina 10.15.4 تحديثًا تكميليًا لإصلاح المشكلات ولكن يبدو أن التحديث يتسبب في المزيد من المشكلات التي تؤدي إلى إنشاء أجهزة macOS. قراءة هذه المادة لمعرفة المزيد