كيفية تثبيت Matomo Analytics على Fedora 28
استخدام نظام مختلف؟ Matomo (Piwik سابقًا) هو نظام أساسي مفتوح المصدر للتحليلات ، وهو بديل مفتوح لبرنامج Google Analytics. مصدر Matomo مستضاف
Wiki.js هو تطبيق wiki مجاني ومفتوح المصدر ومبني على Node.js و MongoDB و Git و Markdown. تتم استضافة شفرة مصدر Wiki.js علنًا على Github . سيوضح لك هذا الدليل كيفية تثبيت Wiki.js على مثيل Fedora 28 Vultr جديد باستخدام Node.js و MongoDB و PM2 و Nginx و Git و Acme.sh.
متطلبات تشغيل Wiki.js هي التالية:
A
/ AAAA
إعداد السجلاتتحقق من إصدار نظام التشغيل.
cat /etc/fedora-release
# Fedora release 28 (Twenty Eight)
قم بإنشاء حساب مستخدم جديد غير جذري مع وصول sudo وقم بالتبديل إليه.
useradd -c "John Doe" johndoe && passwd johndoe
usermod -aG wheel johndoe
su - johndoe
ملاحظة: استبدل johndoe
باسم المستخدم الخاص بك.
تأكد من أن نظامك محدث.
sudo dnf check-upgrade || sudo dnf upgrade -y
قم بإعداد المنطقة الزمنية.
timedatectl list-timezones
sudo timedatectl set-timezone 'Region/City'
قم بتثبيت الحزم المطلوبة والمفيدة.
sudo dnf install -y wget vim unzip bash-completion git
من أجل البساطة ، قم بتعطيل SELinux وجدار الحماية.
sudo setenforce 0
sudo systemctl stop firewalld
sudo systemctl disable firewalld
يتطلب Wiki.js Node.js 6.9.0 أو أحدث ، لذا سنحتاج أولاً إلى تثبيت Node.js.
تثبيت Node.js.
sudo dnf install -y nodejs
تحقق من إصدارات Node.js و npm.
node -v && npm -v
# v8.11.3
# 5.6.0
يستخدم Wiki.js MongoDB كمحرك قاعدة بيانات. وفقًا لذلك ، سنحتاج إلى تثبيت MongoDB على خادمنا.
قم بتثبيت MongoDB.
sudo dnf install -y mongodb mongodb-server
تحقق من إصدار MongoDB.
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
يمكن تشغيل Wiki.js بدون أي خادم ويب فعلي (مثل Nginx أو Apache). ومع ذلك ، يوصى بشدة بوضع خادم ويب قياسي أمام Wiki.js. هذا يضمن لك استخدام ميزات مثل SSL ، والعديد من مواقع الويب ، والتخزين المؤقت ، وغيرها. سنستخدم Nginx في هذا البرنامج التعليمي ، ولكن أي خادم آخر سيفعل ذلك ، ما عليك سوى تكوينه بشكل صحيح.
قم بتثبيت Nginx.
sudo dnf install -y nginx
التحقق من إصدار.
nginx -v
# nginx version: nginx/1.12.1
قم بتمكين Nginx وبدء تشغيله.
sudo systemctl enable nginx.service
sudo systemctl start nginx.service
قم بتهيئة Nginx باعتباره وكيل عكسي ( HTTP
أو HTTPS
إذا كنت تستخدم SSL) لتطبيق Wiki.js.
قم بتشغيله sudo vim /etc/nginx/conf.d/wiki.js.conf
وملؤه باستخدام التكوين الأساسي للخادم الوكيل العكسي أدناه.
server {
listen [::]:80;
listen 80;
server_name wiki.example.com;
root /usr/share/nginx/html;
charset utf-8;
client_max_body_size 50M;
location /.well-known/acme-challenge/ {
allow all;
}
location / {
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_pass http://127.0.0.1:3000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_next_upstream error timeout http_502 http_503 http_504;
}
}
الشيء الوحيد الذي تحتاج إلى تغييره في التكوين أعلاه هو server_name
التوجيه ، وربما proxy_pass
التوجيه إذا قررت تكوين منفذ آخر بخلاف 3000
. يستخدم Wiki.js المنفذ 3000
بشكل افتراضي.
تحقق من التكوين.
sudo nginx -t
إعادة تحميل Nginx.
sudo systemctl reload nginx.service
HTTPS
ليس من الضروري تأمين موقع wiki الخاص بك ، ولكن من الممارسات الجيدة تأمين حركة مرور موقعك. للحصول على شهادة SSL من Let's Encrypt ، سنستخدم عميل Acme.sh. Acme.sh هو برنامج shell unix خالص للحصول على شهادات SSL من Let's Encrypt بدون أي تبعيات. وهذا يجعله خفيفًا جدًا مقارنة ببعض عملاء بروتوكول ACME الآخرين الذين يتطلبون الكثير من التبعيات للتشغيل بنجاح.
تحميل وتثبيت 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 ~
تحقق من acme.sh
الإصدار.
/etc/letsencrypt/acme.sh --version
# v2.7.9
الحصول على شهادات RSA و ECDSA لـ wiki.example.com
.
# RSA 2048
sudo /etc/letsencrypt/acme.sh --issue --home /etc/letsencrypt -d wiki.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 wiki.example.com --webroot /usr/share/nginx/html --reloadcmd "sudo systemctl reload nginx.service" --accountemail [email protected] --ocsp-must-staple --keylength ec-256
بعد تشغيل الأوامر أعلاه ، ستكون الشهادات والمفاتيح الخاصة بك في:
/etc/letsencrypt/wiki.example.com
/etc/letsencrypt/wiki.example.com_ecc
ملاحظة : لا تنس أن تستبدل wiki.example.com
اسم المجال الخاص بك.
بعد الحصول على شهادات من Let's Encrypt ، نحتاج إلى تكوين Nginx للاستفادة منها.
تشغيل sudo vim /etc/nginx/conf.d/wiki.js.conf
مرة أخرى وتكوين Nginx HTTPS
كوكيل عكسي.
server {
listen [::]:443 ssl http2;
listen 443 ssl http2;
listen [::]:80;
listen 80;
server_name wiki.example.com;
root /usr/share/nginx/html;
charset utf-8;
client_max_body_size 50M;
location /.well-known/acme-challenge/ {
allow all;
}
# RSA
ssl_certificate /etc/letsencrypt/wiki.example.com/fullchain.cer;
ssl_certificate_key /etc/letsencrypt/wiki.example.com/wiki.example.com.key;
# ECDSA
ssl_certificate /etc/letsencrypt/wiki.example.com_ecc/fullchain.cer;
ssl_certificate_key /etc/letsencrypt/wiki.example.com_ecc/wiki.example.com.key;
location / {
proxy_set_header Host $http_host;
proxy_set_header X-Real-IP $remote_addr;
proxy_pass http://127.0.0.1:3000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_next_upstream error timeout http_502 http_503 http_504;
}
}
تحقق من التكوين.
sudo nginx -t
إعادة تحميل Nginx.
sudo systemctl reload nginx.service
قم بإنشاء مجلد جذر مستند فارغ ، حيث يجب تثبيت Wiki.js.
sudo mkdir -p /var/www/wiki.example.com
انتقل إلى مجلد جذر المستند.
cd /var/www/wiki.example.com
تغيير ملكية /var/www/wiki.example.com
المجلد إلى المستخدم johndoe
.
sudo chown -R johndoe:johndoe /var/www/wiki.example.com
من /var/www/wiki.example.com
المجلد ، قم بتشغيل الأمر التالي لتنزيل Wiki.js. وتثبيته
curl -sSo- https://wiki.js.org/install.sh | bash
يمكنك تشغيل الأمر التالي لعرض الإصدار المثبت حاليًا من Wiki.js.
node wiki --version
# 1.0.78
بمجرد اكتمال التثبيت ، ستتم مطالبتك بتشغيل معالج التكوين.
ابدأ تشغيل معالج التكوين عن طريق التشغيل.
node wiki configure
هذا وسوف يخطر لك للانتقال إلى http://localhost:3000
تكوين Wiki.js. إذا كان لديك Nginx أمام Wiki.js ، فهذا يعني أنه يمكنك فتح اسم المجال الخاص بك (على سبيل المثال http://wiki.example.com
) بدلاً من الذهاب إلى localhost
.
باستخدام متصفح الويب الخاص بك ، انتقل إلى http://wiki.example.com
واتبع التعليمات التي تظهر على الشاشة. يتم حفظ جميع الإعدادات التي تم إدخالها أثناء معالج التكوين في config.yml
الملف. سيبدأ معالج التكوين تلقائيًا بتشغيل Wiki.js.
افتراضيًا ، لن يبدأ تشغيل Wiki.js تلقائيًا بعد إعادة تشغيل النظام. لكي نبدأ التشغيل ، نحتاج إلى إعداد مدير عمليات PM2. يأتي PM2 مرفقًا بـ Wiki.js كوحدة NPM محلية ، لذلك لا نحتاج إلى تثبيت PM2 عالميًا.
اطلب من PM2 تكوين نفسه كخدمة بدء تشغيل عن طريق تشغيل:
/var/www/wiki.example.com/node_modules/pm2/bin/pm2 startup
أخيرًا ، احفظ تكوين PM2 الحالي عن طريق تشغيل الأمر: /var/www/wiki.example.com/node_modules/pm2/bin/pm2 save
يعمل مثيل Wiki.js الخاص بك كعملية خلفية ، باستخدام PM2 كمدير العمليات الخاص به.
استخدام نظام مختلف؟ Matomo (Piwik سابقًا) هو نظام أساسي مفتوح المصدر للتحليلات ، وهو بديل مفتوح لبرنامج Google Analytics. مصدر Matomo مستضاف
استخدام نظام مختلف؟ Omeka Classic 2.4 CMS هو نظام نشر رقمي مجاني ومفتوح المصدر ونظام إدارة المحتوى (CMS) لمشاركة الصور الرقمية
استخدام نظام مختلف؟ Ghost هي منصة تدوين مفتوحة المصدر اكتسبت شعبية بين المطورين والمستخدمين العاديين منذ عام 201
استخدام نظام مختلف؟ NodeBB هو منتدى قائم على Node.js. يستخدم مقابس الويب للتفاعل الفوري والإشعارات في الوقت الحقيقي. كود مصدر NodeBB i
استخدام نظام مختلف؟ 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. قراءة هذه المادة لمعرفة المزيد