Настройка NFS Share на Debian
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
Есть несколько способов установить Ruby. Мы будем использовать rbenv
для управления средой и версиями.
Во-первых, вам нужно будет установить пакеты, которые требует Ruby.
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
компиляции Ruby:
git clone https://github.com/rbenv/ruby-build.git ~/.rbenv/plugins/ruby-build
Установите Ruby.
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
Эта команда rake прекомпилирует ресурсы.
RAILS_ENV=production bin/rake assets:precompile
Есть много способов управлять диаспорой как сервисом. В этом уроке мы будем использовать Systemd.
Сначала создайте следующие файлы.
target
файл: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
Если вы сейчас откроете доменное имя вашего модуля диаспоры в своем браузере (пример:) https://example.com
, вы попадете на страницу приветствия диаспоры.
Нажмите на ссылку 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
При настройке нового сервера Linux рекомендуется обновить ядро системы и другие пакеты до последней стабильной версии. В этой статье
Введение В MySQL есть замечательная функция, известная как views. Представления хранятся запросы. Думайте о них как о псевдониме для длинного запроса. В этом руководстве
Эта статья научит вас, как настроить chroot-джейл в Debian. Я предполагаю, что вы используете Debian 7.x. Если вы используете Debian 6 или 8, это может сработать, но
Введение Простой способ настроить VPN-сервер в Debian - это PiVPN. PiVPN - это установщик и оболочка для OpenVPN. Это создает простые команды для вас т
Используете другую систему? Brotli - это новый метод сжатия с лучшей степенью сжатия, чем в Gzip. Его исходный код публично размещен на Github. Thi
Используете другую систему? Apache Cassandra - бесплатная система управления базами данных NoSQL с открытым исходным кодом, разработанная для обеспечения масштабируемости, высокой
Введение Lynis - это бесплатный инструмент для аудита системы с открытым исходным кодом, который используется многими системными администраторами для проверки целостности и защиты своих систем. я
Используете другую систему? InvoicePlane - это бесплатное приложение для выставления счетов с открытым исходным кодом. Его исходный код можно найти в этом хранилище Github. Этот гид
Использ��ете другую систему? Backdrop CMS 1.8.0 - это простая и гибкая, удобная для мобильных устройств, бесплатная система с открытым исходным кодом (CMS), которая позволяет нам
Используете другую систему? Plesk - это проприетарная панель управления веб-хостинга, которая позволяет пользователям управлять своими личными и / или клиентскими веб-сайтами, базами данных.
Используете другую систему? BookStack - это простая, удобная и простая в использовании платформа для организации и хранения информации. BookStack полностью бесплатен и открыт
Используете другую систему? Pagekit 1.0 CMS - это красивая, модульная, расширяемая и легкая, бесплатная и с открытым исходным кодом система управления контентом (CMS) с
Используете другую систему? Subrion 4.1 CMS - это мощная и гибкая система управления контентом с открытым исходным кодом (CMS), которая обеспечивает интуитивно понятный и понятный контент.
Введение Системы Linux поставляются с инструментами мониторинга по умолчанию, такими как top, df и du, которые помогают отслеживать процессы и дисковое пространство. Хотя часто они
Используете другую систему? Firefox Sync - это функция синхронизации браузера, которая позволяет вам делиться своими данными и предпочтениями (такими как закладки, история
Используете другую систему? Октябрь 1.0 CMS - это простая и надежная, бесплатная система управления контентом (CMS) с открытым исходным кодом, построенная на платформе Laravel.
Используете другую систему? X-Cart - чрезвычайно гибкая платформа электронной коммерции с открытым исходным кодом, обладающая множеством функций и интеграций. Исходный код X-Cart доступен
Munin - это инструмент для мониторинга процессов и ресурсов на вашем компьютере, который представляет информацию в виде графиков через веб-интерфейс. Используйте следующее
Используете другую систему? TLS 1.3 - это версия протокола безопасности транспортного уровня (TLS), который был опубликован в 2018 году в качестве предлагаемого стандарта в RFC 8446.
Изучение 26 методов анализа больших данных: часть 1
Многие из вас знают Switch, который выйдет в марте 2017 года, и его новые функции. Для тех, кто не знает, мы подготовили список функций, которые делают «Switch» обязательным гаджетом.
Вы ждете, когда технологические гиганты выполнят свои обещания? проверить, что осталось недоставленным.
Прочтите блог, чтобы узнать о различных уровнях архитектуры больших данных и их функциях самым простым способом.
Прочтите это, чтобы узнать, как искусственный интеллект становится популярным среди небольших компаний и как он увеличивает вероятность их роста и дает преимущество перед конкурентами.
CAPTCHA стало довольно сложно решать пользователям за последние несколько лет. Сможет ли он оставаться эффективным в обнаружении спама и ботов в ближайшем будущем?
По мере того, как наука развивается быстрыми темпами, принимая на себя большую часть наших усилий, также возрастает риск подвергнуться необъяснимой сингулярности. Прочтите, что может значить для нас необычность.
Что такое телемедицина, дистанционное здравоохранение и их влияние на будущее поколение? Это хорошее место или нет в ситуации пандемии? Прочтите блог, чтобы узнать мнение!
Возможно, вы слышали, что хакеры зарабатывают много денег, но задумывались ли вы когда-нибудь о том, как они зарабатывают такие деньги? Давайте обсудим.
Недавно Apple выпустила macOS Catalina 10.15.4, дополнительное обновление для исправления проблем, но похоже, что это обновление вызывает больше проблем, приводящих к поломке компьютеров Mac. Прочтите эту статью, чтобы узнать больше