كيفية تثبيت منتدى NodeBB على دبيان 9

NodeBB هو منتدى قائم على Node.js. يستخدم مقابس الويب للتفاعل الفوري والإشعارات في الوقت الحقيقي. تتم استضافة رمز مصدر NodeBB علنًا على Github . سيرشدك هذا الدليل خلال عملية تثبيت NodeBB على نسخة جديدة من Debian 9 Vultr باستخدام Node.js و MongoDB كقاعدة بيانات و Nginx كبديل عكسي و Acme.sh لشهادات SSL.

المتطلبات

يتطلب NodeBB تثبيت البرنامج التالي:

  • شخص سخيف
  • Node.js الإصدار 6.9.0 أو أحدث
  • إصدار MongoDB 2.6 أو أحدث
  • Nginx
  • ذاكرة وصول عشوائي بسعة 1024 ميجابايت على الأقل
  • اسم المجال مع A/ AAAAإعداد السجلات

قبل ان تبدأ

تحقق من إصدار دبيان.

lsb_release -ds
# Debian GNU/Linux 9.4 (stretch)

تأكد من أن نظامك محدث.

apt update && apt upgrade -y

قم بتثبيت الحزم الضرورية.

apt install -y sudo dirmngr git build-essential apt-transport-https

قم بإنشاء non-rootحساب مستخدم جديد له sudoحق الوصول والتبديل إليه.

adduser johndoe --gecos "John Doe"
usermod -aG sudo johndoe
su - johndoe

ملاحظة : استبدل johndoeباسم المستخدم الخاص بك.

قم بإعداد المنطقة الزمنية.

sudo dpkg-reconfigure tzdata

قم بتثبيت Node.js

يتم تشغيل NodeBB بواسطة Node.js ، ولذلك يجب تثبيته. يوصى بتثبيت إصدار LTS الحالي من Node.js.

قم بتثبيت Node.js من مستودع NodeSource.

curl -sL https://deb.nodesource.com/setup_10.x | sudo -E bash -
sudo apt install -y nodejs

تحقق من تثبيت Node.js و npm.

node -v && npm -v
# v10.15.0
# 5.6.0

قم بتثبيت وتكوين MongoDB

MongoDB هي قاعدة البيانات الافتراضية لـ NodeBB.

قم بتثبيت MongoDB من مستودع MongoDB الرسمي.

sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 9DA31620334BD75D9DCB49F368818C72E52529D4
echo "deb https://repo.mongodb.org/apt/debian stretch/mongodb-org/4.0 main" | sudo tee /etc/apt/sources.list.d/mongodb-org-4.0.list
sudo apt update
sudo apt install -y mongodb-org

التحقق من إصدار.

mongo --version | head -n 1 && mongod --version | head -n 1
# MongoDB shell version v4.00
# db version v4.0.0

ابدأ وتمكين MongoDB.

sudo systemctl start mongod.service
sudo systemctl enable mongod.service

إنشاء قاعدة بيانات MongoDB ومستخدم لـ NodeBB.

اتصل بـ MongoDB.

mongo

قم بالتبديل إلى adminقاعدة البيانات المضمنة .

> use admin

قم بإنشاء مستخدم إداري.

> db.createUser( { user: "admin", pwd: "<Enter a secure password>", roles: [ { role: "readWriteAnyDatabase", db: "admin" }, { role: "userAdminAnyDatabase", db: "admin" } ] } )

ملاحظة: استبدل العنصر النائب <Enter a secure password>بكلمة المرور المحددة.

إضافة قاعدة بيانات جديدة تسمى nodebb.

> use nodebb

سيتم إنشاء قاعدة البيانات وتبديل السياق إليها nodebb. بعد ذلك ، قم بإنشاء nodebbالمستخدم بالامتيازات المناسبة.

> db.createUser( { user: "nodebb", pwd: "<Enter a secure password>", roles: [ { role: "readWrite", db: "nodebb" }, { role: "clusterMonitor", db: "admin" } ] } )

