قم بإعداد NFS Share على دبيان
NFS هو نظام ملفات قائم على الشبكة يسمح لأجهزة الكمبيوتر بالوصول إلى الملفات عبر شبكة الكمبيوتر. يوضح هذا الدليل كيف يمكنك فضح المجلدات عبر NF
الشتات هو شبكة اجتماعية مفتوحة المصدر تدرك الخصوصية. في هذا البرنامج التعليمي ، ستتعلم كيفية إعداد وتكوين جراب الشتات على Debian 9.
أولاً ، قم بتحديث النظام وتثبيت الحزم اللازمة.
sudo apt-get update
sudo apt-get install build-essential libssl-dev libcurl4-openssl-dev libxml2-dev libxslt-dev imagemagick ghostscript curl libmagickwand-dev git libpq-dev redis-server nodejs
يدعم الشتات MySQL و MariaDB و PostgreSQL. في هذا الدليل ، سنستخدم PostgreSQL.
قم بتثبيت PostgreSQL.
sudo apt-get install PostgreSQL-server
اتصل بـ PostgreSQL مع postgres
المستخدم.
sudo -u postgres psql
إنشاء مستخدم في الشتات.
CREATE USER diaspora WITH CREATEDB PASSWORD '<password>';
هذا هو حساب المستخدم الذي سيقوم بتشغيل الشتات.
sudo adduser --disabled-login diaspora
التبديل إلى المستخدم الجديد.
sudo su - diaspora
هناك عدة طرق لتثبيت روبي. سنستخدم rbenv
لإدارة البيئة والإصدارات.
أولاً ، ستحتاج إلى تثبيت الحزم التي يتطلبها روبي.
sudo apt-get install autoconf bison build-essential libssl-dev libyaml-dev libreadline6-dev zlib1g-dev libncurses5-dev libffi-dev libgdbm3 libgdbm-dev
التثبيت rbenv
.
git clone https://github.com/rbenv/rbenv.git ~/.rbenv
cd ~/.rbenv && src/configure && make -C src
echo 'export PATH="$HOME/.rbenv/bin:$PATH"' >> ~/.bash_profile
echo 'eval "$(rbenv init -)"' >> ~/.bash_profile
أعد الاتصال لإعادة تحميل المسار.
exit
sudo su - diaspora
قم بتثبيت ruby-build
البرنامج المساعد rbenv
لتجميع روبي:
git clone https://github.com/rbenv/ruby-build.git ~/.rbenv/plugins/ruby-build
تثبيت روبي.
rbenv install 2.4.3
rbenv global 2.4.3
سنستخدم Exim4 كترحيل SMTP لإرسال رسائل بريد إلكتروني إلى المستخدمين.
قم بتثبيت وتكوين الحزمة.
sudo apt-get install exim4
sudo dpkg-reconfigure exim4-config
استنساخ كود المصدر للشتات.
cd ~
git clone -b master https://github.com/diaspora/diaspora.git
cd diaspora
انسخ ملف تهيئة قاعدة بيانات المثال إلى الموقع المطلوب من قبل الشتات.
cp config/database.yml.example config/database.yml
cp config/diaspora.yml.example config/diaspora.yml
افتح ملف تكوين قاعدة البيانات في محرر نصوص لتحرير بعض الإعدادات.
nano config/database.yml
قم بتغيير إعدادات قاعدة البيانات لمطابقة مستخدم PostgreSQL وكلمة المرور اللذين قمت بإنشائهما سابقًا.
postgresql: &postgresql
adapter: postgresql
host: localhost
port: 5432
username: diaspora
password: __password__
encoding: unicode
افتح ملف تكوين الشتات.
nano config/diaspora.yml
ستحتاج إلى تحديث بعض الإعدادات في هذا الملف لكي يعمل الشتات بشكل صحيح.
url
: اضبط عنوان URL المواجه للجمهور على جرابك هنا.certificate_authorities
: إزالة مما يؤدي #
إلى تعليقها.rails_environment
: يجب عليك تعيين هذا على production
.require_ssl
: اضبط هذا false
لمنع إعادة التوجيه من http://
إلى https://
.قم بتثبيت Bundle ، مدير مكتبة Ruby.
gem install bundler
script/configure_bundler
ملاحظة: إذا كانت لديك أخطاء تتعلق بنسخة Ruby ، فقم بتحريرها .ruby-version
ووضعها (هنا 2.4.3
بدلاً من 2.4
).
إنشاء وتكوين قاعدة البيانات.
RAILS_ENV=production bin/rake db:create db:migrate
سيقوم هذا الأمر بجمع الأصول.
RAILS_ENV=production bin/rake assets:precompile
هناك العديد من الطرق لإدارة الشتات كخدمة. في هذا البرنامج التعليمي ، سوف نستخدم Systemd.
أولاً ، قم بإنشاء الملفات التالية.
target
ملف systemd :touch /etc/systemd/system/diaspora.target
web
ملف خدمة systemd :touch /etc/systemd/system/diaspora-web.service
sidekiq
ملف خدمة systemd :touch /etc/systemd/system/diaspora-sidekiq.service
قم بلصق نص التكوين التالي لكل ملف قمت بإنشائه سابقًا.
target
ملف:
[Unit]
Description=Diaspora social network
Wants=postgresql.service
Wants=redis-server.service
After=redis-server.service
After=postgresql.service
[Install]
WantedBy=multi-user.target
web
ملف الخدمة:
[Unit]
Description=Diaspora social network (unicorn)
PartOf=diaspora.target
StopWhenUnneeded=true
[Service]
User=diaspora
Environment=RAILS_ENV=production
WorkingDirectory=/home/diaspora/diaspora
ExecStart=/bin/bash -lc "bin/bundle exec unicorn -c config/unicorn.rb -E production"
Restart=always
[Install]
WantedBy=diaspora.target
sidekiq
ملف الخدمة:
[Unit]
Description=Diaspora social network (sidekiq)
PartOf=diaspora.target
StopWhenUnneeded=true
[Service]
User=diaspora
Environment=RAILS_ENV=production
WorkingDirectory=/home/diaspora/diaspora
ExecStart=/bin/bash -lc "bin/bundle exec sidekiq"
Restart=always
[Install]
WantedBy=diaspora.target
تمكين خدمات التمهيد.
sudo systemctl enable diaspora.target diaspora-sidekiq.service diaspora-web.service
أعد تشغيل الخدمات.
sudo systemctl restart diaspora.target
تأكد من أنها تعمل بشكل صحيح.
sudo systemctl status diaspora-web.service
sudo systemctl status diaspora-sidekiq.service
سنستخدم Nginx كوكيل عكسي لخدمة الموارد الثابتة.
سنستخدم acme.sh للحصول على شهادة Let's Encrypt.
قم بتنزيل acme.sh
كود المصدر.
git clone https://github.com/Neilpang/acme.sh.git
إنشاء شهادة Let's Encrypt.
./.acme.sh/acme.sh --issue --log \
--dns \
--keylength ec-256 \
--cert-file /etc/nginx/https/cert.pem \
--key-file /etc/nginx/https/key.pem \
--fullchain-file /etc/nginx/https/fullchain.pem \
-d example.com \
-d www.example.com
قم بتثبيت Nginx.
sudo apt-get install nginx
قم بإنشاء ملف تكوين Nginx جديد للقرص الشتات الخاص بنا.
nano /etc/nginx/conf.d/diaspora.conf
تعبئة الملف بالمحتوى التالي.
upstream diaspora_server {
server unix:/home/diaspora/diaspora/tmp/diaspora.sock;
}
server {
listen 80;
listen [::]:80;
server_name www.example.com example.com;
return 301 https://example.com$request_uri;
access_log /dev/null;
error_log /dev/null;
}
server {
listen 443 ssl http2;
listen [::]:443 ssl http2;
server_name www.example.com example.com;
if ($host = www.example.com) {
return 301 https://example.com$request_uri;
}
access_log /var/log/nginx/dspr-access.log;
error_log /var/log/nginx/dspr-error.log;
ssl_certificate /etc/nginx/https/fullchain.pem;
ssl_certificate_key /etc/nginx/https/key.pem;
ssl_protocols TLSv1.2;
ssl_ciphers EECDH+CHACHA20:EECDH+AESGCM:EECDH+AES;
ssl_ecdh_curve X25519:P-521:P-384:P-256;
ssl_prefer_server_ciphers on;
ssl_stapling on;
ssl_stapling_verify on;
resolver 80.67.169.40 80.67.169.12 valid=300s;
resolver_timeout 5s;
ssl_session_cache shared:SSL:10m;
root /home/diaspora/diaspora/public;
client_max_body_size 5M;
client_body_buffer_size 256K;
try_files $uri @diaspora;
location /assets/ {
expires max;
add_header Cache-Control public;
}
location @diaspora {
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 https;
proxy_set_header Host $http_host;
proxy_redirect off;
proxy_pass http://diaspora_server;
}
}
ملاحظة: التغيير example.com
إلى اسم المجال المسجل الخاص بك.
بعد اكتمال جميع التعديلات ، تحقق من ملف التكوين بحثًا عن أي أخطاء.
sudo nginx -t
أعد تشغيل Nginx لتطبيق التغييرات.
sudo systemctl restart nginx
إذا قمت الآن بزيارة اسم نطاق Diaspora pod الخاص بك في المستعرض الخاص بك (مثال https://example.com
:) ، فستصل إلى صفحة ترحيب Diaspora.
انقر على الرابط Start by creating an account.
، واملأ التفاصيل لإنشاء مستخدم جديد في الشتات. بعد ذلك ، ستتمكن من عرض الصفحة الرئيسية للمستخدم والبدء في استخدام شبكة التواصل الاجتماعي في الشتات.
بعد إنشاء حساب ، امنحه حقوق المسؤول :.
Role.add_admin User.where(username: "your_username").first.person
لديك الآن حق الوصول إلى لوحة تحكم المشرف.
https://example.com/admins/dashboard
Sidekiq ، الذي يعالج معالجة مهام الخلفية ، لديه واجهة ويب متاحة على https://example.com/sidekiq
. احصائيات الجراب متوفرة في https://example.com/statistics
.
سنستخدم logrotate
لإدارة سجلات الشتات.
إنشاء logrotate
ملف جديد للشتات.
nano /etc/logrotate/diaspora
ثم أضف الأسطر التالية.
/home/diaspora/diaspora/log/*.log {
notifempty
copytruncate
missingok
compress
weekly
rotate 52
}
سيؤدي ذلك إلى تدوير السجلات أسبوعيًا وضغطها والاحتفاظ بها لمدة 52 أسبوعًا.
عندما يحين الوقت لتحديث الشتات ، اتبع هذه الخطوات.
أولاً ، قم بتحديث النظام.
sudo apt-get update
sudo apt-get dist-upgrade
قم بتحديث كود مصدر الشتات بواسطة git
.
su - diaspora
cd diaspora
git pull
تحديث الأحجار الكريمة.
gem install bundler
bin/bundle --full-index
ترحيل قاعدة البيانات وإعادة تجميع الأصول.
RAILS_ENV=production bin/rake db:migrate
RAILS_ENV=production bin/rake assets:precompile
أخيرًا ، أعد تشغيل الشتات.
systemctl restart diaspora.target
NFS هو نظام ملفات قائم على الشبكة يسمح لأجهزة الكمبيوتر بالوصول إلى الملفات عبر شبكة الكمبيوتر. يوضح هذا الدليل كيف يمكنك فضح المجلدات عبر NF
مقدمة: التأليف والإصدار الموزع على الويب (WebDAV) هو امتداد HTTP يوفر إطار عمل لإنشاء الملفات وتعديلها عن بُعد على
مقدمة يتميز MySQL بميزة رائعة تعرف باسم طرق العرض. المشاهدات هي استعلامات مخزنة. اعتبرها اسمًا مستعارًا لاستعلام طويل. في هذا الدليل ،
ستعلمك هذه المقالة كيفية إعداد سجن سريع على دبيان. أفترض أنك تستخدم Debian 7.x. إذا كنت تقوم بتشغيل دبيان 6 أو 8 ، فقد يعمل هذا ، ولكن
مقدمة طريقة سهلة لإعداد خادم VPN على دبيان هي PiVPN. PiVPN هو أداة تثبيت وغلاف لـ OpenVPN. يخلق أوامر بسيطة لك
استخدام نظام مختلف؟ Brotli هو طريقة ضغط جديدة مع نسبة ضغط أفضل من Gzip. يتم استضافة رمز المصدر الخاص به علانية على Github. ثي
استخدام نظام مختلف؟ Neos عبارة عن منصة تطبيق محتوى مع CMS وإطار تطبيق في جوهرها. سيوضح لك هذا الدليل كيفية التثبيت
مقدمة Cacti هي أدوات مراقبة ورسوم بيانية مفتوحة المصدر تعتمد بالكامل على بيانات RRD. من خلال Cacti ، يمكنك مراقبة أي نوع من أنواع الأجهزة تقريبًا
Go (تُعرف أيضًا باسم Golang) هي لغة برمجة مكتوبة بشكل ثابت ومجمعة على شكل حرف C تم تطويرها بواسطة Google. جعلت البساطة وتعدد الاستخدامات ب
استخدام نظام مختلف؟ InvoicePlane هو تطبيق فواتير مجاني ومفتوح المصدر. يمكن العثور على رمز المصدر الخاص به في مستودع Github هذا. هذا الدليل
استخدام نظام مختلف؟ Reader Self 3.5 هو قارئ RSS بسيط ومرن ومفتوح ومفتوح المصدر ومستضاف ذاتيًا وبديل Google Reader. القارئ سيل
استخدام نظام مختلف؟ BookStack عبارة عن نظام أساسي بسيط وسهل الاستخدام لتنظيم المعلومات وتخزينها. BookStack مجاني تمامًا ومفتوح
مقدمة FFmpeg هي أداة سطر أوامر مفتوحة المصدر لتشفير / فك تشفير الفيديو والصوت. ميزاته الرئيسية هي سرعة عالية وجودة وفيل صغير
استخدام نظام مختلف؟ TermRecord هو أداة بسيطة مفتوحة المصدر مكتوبة بلغة Python ، تسمح بحفظ الجلسات النهائية إلى مشاركة ذاتية سهلة المشاركة
استخدام نظام مختلف؟ Matomo (Piwik سابقًا) هو نظام أساسي مفتوح المصدر للتحليلات ، وهو بديل مفتوح لبرنامج Google Analytics. مصدر Matomo مستضاف
تقدم هذه المقالة ملخصًا موجزًا لأنظمة تشغيل الخادم المقدمة كنماذج على Vultr. CentOS CentOS هو إصدار مفتوح المصدر من RHEL (Re
استخدام نظام مختلف؟ X-Cart هي منصة تجارة إلكترونية مفتوحة المصدر مرنة للغاية مع الكثير من الميزات والتكاملات. كود مصدر X-Cart مضيف
Munin عبارة عن أداة مراقبة لمسح العمليات والموارد في جهازك وتقديم المعلومات في الرسوم البيانية من خلال واجهة الويب. استخدم ما يلي
استخدام نظام مختلف؟ Tiny Tiny RSS Reader هو قارئ ومجمّع أخبار مستوحى ذاتيًا ومفتوح المصدر ومستضاف على الويب (RSS / Atom) ، مصمم خصيصًا
مقدمة في هذا البرنامج التعليمي ، سنغطي عملية إضافة نطاق IP / شبكة فرعية كاملة إلى خادم Linux يعمل بنظام CentOS أو Debian أو Ubuntu. الموكيز
نظرة ثاقبة على 26 أسلوبًا لتحليل البيانات الضخمة: الجزء الأول
يعرف الكثير منكم أن Switch سيصدر في مارس 2017 وميزاته الجديدة. بالنسبة لأولئك الذين لا يعرفون ، قمنا بإعداد قائمة بالميزات التي تجعل "التبديل" "أداة لا غنى عنها".
هل تنتظر عمالقة التكنولوجيا للوفاء بوعودهم؟ تحقق من ما تبقى دون تسليم.
اقرأ المدونة لمعرفة الطبقات المختلفة في بنية البيانات الضخمة ووظائفها بأبسط طريقة.
اقرأ هذا لمعرفة مدى انتشار الذكاء الاصطناعي بين الشركات الصغيرة وكيف أنه يزيد من احتمالات نموها ومنح منافسيها القدرة على التفوق.
لقد أصبح حل CAPTCHA صعبًا جدًا على المستخدمين في السنوات القليلة الماضية. هل ستكون قادرة على أن تظل فعالة في اكتشاف البريد العشوائي والروبوتات في المستقبل القريب؟
مع تطور العلم بمعدل سريع ، واستلام الكثير من جهودنا ، تزداد أيضًا مخاطر تعريض أنفسنا إلى تفرد غير قابل للتفسير. اقرأ ، ماذا يمكن أن يعني التفرد بالنسبة لنا.
ما هو التطبيب عن بعد والرعاية الصحية عن بعد وأثره على الأجيال القادمة؟ هل هو مكان جيد أم لا في حالة الوباء؟ اقرأ المدونة لتجد طريقة عرض!
ربما سمعت أن المتسللين يكسبون الكثير من المال ، لكن هل تساءلت يومًا كيف يجنون هذا النوع من المال؟ دعنا نناقش.
أصدرت Apple مؤخرًا macOS Catalina 10.15.4 تحديثًا تكميليًا لإصلاح المشكلات ولكن يبدو أن التحديث يتسبب في المزيد من المشكلات التي تؤدي إلى إنشاء أجهزة macOS. قراءة هذه المادة لمعرفة المزيد