كيفية تثبيت منتدى NodeBB على Fedora 28

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

المتطلبات

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

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

قبل ان تبدأ

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

cat /etc/fedora-release
# Fedora release 28 (Twenty Eight)

قم بإنشاء حساب مستخدم جديد غير جذري له sudoحق الوصول وقم بالتبديل إليه.

useradd -c "John Doe" johndoe && passwd johndoe
usermod -aG wheel johndoe
su - johndoe

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

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

timedatectl list-timezones
sudo timedatectl set-timezone 'Region/City'

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

sudo dnf check-upgrade || sudo dnf upgrade -y

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

sudo dnf install -y git wget vim gcc-c++ make

من أجل البساطة ، قم بتعطيل SELinux وجدار الحماية.

sudo setenforce 0
sudo systemctl stop firewalld
sudo systemctl disable firewalld

قم بتثبيت Node.js

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

تثبيت Node.js.

sudo dnf install -y nodejs

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

node -v && npm -v
# v8.11.3
# 5.6.0

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

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

قم بتثبيت MongoDB.

sudo dnf install -y mongodb mongodb-server

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

mongo --version | head -n 1 && mongod --version | head -n 1
# MongoDB shell version v3.6.3
# db version v3.6.3

قم بتمكين وبدء خدمة MongoDB.

sudo systemctl enable mongod.service
sudo systemctl start 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.

sudo dnf install -y nginx

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

sudo nginx -v
# nginx version: nginx/1.12.1

قم بتمكين 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 هو برنامج shell unix خالص للحصول على شهادات 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

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

/etc/letsencrypt/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 useradd 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

كيفية تثبيت Matomo Analytics على Fedora 28

كيفية تثبيت Matomo Analytics على Fedora 28

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

كيفية تثبيت Omeka Classic 2.4 CMS على Fedora 26 LAMP VPS

كيفية تثبيت Omeka Classic 2.4 CMS على Fedora 26 LAMP VPS

استخدام نظام مختلف؟ Omeka Classic 2.4 CMS هو نظام نشر رقمي مجاني ومفتوح المصدر ونظام إدارة المحتوى (CMS) لمشاركة الصور الرقمية

كيفية نشر Ghost v0.11 LTS على Fedora 25

كيفية نشر Ghost v0.11 LTS على Fedora 25

استخدام نظام مختلف؟ Ghost هي منصة تدوين مفتوحة المصدر اكتسبت شعبية بين المطورين والمستخدمين العاديين منذ عام 201

كيفية تثبيت WonderCMS على Fedora 29

كيفية تثبيت WonderCMS على Fedora 29

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

كيفية تثبيت 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. جعلت البساطة وتعدد الاستخدامات ب

كيفية تثبيت Directus 6.4 CMS على Fedora 26 LAMP VPS

كيفية تثبيت Directus 6.4 CMS على Fedora 26 LAMP VPS

استخدام نظام مختلف؟ Directus 6.4 CMS هو نظام إدارة محتوى بلا محتوى قوي ومرن ومفتوح المصدر ومفتوح المصدر يوفر للمطورين

كيفية تثبيت ألبوم صور Lychee 3.1 على Fedora 26 LAMP VPS

كيفية تثبيت ألبوم صور Lychee 3.1 على Fedora 26 LAMP VPS

استخدام نظام مختلف؟ Lychee 3.1 Photo Album هو أداة إدارة صور بسيطة ومرنة ومجانية ومفتوحة المصدر تعمل على خادم VPS. يتم تثبيته

تثبيت Fork CMS على Fedora 28

تثبيت Fork CMS على Fedora 28

استخدام نظام مختلف؟ Fork هو CMS مفتوح المصدر مكتوب بلغة PHP. رمز مصدر فوركس مستضاف على جيثب. سيوضح لك هذا الدليل كيفية تثبيت Fork CM

كيفية تثبيت RainLoop Webmail على Fedora 28

كيفية تثبيت RainLoop Webmail على Fedora 28

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

كيفية تثبيت PyroCMS على Fedora 28

كيفية تثبيت PyroCMS على Fedora 28

استخدام نظام مختلف؟ PyroCMS هو CMS مفتوح المصدر مكتوب بلغة PHP. يتم استضافة شفرة مصدر PyroCMS على GitHub. في هذا الدليل تمشي جيدًا عبر الكل

كيفية تثبيت وتكوين لوحة المهام على Fedora 30

كيفية تثبيت وتكوين لوحة المهام على Fedora 30

استخدام نظام مختلف؟ مقدمة TaskBoard هي أداة مجانية ومفتوحة المصدر يمكن استخدامها لتتبع الأشياء التي تحتاج إلى إنجازها. أنه يوفر

كيفية تثبيت TextPattern CMS 4.6.2 على Fedora 26 LAMP VPS

كيفية تثبيت TextPattern CMS 4.6.2 على Fedora 26 LAMP VPS

استخدام نظام مختلف؟ TextPattern CMS 4.6.2 هو نظام إدارة محتوى بسيط ومرن ومجاني ومفتوح المصدر (CMS) يتيح لمصممي الويب

كيفية تثبيت BookStack على Fedora 28

كيفية تثبيت BookStack على Fedora 28

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

كيفية تثبيت Gitea على Fedora 29

كيفية تثبيت Gitea على Fedora 29

استخدام نظام مختلف؟ Gitea هو نظام بديل مفتوح المصدر للتحكم في الإصدار يعمل بواسطة Git. Gitea هو مكتوب في Golang وهو

كيفية تثبيت Couch CMS 2.0 على Fedora 26 LAMP VPS

كيفية تثبيت Couch CMS 2.0 على Fedora 26 LAMP VPS

استخدام نظام مختلف؟ Couch CMS هو نظام إدارة محتوى (CMS) بسيط ومرن ومجاني ومفتوح يسمح لمصممي الويب بتصميم

كيفية تثبيت MyBB على Fedora 28

كيفية تثبيت MyBB على Fedora 28

استخدام نظام مختلف؟ MyBB هو برنامج منتدى مجاني ومفتوح المصدر وبديهي وقابل للتوسيع. يتم استضافة رمز مصدر MyBB على GitHub. هذا الدليل سوف يظهر

كيفية تثبيت Microweber على Fedora 28

كيفية تثبيت Microweber على Fedora 28

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

كيفية تثبيت Osclass على Fedora 28

كيفية تثبيت Osclass على Fedora 28

استخدام نظام مختلف؟ Osclass هو مشروع مفتوح المصدر يسمح لك بإنشاء موقع مصنف بسهولة دون أي معرفة تقنية. مصدره

قم بتثبيت HTMLDoc على Fedora 29

قم بتثبيت HTMLDoc على Fedora 29

استخدام نظام مختلف؟ سيقوم HTMLDoc بتحليل مستندات Postcript (PDF 1.6) ديناميكيًا من النص التشعبي المكتوب بشكل صحيح (HTML 3.2). هذا سيسمح لك ر

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