ملاحظة: مرة أخرى ، استبدل العنصر النائب <Enter a secure password>بكلمة المرور المحددة.

اخرج من قشرة المونغو.

> quit()

أعد تشغيل MongoDB وتحقق من أن المستخدم الإداري الذي تم إنشاؤه سابقًا يمكنه الاتصال.

sudo systemctl restart mongod.service
mongo -u admin -p your_password --authenticationDatabase=admin

قم بتثبيت وتكوين Nginx

قم بتثبيت أحدث إصدار رئيسي من Nginx من مستودع Nginx الرسمي.

wget https://nginx.org/keys/nginx_signing.key
sudo apt-key add nginx_signing.key
rm nginx_signing.key
sudo -s
printf "deb https://nginx.org/packages/mainline/debian/ $(lsb_release -sc) nginx\ndeb-src https://nginx.org/packages/mainline/debian/ $(lsb_release -sc) nginx\n" >> /etc/apt/sources.list.d/nginx_mainline.list
exit
sudo apt update
sudo apt install -y nginx

التحقق من إصدار.

sudo nginx -v
# nginx version: nginx/1.15.0

قم بتمكين Nginx وبدء تشغيله.

sudo systemctl enable nginx.service
sudo systemctl start nginx.service

يعمل NodeBB بشكل افتراضي على المنفذ 4567. لتجنب الكتابة http://example.com:4567، سنقوم بتكوين Nginx كوكيل عكسي لتطبيق NodeBB. سيتم إعادة توجيه كل طلب على المنفذ 80أو 443(إذا تم استخدام SSL) إلى المنفذ 4567.

قم بتشغيله sudo vim /etc/nginx/conf.d/nodebb.confوملؤه باستخدام التكوين الأساسي للخادم الوكيل العكسي الموضح أدناه.

server {

  listen [::]:80;
  listen 80;

  server_name forum.example.com;

  root /usr/share/nginx/html;

  client_max_body_size 50M;

  location /.well-known/acme-challenge/ {
    allow all;
  }

  location / {
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header X-Forwarded-Proto $scheme;
    proxy_set_header Host $http_host;
    proxy_hide_header X-Powered-By;
    proxy_set_header X-Nginx-Proxy true;

    proxy_pass http://127.0.0.1:4567;
    proxy_redirect off;

    # Socket.IO Support
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection "upgrade";
  }

}

في التكوين أعلاه ، قم بتحديث server_nameالتوجيه باستخدام اسم المجال / المضيف الخاص بك.

تحقق من التكوين.

sudo nginx -t

إعادة تحميل Nginx.

sudo systemctl reload nginx.service

قم بتثبيت عميل Acme.sh واحصل على شهادة Let's Encrypt (اختياري)

ليس من الضروري تأمين منتداك باستخدام HTTPS ، ولكنه سيؤمن حركة المرور على موقعك. Acme.sh هو برنامج Unix shell خالص للحصول على شهادات SSL من Let's Encrypt بدون أية تبعيات.

تنزيل وتثبيت Acme.sh.

sudo mkdir /etc/letsencrypt
git clone https://github.com/Neilpang/acme.sh.git
cd acme.sh
sudo ./acme.sh --install --home /etc/letsencrypt --accountemail [email protected]
cd ~
source ~/.bashrc

التحقق من إصدار.

acme.sh --version
# v2.7.9

الحصول على شهادات RSA و ECDSA لـ forum.example.com.

# RSA 2048
sudo /etc/letsencrypt/acme.sh --issue --home /etc/letsencrypt -d forum.example.com --webroot /usr/share/nginx/html --reloadcmd "sudo systemctl reload nginx.service" --accountemail [email protected] --ocsp-must-staple --keylength 2048
# ECDSA/ECC P-256
sudo /etc/letsencrypt/acme.sh --issue --home /etc/letsencrypt -d forum.example.com --webroot /usr/share/nginx/html --reloadcmd "sudo systemctl reload nginx.service" --accountemail [email protected] --ocsp-must-staple --keylength ec-256

