كيفية تثبيت منتدى 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

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