在Debian 9上使用Diaspora建立您的社交网络

Diaspora是一个具有隐私意识的开源社交网络。在本教程中,您将学习如何在Debian 9上设置和配置Diaspora pod。

先决条件

  • Debian 9服务器实例。
  • 运行一个普通大小的Pod,您的服务器至少应具有512MB的RAM(+ 1GB交换空间)和一个不错的多核CPU。
  • 一个sudo的用户。

安装必备软件包

首先,更新系统并安装必要的软件包。

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

安装PostgreSQL

Diaspora支持MySQL,MariaDB和PostgreSQL。在本指南中,我们将使用PostgreSQL。

安装PostgreSQL。

sudo apt-get install PostgreSQL-server

postgres用户连接到PostgreSQL 。

sudo -u postgres psql

创建一个Diaspora用户。

CREATE USER diaspora WITH CREATEDB PASSWORD '<password>';

添加一个专用的散居用户

这是将运行Diaspora的用户帐户。

sudo adduser --disabled-login diaspora

切换到新用户。

sudo  su - diaspora

安装Ruby

有几种安装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

我们将使用Exim4作为SMTP中继来向用户发送电子邮件。

安装和配置软件包。

sudo apt-get install exim4
sudo dpkg-reconfigure exim4-config

安装和配置Diaspora

克隆Diaspora的源代码。

cd ~
git clone -b master https://github.com/diaspora/diaspora.git
cd diaspora

将示例数据库配置文件复制到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

打开Diaspora配置文件。

nano config/diaspora.yml

您将需要更新此文件中的一些设置,Diaspora才能正常工作。

  • url:在此处将公开网址设置为您的广告连播。
  • certificate_authorities:删除导致#取消注释的引线。
  • rails_environment:您必须将此设置为production
  • require_ssl:设置此项false可防止重定向http://https://

安装必需的宝石

安装Ruby库管理器Bundle。

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

散居系统服务

有多种方法可以将Diaspora作为服务进行管理。在本教程中,我们将使用Systemd。

首先,创建以下文件。

  • 系统target文件:touch /etc/systemd/system/diaspora.target
  • 系统web服务文件:touch /etc/systemd/system/diaspora-web.service
  • 系统sidekiq服务文件: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反向代理

我们将使用Nginx作为反向代理来提供静态资源。

我们将使用acme.sh来获取Let's Encrypt证书。

下载acme.sh源代码。

git clone https://github.com/Neilpang/acme.sh.git

生成一个“让我们加密”证书。

./.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

为我们的Diaspora容器创建一个新的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.,然后填写详细信息以创建新的Diaspora用户。然后,您将能够查看用户的主页并开始使用Diaspora社交网络。

创建帐户后,为其授予管理员权限:。

Role.add_admin User.where(username: "your_username").first.person

您现在可以访问管理控制台。

https://example.com/admins/dashboard

Sidekiq

Sidekiq处理后台作业处理,在处有一个Web界面 https://example.com/sidekiq。可在上获得广告连播统计信息https://example.com/statistics

对数旋转

我们将logrotate用来管理Diaspora日志。

logrotate为Diaspora 创建一个新文件。

nano /etc/logrotate/diaspora

然后,添加以下行。

/home/diaspora/diaspora/log/*.log {
  notifempty
  copytruncate
  missingok
  compress
  weekly
  rotate 52
}

这将每周轮换一次日志,对其进行压缩,并将其保留52周。

更新侨民

当需要更新Diaspora时,请按照下列步骤操作。

首先,更新系统。

sudo apt-get update
sudo apt-get dist-upgrade

使用来更新Diaspora源代码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

最后,重新启动Diaspora。

systemctl restart diaspora.target

留下評論

在Arch Linux上使用Makepkg

在Arch Linux上使用Makepkg

在Arch Linux上使用Makepkg可以避免系统污染,确保仅安装必要的依赖关系。

如何在Ubuntu 16.04上安装OpenSIPS控制面板

如何在Ubuntu 16.04上安装OpenSIPS控制面板

快速学习如何在Ubuntu 16.04上安装OpenSIPS控制面板,为VoIP提供商提供支持的功能。

在Fedora 28上安装Akaunting

在Fedora 28上安装Akaunting

学习如何在Fedora 28上安装Akaunting,一款适合小型企业和自由职业者的开源会计软件。

如何在CentOS 7上安装Mailtrain新闻通讯应用程序

如何在CentOS 7上安装Mailtrain新闻通讯应用程序

使用其他系统?Mailtrain是一个基于Node.js和MySQL / MariaDB构建的开源自托管新闻通讯应用程序。

诊断Minecraft服务器延迟和低TPS

诊断Minecraft服务器延迟和低TPS

了解導致Minecraft延遲的原因和解決方案,包括優化伺服器性能和減少滯後的步驟。

AI 能否應對越來越多的勒索軟件攻擊?

AI 能否應對越來越多的勒索軟件攻擊?

勒索軟件攻擊呈上升趨勢,但人工智能能否幫助應對最新的計算機病毒?AI 是答案嗎?在這裡閱讀知道是 AI 布恩還是禍根

ReactOS:這是 Windows 的未來嗎?

ReactOS:這是 Windows 的未來嗎?

ReactOS,一個開源和免費的操作系統,這裡有最新版本。它能否滿足現代 Windows 用戶的需求並打倒微軟?讓我們更多地了解這種老式但更新的操作系統體驗。

通過 WhatsApp 桌面應用程序 24*7 保持聯繫

通過 WhatsApp 桌面應用程序 24*7 保持聯繫

Whatsapp 終於為 Mac 和 Windows 用戶推出了桌面應用程序。現在您可以輕鬆地從 Windows 或 Mac 訪問 Whatsapp。適用於 Windows 8+ 和 Mac OS 10.9+

人工智能如何將流程自動化提升到新的水平?

人工智能如何將流程自動化提升到新的水平?

閱讀本文以了解人工智能如何在小型公司中變得流行,以及它如何增加使它們成長並為競爭對手提供優勢的可能性。

macOS Catalina 10.15.4 補充更新引發的問題多於解決

macOS Catalina 10.15.4 補充更新引發的問題多於解決

最近,Apple 發布了 macOS Catalina 10.15.4 補充更新以修復問題,但似乎該更新引起了更多問題,導致 mac 機器變磚。閱讀這篇文章以了解更多信息