بعد تشغيل الأوامر أعلاه ، ستكون الشهادات والمفاتيح الخاصة بك في الدلائل التالية:

  • RSA: /etc/letsencrypt/forum.example.com
  • ECC / ECDSA: /etc/letsencrypt/forum.example.com_ecc

بعد الحصول على الشهادات من Let's Encrypt ، نحتاج إلى تكوين Nginx لاستخدامها.

تشغيل sudo vim /etc/nginx/conf.d/nodebb.confمرة أخرى وتكوين Nginx كوكيل عكسي HTTPS.

server {

  listen [::]:443 ssl http2;
  listen 443 ssl http2;
  listen [::]:80;
  listen 80;

  server_name forum.example.com;

  root /usr/share/nginx/html;

  client_max_body_size 50M;

  location /.well-known/acme-challenge/ {
    allow all;
  }

  # RSA
  ssl_certificate /etc/letsencrypt/forum.example.com/fullchain.cer;
  ssl_certificate_key /etc/letsencrypt/forum.example.com/forum.example.com.key;
  # ECDSA
  ssl_certificate /etc/letsencrypt/forum.example.com_ecc/fullchain.cer;
  ssl_certificate_key /etc/letsencrypt/forum.example.com_ecc/forum.example.com.key;

  location / {
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    proxy_set_header X-Forwarded-Proto $scheme;
    proxy_set_header Host $http_host;
    proxy_set_header X-NginX-Proxy true;

    proxy_pass http://127.0.0.1:4567;
    proxy_redirect off;

    # Socket.IO Support
    proxy_http_version 1.1;
    proxy_set_header Upgrade $http_upgrade;
    proxy_set_header Connection "upgrade";
  }

}

تحقق من التكوين.

sudo nginx -t

إعادة تحميل Nginx.

sudo systemctl reload nginx.service

قم بتثبيت NodeBB

قم بإنشاء دليل جذر المستند.

sudo mkdir -p /var/www/nodebb

تغيير ملكية /var/www/nodebbالدليل إلى johndoe.

sudo chown -R johndoe:johndoe /var/www/nodebb

انتقل إلى مجلد جذر المستند.

cd /var/www/nodebb

استنساخ أحدث NodeBB في مجلد جذر المستند.

git clone -b v1.10.x https://github.com/NodeBB/NodeBB.git .

شغّل أمر إعداد NodeBB وأجب عن كل سؤال عند مطالبتك بذلك.

./nodebb setup

بعد اكتمال إعداد NodeBB ، ./nodebb startقم بالتشغيل لبدء خادم NodeBB يدويًا.

./nodebb start

بعد هذا الأمر ، ستتمكن من الوصول إلى المنتدى الخاص بك في متصفح الويب الخاص بك.

تشغيل NodeBB كخدمة نظام

عند البدء عبر ./nodebb start، لن يبدأ NodeBB تلقائيًا مرة أخرى عند إعادة تشغيل النظام. لتجنب ذلك ، سنحتاج إلى إعداد NodeBB كخدمة نظام.

إذا كان قيد التشغيل ، قم بإيقاف NodeBB.

./nodebb stop

إنشاء nodebbمستخدم جديد :

sudo adduser nodebb

قم بتغيير ملكية /var/www/nodebbالدليل إلى nodebb.

sudo chown -R nodebb:nodebb /var/www/nodebb

إنشاء nodebb.serviceملف تكوين وحدة systemd. سوف يعالج ملف الوحدة هذا بدء تشغيل Dodeon NodeBB. قم بتشغيل sudo vim /etc/systemd/system/nodebb.serviceوملء الملف بالمحتوى التالي:

[Unit]
Description=NodeBB
Documentation=https://docs.nodebb.org
After=system.slice multi-user.target mongod.service

[Service]
Type=forking
User=nodebb

StandardOutput=syslog
StandardError=syslog
SyslogIdentifier=nodebb

Environment=NODE_ENV=production
WorkingDirectory=/var/www/nodebb
PIDFile=/var/www/nodebb/pidfile
ExecStart=/usr/bin/env node loader.js
Restart=always

