كيفية تثبيت Neos CMS على FreeBSD 12
استخدام نظام مختلف؟ Neos عبارة عن منصة تطبيق محتوى مع CMS وإطار تطبيق في جوهرها. سيوضح لك هذا الدليل كيفية التثبيت
NodeBB هو برنامج منتدى Node.js. يستخدم مقابس الويب للتفاعل الفوري والإشعارات في الوقت الحقيقي. يتم استضافة رمز مصدر NodeBB علنًا على Github . سيرشدك هذا الدليل خلال عملية تثبيت NodeBB على مثيل FreeBSD 12 Vultr ، باستخدام Node.js و MongoDB كقاعدة بيانات و Nginx كوكيل عكسي و Acme.sh لشهادات SSL.
يتطلب NodeBB تثبيت البرنامج التالي:
A
/ AAAA
إعداد السجلاتتحقق من إصدار FreeBSD.
uname -ro
# FreeBSD 12.0-RELEASE
تأكد من تحديث نظام FreeBSD الخاص بك.
freebsd-update fetch install
pkg update && pkg upgrade -y
قم بتثبيت الحزم الضرورية إذا لم تكن موجودة على نظامك.
pkg install -y sudo vim unzip wget git bash socat gcc8 pkgconf vips
قم بإنشاء حساب مستخدم جديد باسم المستخدم المفضل لديك (سوف نستخدمه johndoe
).
adduser
# Username: johndoe
# Full name: John Doe
# Uid (Leave empty for default): <Enter>
# Login group [johndoe]: <Enter>
# Login group is johndoe. Invite johndoe into other groups? []: wheel
# Login class [default]: <Enter>
# Shell (sh csh tcsh nologin) [sh]: bash
# Home directory [/home/johndoe]: <Enter>
# Home directory permissions (Leave empty for default): <Enter>
# Use password-based authentication? [yes]: <Enter>
# Use an empty password? (yes/no) [no]: <Enter>
# Use a random password? (yes/no) [no]: <Enter>
# Enter password: your_secure_password
# Enter password again: your_secure_password
# Lock out the account after creation? [no]: <Enter>
# OK? (yes/no): yes
# Add another user? (yes/no): no
# Goodbye!
قم بتشغيل visudo
الأمر وإلغاء تعليق %wheel ALL=(ALL) ALL
السطر ، للسماح لأعضاء wheel
المجموعة بتنفيذ أي أمر.
visudo
# Uncomment by removing hash (#) sign
# %wheel ALL=(ALL) ALL
الآن ، قم بالتبديل إلى المستخدم الذي تم إنشاؤه حديثًا باستخدام su
.
su - johndoe
ملاحظة: استبدل johndoe
باسم المستخدم الخاص بك.
قم بإعداد المنطقة الزمنية.
sudo tzsetup
يتم تشغيل NodeBB بواسطة Node.js ، ولذلك يجب تثبيته. يوصى بتثبيت إصدار LTS الحالي من Node.js.
قم بتثبيت Node.js و npm.
sudo pkg install -y node10 npm-node10
تحقق من الإصدارات.
node -v && npm -v
# v10.15.3
# 6.9.0
MongoDB هي قاعدة البيانات الافتراضية لـ NodeBB.
قم بتثبيت MongoDB.
sudo pkg install -y mongodb40
التحقق من إصدار.
mongo --version | head -n 1 && mongod --version | head -n 1
# MongoDB shell version v4.0.6
# db version v4.0.6
قم بتمكين وبدء MongoDB.
sudo sysrc mongod_enable=yes
sudo service mongod start
إنشاء قاعدة بيانات ومستخدم ل 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 service mongod restart
mongo -u admin -p your_password --authenticationDatabase=admin
قم بتثبيت Nginx.
sudo pkg install -y nginx
التحقق من إصدار.
nginx -v
# nginx version: nginx/1.14.2
قم بتمكين Nginx وبدء تشغيله.
sudo sysrc nginx_enable=yes
sudo service nginx start
NodeBB بشكل افتراضي يعمل على المنفذ 4567
. لتجنب الكتابة http://example.com:4567
، سنقوم بتكوين Nginx كوكيل عكسي لتطبيق NodeBB. ستتم إعادة توجيه كل طلب على المنفذ 80
أو 443
، إذا تم استخدام SSL ، إلى المنفذ 4567
.
قم بتشغيله sudo vim /usr/local/etc/nginx/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
التوجيه باسم المجال / اسم المضيف الخاص بك.
احفظ الملف واخرج مع :+ W+ Q.
الآن نحن بحاجة إلى تضمينها nodebb.conf
في nginx.conf
الملف الرئيسي .
قم بتشغيل sudo vim /usr/local/etc/nginx/nginx.conf
وإضافة السطر التالي إلى http {}
الكتلة.
include nodebb.conf;
تحقق من التكوين.
sudo nginx -t
إعادة تحميل Nginx.
sudo service nginx reload
ليس من الضروري تأمين منتداك باستخدام 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 ~
التحقق من إصدار.
/etc/letsencrypt/acme.sh --version
# v2.8.1
الحصول على شهادات 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 service nginx reload" --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 service nginx reload" --keylength ec-256
بعد تشغيل الأوامر أعلاه ، ستكون الشهادات والمفاتيح الخاصة بك في:
/etc/letsencrypt/forum.example.com
./etc/letsencrypt/forum.example.com_ecc
.بعد الحصول على الشهادات من Let's Encrypt ، نحتاج إلى تكوين Nginx لاستخدامها.
تشغيل sudo vim /usr/local/etc/nginx/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 service nginx reload
قم بإنشاء دليل جذر المستند.
sudo mkdir -p /usr/local/www/nodebb
تغيير ملكية /usr/local/www/nodebb
الدليل إلى johndoe
.
sudo chown -R johndoe:johndoe /usr/local/www/nodebb
انتقل إلى مجلد جذر المستند.
cd /usr/local/www/nodebb
استنساخ أحدث NodeBB في مجلد جذر المستند.
git clone -b v1.11.x https://github.com/NodeBB/NodeBB.git .
شغّل أمر إعداد NodeBB وأجب عن كل سؤال عند مطالبتك بذلك.
./nodebb setup
بعد اكتمال إعداد NodeBB ، ./nodebb start
قم بالتشغيل لبدء خادم NodeBB يدويًا.
./nodebb start
بعد هذا الأمر ، ستتمكن من الوصول إلى مثيل منتدى NodeBB في متصفح الويب.
عند البدء عبر ./nodebb start
، لن يبدأ NodeBB تلقائيًا مرة أخرى عند إعادة تشغيل النظام. لتجنب ذلك ، سنحتاج إلى إعداد NodeBB كخدمة نظام.
إذا كان قيد التشغيل ، قم بإيقاف NodeBB.
./nodebb stop
قم بتثبيت PM2 عالميًا.
sudo npm install pm2 -g
التحقق من إصدار.
pm2 -v
# 3.5.0
انتقل إلى جذر وثيقة NodeBB.
cd /usr/local/www/nodebb
بدء NodeBB عبر PM2.
pm2 start app.js
سرد عملية NodeBB.
pm2 ls
كشف نظام التهيئة المتاحة.
pm2 startup
قم بنسخ ولصق إخراج هذا الأمر في CLI لإعداد ربط بدء التشغيل الخاص بك.
حفظ قائمة العمليات الخاصة بك.
pm2 save
هذا هو. نسخة NodeBB قيد التشغيل الآن.
استخدام نظام مختلف؟ Neos عبارة عن منصة تطبيق محتوى مع CMS وإطار تطبيق في جوهرها. سيوضح لك هذا الدليل كيفية التثبيت
استخدام نظام مختلف؟ osTicket هو نظام تذاكر مفتوح المصدر لدعم العملاء. تتم استضافة شفرة مصدر osTicket علنًا على Github. في هذا البرنامج التعليمي
استخدام نظام مختلف؟ مونيكا هو نظام إدارة علاقات شخصية مفتوح المصدر. فكر في الأمر على أنه CRM (أداة شائعة تستخدمها فرق المبيعات في ال
مقدمة WordPress هو نظام إدارة المحتوى المهيمن على الإنترنت. يعمل على تشغيل كل شيء من المدونات إلى مواقع الويب المعقدة ذات المحتوى الديناميكي
استخدام نظام مختلف؟ ProcessWire CMS 3.0 هو نظام إدارة محتوى بسيط ومرن وقوي ومجاني ومفتوح المصدر (CMS). ProcessWire CMS 3.
مقدمة يوضح هذا البرنامج التعليمي OpenBSD كحل للتجارة الإلكترونية باستخدام PrestaShop و Apache. مطلوب أباتشي لأن PrestaShop لديه UR معقدة
مقدمة مكدس FAMP ، الذي يمكن مقارنته بمكدس LAMP على Linux ، هو مجموعة من البرامج مفتوحة المصدر التي يتم تثبيتها معًا عادةً
تقدم هذه المقالة ملخصًا موجزًا لأنظمة تشغيل الخادم المقدمة كنماذج على Vultr. CentOS CentOS هو إصدار مفتوح المصدر من RHEL (Re
استخدام نظام مختلف؟ X-Cart هي منصة تجارة إلكترونية مفتوحة المصدر مرنة للغاية مع الكثير من الميزات والتكاملات. كود مصدر X-Cart مضيف
استخدام نظام مختلف؟ PyroCMS هو CMS مفتوح المصدر مكتوب بلغة PHP. يتم استضافة شفرة مصدر PyroCMS على GitHub. في هذا الدليل ، تمشي جيدًا عبر الكل
خارج الصندوق ، لم يتم تكوين خوادم Vultr FreeBSD لتشمل مساحة المبادلة. إذا كانت نيتك هي مثيل سحابة يمكن التخلص منها ، فربما لا تحتاج
في هذا المقال ، يوضح لك Ill كيفية تثبيت MariaDB على OpenBSD 6 وتكوينه بحيث يمكن الوصول إليه من خلال خادم ويب مختلط (Apache أو Nginx). أنت أيضا
استخدام نظام مختلف؟ مقدمة Craft CMS هو CMS مفتوح المصدر مكتوب بلغة PHP. تتم استضافة رمز مصدر Craft CMS على GitHub. هذا الدليل سيظهر لك
عند ترقية نسخة VPS على Vultr ، يتم تغيير حجم نظام ملفات Linux تلقائيًا. عند تشغيل FreeBSD مع نظام ملفات ZFS المتقدم ، هناك بعض القلق اليدوي
استخدام نظام مختلف؟ TextPattern CMS 4.6.2 هو نظام إدارة محتوى بسيط ومرن ومجاني ومفتوح المصدر (CMS) يتيح لمصممي الويب
استخدام نظام مختلف؟ يمكن لـ ESpeak إنشاء ملفات صوتية من تحويل النص إلى كلام (TTS). يمكن أن تكون هذه مفيدة لعدة أسباب ، مثل إنشاء تورين الخاصة بك
pfSense هي أداة مثالية لمسؤولي النظام الذين يتطلعون إلى إضافة مجموعة واسعة من الميزات إلى شبكتهم. وهي في الأساس مصدر مفتوح
إذا كنت تقوم بتشغيل المحلل الخاص بك ، أو ترغب في استخدام واحد من موفر تابع لجهة خارجية ، فقد تجد أن DHCP يتم استبدال ملف /etc/resolv.conf الخاص بك
استخدام نظام مختلف؟ مقدمة Akaunting هو برنامج محاسبة مجاني مفتوح المصدر وعبر الإنترنت مصمم للشركات الصغيرة والمستقلين. أنا
استخدام نظام مختلف؟ Anchor CMS هو محرك مدونة نظام إدارة المحتوى (CMS) بسيط للغاية وخفيف الوزن للغاية ومفتوح المصدر
نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول
يعرف الكثير منكم أن Switch سيصدر في مارس 2017 وميزاته الجديدة. بالنسبة لأولئك الذين لا يعرفون ، قمنا بإعداد قائمة بالميزات التي تجعل "التبديل" "أداة لا غنى عنها".
هل تنتظر عمالقة التكنولوجيا للوفاء بوعودهم؟ تحقق من ما تبقى دون تسليم.
اقرأ المدونة لمعرفة الطبقات المختلفة في بنية البيانات الضخمة ووظائفها بأبسط طريقة.
اقرأ هذا لمعرفة مدى انتشار الذكاء الاصطناعي بين الشركات الصغيرة وكيف أنه يزيد من احتمالات نموها ومنح منافسيها القدرة على التفوق.
لقد أصبح حل CAPTCHA صعبًا جدًا على المستخدمين في السنوات القليلة الماضية. هل ستكون قادرة على أن تظل فعالة في اكتشاف البريد العشوائي والروبوتات في المستقبل القريب؟
مع تطور العلم بمعدل سريع ، واستلام الكثير من جهودنا ، تزداد أيضًا مخاطر تعريض أنفسنا إلى تفرد غير قابل للتفسير. اقرأ ، ماذا يمكن أن يعني التفرد بالنسبة لنا.
ما هو التطبيب عن بعد والرعاية الصحية عن بعد وأثره على الأجيال القادمة؟ هل هو مكان جيد أم لا في حالة الوباء؟ اقرأ المدونة لتجد طريقة عرض!
ربما سمعت أن المتسللين يكسبون الكثير من المال ، لكن هل تساءلت يومًا كيف يجنون هذا النوع من المال؟ دعنا نناقش.
أصدرت Apple مؤخرًا macOS Catalina 10.15.4 تحديثًا تكميليًا لإصلاح المشكلات ولكن يبدو أن التحديث يتسبب في المزيد من المشكلات التي تؤدي إلى إنشاء أجهزة macOS. قراءة هذه المادة لمعرفة المزيد