كيفية تثبيت وتكوين CyberPanel على خادم CentOS 7 الخاص بك
استخدام نظام مختلف؟ مقدمة تعد CyberPanel واحدة من أولى لوحات التحكم في السوق مفتوحة المصدر وتستخدم OpenLiteSpeed. ما هذا
Wiki.js هو تطبيق wiki مجاني ومفتوح المصدر ومبني على Node.js و MongoDB و Git و Markdown. تتم استضافة شفرة مصدر Wiki.js علنًا على Github . سيوضح لك هذا الدليل كيفية تثبيت Wiki.js على مثيل CentOS 7 Vultr الجديد باستخدام Node.js و MongoDB و PM2 و Nginx و Git و Acme.sh.
متطلبات تشغيل Wiki.js هي التالية:
A
/ AAAA
إعداد السجلاتتحقق من إصدار CentOS.
cat /etc/centos-release
# CentOS Linux release 7.5.1804 (Core)
قم بإنشاء non-root
حساب مستخدم جديد له 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 yum update -y
قم بتثبيت الحزم الضرورية لإنهاء هذا البرنامج التعليمي.
sudo yum install -y wget curl vim zip unzip bash-completion
قم بتعطيل SELinux وجدار الحماية.
sudo setenforce 0
sudo systemctl stop firewalld
sudo systemctl disable firewalld
قم بتمكين مستودع EPEL.
sudo rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
توفر مستودعات CentOS إصدارًا قديمًا جدًا من Git ، لذلك سنحتاج إلى إنشاء Git من المصدر.
قم بتثبيت Git من خلال بنائه من كود المصدر.
# Remove existing git package if installed:
sudo yum remove -y git
sudo yum groupinstall -y "Development Tools"
sudo yum install -y gettext-devel openssl-devel perl-CPAN perl-devel zlib-devel curl-devel
wget https://mirrors.edge.kernel.org/pub/software/scm/git/git-2.17.1.tar.gz && tar zxvf git-2.17.1.tar.gz
rm git-2.17.1.tar.gz
cd git-2.17.1
make configure
./configure
make prefix=/usr/local all
sudo make prefix=/usr/local install
cd ~
# Confirm this command returns /usr/local/bin/git:
which git
تحقق من الإصدار.
git --version
# git version 2.17.1
يتطلب Wiki.js Node.js 6.9.0 أو أحدث ، لذا سنحتاج أولاً إلى تثبيت Node.js.
قم بتثبيت Node.js عن طريق استخدام مستودع NodeSource YUM لـ Node.js.
curl --silent --location https://rpm.nodesource.com/setup_8.x | sudo bash -
sudo yum install -y nodejs
تحقق من إصدارات Node.js و NPM.
node -v && npm -v
# v8.11.2
# 5.6.0
يستخدم Wiki.js MongoDB كمحرك قاعدة بيانات. سنستخدم مستودعات MongoDB الرسمية ، والتي تحتوي على أحدث إصدارات MongoDB الرئيسية والثانوية.
قم بتثبيت MongoDB Community Edition.
sudo vim /etc/yum.repos.d/mongodb-org-3.6.repo
# Copy/paste this
[mongodb-org-3.6]
name=MongoDB Repository
baseurl=https://repo.mongodb.org/yum/redhat/$releasever/mongodb-org/3.6/x86_64/
gpgcheck=1
enabled=1
gpgkey=https://www.mongodb.org/static/pgp/server-3.6.asc
sudo yum install -y mongodb-org
التحقق من إصدار.
mongo --version | head -n 1 && mongod --version | head -n 1
# MongoDB shell version v3.6.5
# db version v3.6.5
قم بتمكين وبدء MongoDB.
sudo systemctl enable mongod.service
sudo systemctl start mongod.service
يوصى بشدة بوضع خادم ويب قياسي أمام Wiki.js. هذا يضمن لك استخدام ميزات مثل SSL ، والعديد من مواقع الويب ، والتخزين المؤقت والمزيد.
قم بتثبيت Nginx.
sudo vim /etc/yum.repos.d/nginx_mainline.repo
# Copy/paste this
[nginx]
name=nginx repo
baseurl=https://nginx.org/packages/mainline/centos/7/$basearch/
gpgcheck=1
enabled=1
wget https://nginx.org/keys/nginx_signing.key
sudo rpm --import nginx_signing.key
rm nginx_signing.key
sudo yum install -y nginx
التحقق من إصدار.
nginx -v
# nginx version: nginx/1.15.0
قم بتمكين Nginx وبدء تشغيله.
sudo systemctl enable nginx.service
sudo systemctl start nginx.service
تكوين Nginx كوكيل HTTP
أو HTTPS
عكس لـ 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 هو نص برمجي خالص لـ 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 ~
التحقق من إصدار.
/etc/letsencrypt/acme.sh --version
# v2.7.9
احصل على شهادات RSA و ECDSA لنطاقك / اسم المضيف.
# 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 تكوين نفسه كخدمة بدء تشغيل.
/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 كمدير العمليات الخاص به. يمكنك إعادة تشغيل نظام التشغيل الخاص بك مع sudo reboot
التأكد من أن Wiki.js يبدأ بعد إعادة التشغيل.
استخدام نظام مختلف؟ مقدمة تعد CyberPanel واحدة من أولى لوحات التحكم في السوق مفتوحة المصدر وتستخدم OpenLiteSpeed. ما هذا
أكتوبر هو نظام إدارة محتوى مفتوح المصدر يعتمد على Laravel PHP Framework. مع واجهة أنيقة وبنية وحدات موجزة
RockMongo هي أداة إدارة MongoDB على الويب تشبه أداة إدارة MySQL: phpMyAdmin. سيغطي هذا البرنامج التعليمي عملية التثبيت
Lets Chat هو تطبيق دردشة مفتوح المصدر مصمم لتوفير خدمة الرسائل ذاتية الاستضافة للفرق الصغيرة. يعتمد Lets Chat على NodeJS و MongoDB
استخدام نظام مختلف؟ Taiga هو تطبيق مجاني ومفتوح المصدر لإدارة المشاريع. على عكس أدوات إدارة المشاريع الأخرى ، يستخدم Taiga زيادة
استخدام نظام مختلف؟ المتطلبات الأساسية مثيل خادم Vultr CentOS 7. مستخدم sudo. الخطوة 1: تحديث النظام أولاً ، قم بتحديث خادم النظام الخاص بك إلى th
استخدام نظام مختلف؟ Netdata هي نجمة صاعدة في مجال مراقبة مقاييس النظام في الوقت الفعلي. مقارنة بالأدوات الأخرى من نفس النوع ، Netdata:
DreamFactory هو برنامج مفتوح المصدر يمكنه تحويل أي قاعدة بيانات إلى منصة RESTful API. يمكن نشر DreamFactory على منصات مختلفة. في ثي
استخدام نظام مختلف؟ في هذا البرنامج التعليمي ، سأشرح لك كيفية إعداد خادم Starbound على CentOS 7. المتطلبات الأساسية يجب أن تمتلك هذه اللعبة عليك
Go (تُعرف أيضًا باسم Golang) هي لغة برمجة مكتوبة بشكل ثابت ومجمعة على شكل حرف C تم تطويرها بواسطة Google. جعلت البساطة وتعدد الاستخدامات ب
Django هو إطار Python شائع لكتابة تطبيقات الويب. مع Django ، يمكنك بناء التطبيقات بشكل أسرع ، دون إعادة اختراع العجلة. إذا كنت تريد
مرحبًا بك في برنامج تعليمي Vultr آخر. هنا ، ستتعلم كيفية تثبيت خادم SAMP وتشغيله. تمت كتابة هذا الدليل الخاص بـ CentOS 6. المتطلبات الأساسية التي ستحتاج إليها
Revive Adserver هو نظام عرض إعلانات مجاني ومفتوح المصدر يمكن استخدامه لإدارة الإعلانات على مواقع الويب و / أو التطبيقات و / أو مشغلات الفيديو. في هذه المقالة ،
استخدام نظام مختلف؟ Elgg هو محرك تواصل اجتماعي مفتوح المصدر يسمح بإنشاء بيئات اجتماعية مثل الشبكات الاجتماعية في الحرم الجامعي
استخدام نظام مختلف؟ الشتات هو شبكة اجتماعية مفتوحة المصدر تدرك الخصوصية. في هذا البرنامج التعليمي ، ستتعلم كيفية إعداد وتكوين po Diaspora po
نظرة عامة تهدف هذه المقالة إلى مساعدتك في إنشاء مجموعة Kubernetes وتشغيلها باستخدام kubeadm في لمح البصر. سيقوم هذا الدليل بنشر خادمين في
استخدام نظام مختلف؟ مقدمة Sails.js هو إطار عمل MVC لـ Node.js ، مشابه لـ Ruby on Rails. يجعل لتطوير التطبيقات الحديثة ver
استخدام نظام مختلف؟ يمكن استخدام NGINX كخادم HTTP / HTTPS أو خادم وكيل عكسي أو خادم وكيل بريد أو موازن تحميل أو فاصل TLS أو ذاكرة تخزين مؤقت
استخدام نظام مختلف؟ dotCMS هو نظام إدارة محتوى من فئة مفتوحة المصدر مفتوح بلغة جافا. أنه يحتوي تقريبا على كل ميزة مطلوبة ر
مقدمة في هذا البرنامج التعليمي ، سيتم تثبيت PufferPanel على Vultr VPS. PufferPanel هي لوحة تحكم مفتوحة المصدر مجانية للاستخدام لإدارتك
نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول
يعرف الكثير منكم أن Switch سيصدر في مارس 2017 وميزاته الجديدة. بالنسبة لأولئك الذين لا يعرفون ، قمنا بإعداد قائمة بالميزات التي تجعل "التبديل" "أداة لا غنى عنها".
هل تنتظر عمالقة التكنولوجيا للوفاء بوعودهم؟ تحقق من ما تبقى دون تسليم.
اقرأ المدونة لمعرفة الطبقات المختلفة في بنية البيانات الضخمة ووظائفها بأبسط طريقة.
اقرأ هذا لمعرفة مدى انتشار الذكاء الاصطناعي بين الشركات الصغيرة وكيف أنه يزيد من احتمالات نموها ومنح منافسيها القدرة على التفوق.
لقد أصبح حل CAPTCHA صعبًا جدًا على المستخدمين في السنوات القليلة الماضية. هل ستكون قادرة على أن تظل فعالة في اكتشاف البريد العشوائي والروبوتات في المستقبل القريب؟
مع تطور العلم بمعدل سريع ، واستلام الكثير من جهودنا ، تزداد أيضًا مخاطر تعريض أنفسنا إلى تفرد غير قابل للتفسير. اقرأ ، ماذا يمكن أن يعني التفرد بالنسبة لنا.
ما هو التطبيب عن بعد والرعاية الصحية عن بعد وأثره على الأجيال القادمة؟ هل هو مكان جيد أم لا في حالة الوباء؟ اقرأ المدونة لتجد طريقة عرض!
ربما سمعت أن المتسللين يكسبون الكثير من المال ، لكن هل تساءلت يومًا كيف يجنون هذا النوع من المال؟ دعنا نناقش.
أصدرت Apple مؤخرًا macOS Catalina 10.15.4 تحديثًا تكميليًا لإصلاح المشكلات ولكن يبدو أن التحديث يتسبب في المزيد من المشكلات التي تؤدي إلى إنشاء أجهزة macOS. قراءة هذه المادة لمعرفة المزيد