[Install]
WantedBy=multi-user.target

ملاحظة: قم بتعيين مسار المستخدم واسم الدليل وفقًا للأسماء التي اخترتها.

تمكين nodebb.serviceعند إعادة التشغيل والبدء على الفور nodebb.service.

sudo systemctl enable nodebb.service
sudo systemctl start nodebb.service

تحقق من nodebb.serviceالحالة.

sudo systemctl status nodebb.service
sudo systemctl is-enabled nodebb.service

هذا هو. نسخة NodeBB قيد التشغيل الآن.



Leave a Comment

قم بإعداد NFS Share على دبيان

قم بإعداد NFS Share على دبيان

NFS هو نظام ملفات قائم على الشبكة يسمح لأجهزة الكمبيوتر بالوصول إلى الملفات عبر شبكة الكمبيوتر. يوضح هذا الدليل كيف يمكنك فضح المجلدات عبر NF

نشر WebDAV على دبيان 10 باستخدام WsgiDAV

نشر WebDAV على دبيان 10 باستخدام WsgiDAV

مقدمة: التأليف والإصدار الموزع على الويب (WebDAV) هو امتداد HTTP يوفر إطار عمل لإنشاء الملفات وتعديلها عن بُعد على

استخدام طرق عرض MySQL على دبيان 7

استخدام طرق عرض MySQL على دبيان 7

مقدمة يتميز MySQL بميزة رائعة تعرف باسم طرق العرض. المشاهدات هي استعلامات مخزنة. اعتبرها اسمًا مستعارًا لاستعلام طويل. في هذا الدليل ،

إنشاء Chroot على دبيان

إنشاء Chroot على دبيان

ستعلمك هذه المقالة كيفية إعداد سجن سريع على دبيان. أفترض أنك تستخدم Debian 7.x. إذا كنت تقوم بتشغيل دبيان 6 أو 8 ، فقد يعمل هذا ، ولكن

كيفية تثبيت PiVPN على دبيان

كيفية تثبيت PiVPN على دبيان

مقدمة طريقة سهلة لإعداد خادم VPN على دبيان هي PiVPN. PiVPN هو أداة تثبيت وغلاف لـ OpenVPN. يخلق أوامر بسيطة لك

كيفية بناء Brotli من المصدر على دبيان 9

كيفية بناء Brotli من المصدر على دبيان 9

استخدام نظام مختلف؟ Brotli هو طريقة ضغط جديدة مع نسبة ضغط أفضل من Gzip. يتم استضافة رمز المصدر الخاص به علانية على Github. ثي

كيفية تثبيت Neos CMS على دبيان 9

كيفية تثبيت Neos CMS على دبيان 9

استخدام نظام مختلف؟ Neos عبارة عن منصة تطبيق محتوى مع CMS وإطار تطبيق في جوهرها. سيوضح لك هذا الدليل كيفية التثبيت

قم بإعداد Cacti على Debian Jessie

قم بإعداد Cacti على Debian Jessie

مقدمة Cacti هي أدوات مراقبة ورسوم بيانية مفتوحة المصدر تعتمد بالكامل على بيانات RRD. من خلال Cacti ، يمكنك مراقبة أي نوع من أنواع الأجهزة تقريبًا

كيفية تثبيت Golang 1.13 على CentOS 8 و Ubuntu 18.04 و Debian 10 و Fedora 31

كيفية تثبيت Golang 1.13 على CentOS 8 و Ubuntu 18.04 و Debian 10 و Fedora 31

Go (تُعرف أيضًا باسم Golang) هي لغة برمجة مكتوبة بشكل ثابت ومجمعة على شكل حرف C تم تطويرها بواسطة Google. جعلت البساطة وتعدد الاستخدامات ب

كيفية تثبيت InvoicePlane على دبيان 9

كيفية تثبيت InvoicePlane على دبيان 9

استخدام نظام مختلف؟ InvoicePlane هو تطبيق فواتير مجاني ومفتوح المصدر. يمكن العثور على رمز المصدر الخاص به في مستودع Github هذا. هذا الدليل

