كيفية تثبيت Matomo Analytics على Fedora 28
استخدام نظام مختلف؟ Matomo (Piwik سابقًا) هو نظام أساسي مفتوح المصدر للتحليلات ، وهو بديل مفتوح لبرنامج Google Analytics. مصدر Matomo مستضاف
NodeBB هو منتدى قائم على Node.js. يستخدم مقابس الويب للتفاعل الفوري والإشعارات في الوقت الحقيقي. تتم استضافة رمز مصدر NodeBB علنًا على Github . سيرشدك هذا الدليل خلال عملية تثبيت NodeBB على مثيل Fedora 28 Vultr الجديد باستخدام Node.js و MongoDB كقاعدة بيانات و Nginx كبديل عكسي و Acme.sh لشهادات SSL.
يتطلب NodeBB تثبيت البرنامج التالي:
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
يتم تشغيل 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 هي قاعدة البيانات الافتراضية لـ 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.
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
ليس من الضروري تأمين منتداك باستخدام 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
بعد تشغيل الأوامر أعلاه ، ستكون الشهادات والمفاتيح الخاصة بك في الدلائل التالية:
/etc/letsencrypt/forum.example.com
/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
قم بإنشاء دليل جذر المستند.
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 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 قيد التشغيل الآن.
استخدام نظام مختلف؟ Matomo (Piwik سابقًا) هو نظام أساسي مفتوح المصدر للتحليلات ، وهو بديل مفتوح لبرنامج Google Analytics. مصدر Matomo مستضاف
استخدام نظام مختلف؟ Omeka Classic 2.4 CMS هو نظام نشر رقمي مجاني ومفتوح المصدر ونظام إدارة المحتوى (CMS) لمشاركة الصور الرقمية
استخدام نظام مختلف؟ Ghost هي منصة تدوين مفتوحة المصدر اكتسبت شعبية بين المطورين والمستخدمين العاديين منذ عام 201
استخدام نظام مختلف؟ WonderCMS هو ملف CMS مفتوح المصدر وسريع وصغير مكتوب بلغة PHP. يتم استضافة كود مصدر WonderCMS على جيثب. فيل هذا الدليل
Go (تُعرف أيضًا باسم Golang) هي لغة برمجة مكتوبة بشكل ثابت ومجمعة على شكل حرف C تم تطويرها بواسطة Google. جعلت البساطة وتعدد الاستخدامات ب
استخدام نظام مختلف؟ Directus 6.4 CMS هو نظام إدارة محتوى بلا محتوى قوي ومرن ومفتوح المصدر ومفتوح المصدر يوفر للمطورين
استخدام نظام مختلف؟ Lychee 3.1 Photo Album هو أداة إدارة صور بسيطة ومرنة ومجانية ومفتوحة المصدر تعمل على خادم VPS. يتم تثبيته
استخدام نظام مختلف؟ Fork هو CMS مفتوح المصدر مكتوب بلغة PHP. رمز مصدر فوركس مستضاف على جيثب. سيوضح لك هذا الدليل كيفية تثبيت Fork CM
استخدام نظام مختلف؟ RainLoop هو عميل بريد إلكتروني بسيط وحديث وسريع يعتمد على الويب. يتم استضافة كود مصدر RainLoop على جيثب. هذا الدليل سوف يظهر لك حو
استخدام نظام مختلف؟ PyroCMS هو CMS مفتوح المصدر مكتوب بلغة PHP. يتم استضافة شفرة مصدر PyroCMS على GitHub. في هذا الدليل تمشي جيدًا عبر الكل
استخدام نظام مختلف؟ مقدمة TaskBoard هي أداة مجانية ومفتوحة المصدر يمكن استخدامها لتتبع الأشياء التي تحتاج إلى إنجازها. أنه يوفر
استخدام نظام مختلف؟ TextPattern CMS 4.6.2 هو نظام إدارة محتوى بسيط ومرن ومجاني ومفتوح المصدر (CMS) يتيح لمصممي الويب
استخدام نظام مختلف؟ BookStack عبارة عن منصة بسيطة ذاتية الاستضافة لتنظيم المعلومات وتخزينها. BookStack مجاني تمامًا ومفتوح المصدر ، أ
استخدام نظام مختلف؟ Gitea هو نظام بديل مفتوح المصدر للتحكم في الإصدار يعمل بواسطة Git. Gitea هو مكتوب في Golang وهو
استخدام نظام مختلف؟ Couch CMS هو نظام إدارة محتوى (CMS) بسيط ومرن ومجاني ومفتوح يسمح لمصممي الويب بتصميم
استخدام نظام مختلف؟ MyBB هو برنامج منتدى مجاني ومفتوح المصدر وبديهي وقابل للتوسيع. يتم استضافة رمز مصدر MyBB على GitHub. هذا الدليل سوف يظهر
استخدام نظام مختلف؟ Microweber هو سحب مفتوح المصدر وإفلات CMS ومتجر عبر الإنترنت. يتم استضافة شفرة مصدر Microweber على GitHub. هذا الدليل سيظهر لك
استخدام نظام مختلف؟ Osclass هو مشروع مفتوح المصدر يسمح لك بإنشاء موقع مصنف بسهولة دون أي معرفة تقنية. مصدره
استخدام نظام مختلف؟ سيقوم HTMLDoc بتحليل مستندات Postcript (PDF 1.6) ديناميكيًا من النص التشعبي المكتوب بشكل صحيح (HTML 3.2). هذا سيسمح لك ر
نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول
يعرف الكثير منكم أن Switch سيصدر في مارس 2017 وميزاته الجديدة. بالنسبة لأولئك الذين لا يعرفون ، قمنا بإعداد قائمة بالميزات التي تجعل "التبديل" "أداة لا غنى عنها".
هل تنتظر عمالقة التكنولوجيا للوفاء بوعودهم؟ تحقق من ما تبقى دون تسليم.
اقرأ المدونة لمعرفة الطبقات المختلفة في بنية البيانات الضخمة ووظائفها بأبسط طريقة.
اقرأ هذا لمعرفة مدى انتشار الذكاء الاصطناعي بين الشركات الصغيرة وكيف أنه يزيد من احتمالات نموها ومنح منافسيها القدرة على التفوق.
لقد أصبح حل CAPTCHA صعبًا جدًا على المستخدمين في السنوات القليلة الماضية. هل ستكون قادرة على أن تظل فعالة في اكتشاف البريد العشوائي والروبوتات في المستقبل القريب؟
مع تطور العلم بمعدل سريع ، واستلام الكثير من جهودنا ، تزداد أيضًا مخاطر تعريض أنفسنا إلى تفرد غير قابل للتفسير. اقرأ ، ماذا يمكن أن يعني التفرد بالنسبة لنا.
ما هو التطبيب عن بعد والرعاية الصحية عن بعد وأثره على الأجيال القادمة؟ هل هو مكان جيد أم لا في حالة الوباء؟ اقرأ المدونة لتجد طريقة عرض!
ربما سمعت أن المتسللين يكسبون الكثير من المال ، لكن هل تساءلت يومًا كيف يجنون هذا النوع من المال؟ دعنا نناقش.
أصدرت Apple مؤخرًا macOS Catalina 10.15.4 تحديثًا تكميليًا لإصلاح المشكلات ولكن يبدو أن التحديث يتسبب في المزيد من المشكلات التي تؤدي إلى إنشاء أجهزة macOS. قراءة هذه المادة لمعرفة المزيد