كيفية تثبيت Reader Self 3.5 RSS Reader على Debian 9 LAMP VPS

كيفية تثبيت Reader Self 3.5 RSS Reader على Debian 9 LAMP VPS

استخدام نظام مختلف؟ Reader Self 3.5 هو قارئ RSS بسيط ومرن ومفتوح ومفتوح المصدر ومستضاف ذاتيًا وبديل Google Reader. القارئ سيل

كيفية تثبيت BookStack على دبيان 9

كيفية تثبيت BookStack على دبيان 9

استخدام نظام مختلف؟ BookStack عبارة عن نظام أساسي بسيط وسهل الاستخدام لتنظيم المعلومات وتخزينها. BookStack مجاني تمامًا ومفتوح

كيفية تثبيت FFmpeg على دبيان 8 أو دبيان 9

كيفية تثبيت FFmpeg على دبيان 8 أو دبيان 9

مقدمة FFmpeg هي أداة سطر أوامر مفتوحة المصدر لتشفير / فك تشفير الفيديو والصوت. ميزاته الرئيسية هي سرعة عالية وجودة وفيل صغير

كيفية تثبيت TermRecord على Ubuntu 16.04 و Debian 9

كيفية تثبيت TermRecord على Ubuntu 16.04 و Debian 9

استخدام نظام مختلف؟ TermRecord هو أداة بسيطة مفتوحة المصدر مكتوبة بلغة Python ، تسمح بحفظ الجلسات النهائية إلى مشاركة ذاتية سهلة المشاركة

كيفية تثبيت Matomo Analytics على Debian 9

كيفية تثبيت Matomo Analytics على Debian 9

استخدام نظام مختلف؟ Matomo (Piwik سابقًا) هو نظام أساسي مفتوح المصدر للتحليلات ، وهو بديل مفتوح لبرنامج Google Analytics. مصدر Matomo مستضاف

اختيار نظام التشغيل: CentOS أو Ubuntu أو Debian أو FreeBSD أو CoreOS أو Windows Server

اختيار نظام التشغيل: CentOS أو Ubuntu أو Debian أو FreeBSD أو CoreOS أو Windows Server

تقدم هذه المقالة ملخصًا موجزًا ​​لأنظمة تشغيل الخادم المقدمة كنماذج على Vultr. CentOS CentOS هو إصدار مفتوح المصدر من RHEL (Re

كيفية تثبيت X-Cart 5 على دبيان 10

كيفية تثبيت X-Cart 5 على دبيان 10

استخدام نظام مختلف؟ X-Cart هي منصة تجارة إلكترونية مفتوحة المصدر مرنة للغاية مع الكثير من الميزات والتكاملات. كود مصدر X-Cart مضيف

راقب حالة خادم Debian مع Munin

راقب حالة خادم Debian مع Munin

Munin عبارة عن أداة مراقبة لمسح العمليات والموارد في جهازك وتقديم المعلومات في الرسوم البيانية من خلال واجهة الويب. استخدم ما يلي

كيفية تثبيت Tiny Tiny RSS Reader على Debian 9 LAMP VPS

كيفية تثبيت Tiny Tiny RSS Reader على Debian 9 LAMP VPS

استخدام نظام مختلف؟ Tiny Tiny RSS Reader هو قارئ ومجمّع أخبار مستوحى ذاتيًا ومفتوح المصدر ومستضاف على الويب (RSS / Atom) ، مصمم خصيصًا

إضافة نطاق عناوين IP إلى خادمك (CentOS / Ubuntu / Debian)

إضافة نطاق عناوين IP إلى خادمك (CentOS / Ubuntu / Debian)

مقدمة في هذا البرنامج التعليمي ، سنغطي عملية إضافة نطاق IP / شبكة فرعية كاملة إلى خادم Linux يعمل بنظام CentOS أو Debian أو Ubuntu. الموكيز

نظرة ثاقبة على 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. قراءة هذه المادة لمعرفة المزيد