Construa sua rede social com a diáspora no Debian 9

A diáspora é uma rede social de código aberto com privacidade. Neste tutorial, você aprenderá como instalar e configurar um pod da diáspora no Debian 9.

Pré-requisitos

  • Uma instância do servidor Debian 9.
  • Executando um pod de tamanho médio, seu servidor deve ter, no mínimo, 512 MB de RAM (+ 1 GB de espaço de troca) e uma CPU multi-core decente.
  • Um usuário sudo .

Instalar pacotes de pré-requisitos

Primeiro, atualize o sistema e instale os pacotes necessários.

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

Instale o PostgreSQL

A diáspora suporta MySQL, MariaDB e PostgreSQL. Neste guia, usaremos o PostgreSQL.

Instale o PostgreSQL.

sudo apt-get install PostgreSQL-server

Conecte-se ao PostgreSQL com o postgresusuário.

sudo -u postgres psql

Crie um usuário da diáspora.

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

Adicionar um usuário dedicado da diáspora

Esta é a conta de usuário que executará a diáspora.

sudo adduser --disabled-login diaspora

Mude para o novo usuário.

sudo  su - diaspora

Instale o Ruby

Existem várias maneiras de instalar o Ruby. Usaremos rbenvpara gerenciar o ambiente e as versões.

Primeiro, você precisará instalar os pacotes que o Ruby requer.

sudo apt-get install autoconf bison build-essential libssl-dev libyaml-dev libreadline6-dev zlib1g-dev libncurses5-dev libffi-dev libgdbm3 libgdbm-dev

Instale 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

Reconecte para recarregar o caminho.

exit
sudo su - diaspora

Instale o ruby-buildplugin para rbenvcompilar o Ruby:

git clone https://github.com/rbenv/ruby-build.git ~/.rbenv/plugins/ruby-build

Instale o Ruby.

rbenv install 2.4.3
rbenv global 2.4.3

Instale o Exim4

Usaremos o Exim4 como uma retransmissão SMTP para enviar e-mails aos usuários.

Instale e configure o pacote.

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

Instale e configure a diáspora

Clone o código fonte da diáspora.

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

Copie o arquivo de configuração do banco de dados de exemplo para o local requerido pela diáspora.

cp config/database.yml.example config/database.yml
cp config/diaspora.yml.example config/diaspora.yml

Abra o arquivo de configuração do banco de dados em um editor de texto para editar algumas das configurações.

nano config/database.yml

Altere as configurações do banco de dados para corresponder ao usuário e senha do PostgreSQL que você criou anteriormente.

postgresql: &postgresql
adapter: postgresql
host: localhost
port: 5432
username: diaspora
password: __password__
encoding: unicode

Abra o arquivo de configuração da diáspora.

nano config/diaspora.yml

Você precisará atualizar algumas configurações neste arquivo para que a diáspora funcione corretamente.

  • url: Defina aqui o URL voltado ao público.
  • certificate_authorities: Remova a guia #para descomentá-la.
  • rails_environment: Você deve definir isso para production.
  • require_ssl: Defina falsepara impedir um redirecionamento de http://para https://.

Instalar gemas necessárias

Instale o Bundle, o gerenciador de bibliotecas Ruby.

gem install bundler
script/configure_bundler

Nota: Se houver erros relacionados à sua versão do Ruby, edite .ruby-versione coloque a sua (aqui em 2.4.3vez de 2.4).

Configurar banco de dados

Crie e configure o banco de dados.

RAILS_ENV=production bin/rake db:create db:migrate

Pré-compile os ativos

Este comando rake pré-compila os ativos.

RAILS_ENV=production bin/rake assets:precompile

Serviços da diáspora systemd

Existem muitas maneiras de gerenciar a diáspora como um serviço. Neste tutorial, usaremos o Systemd.

Primeiro, crie os seguintes arquivos.

  • targetarquivo systemd :touch /etc/systemd/system/diaspora.target
  • webarquivo de serviço systemd :touch /etc/systemd/system/diaspora-web.service
  • sidekiqarquivo de serviço systemd :touch /etc/systemd/system/diaspora-sidekiq.service

Cole o seguinte texto de configuração para cada arquivo que você criou anteriormente.

target Arquivo:

[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 arquivo de serviço:

[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 arquivo de serviço:

[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

Ativar serviços de inicialização.

sudo systemctl enable diaspora.target diaspora-sidekiq.service diaspora-web.service

Reinicie os serviços.

sudo systemctl restart diaspora.target

Verifique se eles estão funcionando corretamente.

sudo systemctl status diaspora-web.service
sudo systemctl status diaspora-sidekiq.service

Nginx Reverse Proxy

Usaremos o Nginx como um proxy reverso para servir recursos estáticos.

Usaremos o acme.sh para obter um certificado Let's Encrypt.

Faça o download do acme.shcódigo fonte.

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

Gere um certificado 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

Instale o Nginx.

sudo apt-get install nginx

Crie um novo arquivo de configuração do Nginx para o nosso pod de diáspora.

nano /etc/nginx/conf.d/diaspora.conf

Preencha o arquivo com o seguinte conteúdo.

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;
  }
}

Nota: mude example.compara o seu próprio nome de domínio registrado.

Após todas as modificações terem sido concluídas, verifique se há erros no arquivo de configuração.

sudo nginx -t

Reinicie o Nginx para aplicar as alterações.

sudo systemctl restart nginx

Se você agora visitar o nome de domínio do seu pod de diáspora no navegador (exemplo https://example.com:), chegará à página de boas-vindas da diáspora.

Criar um usuário da diáspora

Clique no link Start by creating an account.e preencha os detalhes para criar um novo usuário da diáspora. Então, você poderá visualizar a página inicial do usuário e começar a usar a rede social da diáspora.

Depois de criar uma conta, conceda-lhe direitos de administrador :.

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

Agora você tem acesso ao painel do administrador.

https://example.com/admins/dashboard

Sidekiq

O Sidekiq, que lida com o processamento de trabalhos em segundo plano, tem uma interface da Web disponível em https://example.com/sidekiq. As estatísticas do pod estão disponíveis em https://example.com/statistics.

Logrotate

Usaremos logrotatepara gerenciar logs da diáspora.

Crie um novo logrotatearquivo para a diáspora.

nano /etc/logrotate/diaspora

Em seguida, adicione as seguintes linhas.

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

Isso irá girar os logs semanalmente, compactá-los e mantê-los por 52 semanas.

Atualizar diáspora

Quando chegar a hora de atualizar a diáspora, siga estas etapas.

Primeiro, atualize o sistema.

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

Atualize o código fonte da diáspora com git.

su - diaspora
cd diaspora
git pull

Atualize as gemas.

gem install bundler
bin/bundle --full-index

Migrar o banco de dados e recompilar os ativos.

RAILS_ENV=production bin/rake db:migrate
RAILS_ENV=production bin/rake assets:precompile

Finalmente, reinicie a diáspora.

systemctl restart diaspora.target


Leave a Comment

Configure sua própria rede privada com o OpenVPN

Configure sua própria rede privada com o OpenVPN

O Vultr oferece uma incrível conectividade de rede privada para servidores executando no mesmo local. Mas às vezes você quer dois servidores em países diferentes

Como instalar o Couch CMS 2.0 em um VPS Debian 9 LAMP

Como instalar o Couch CMS 2.0 em um VPS Debian 9 LAMP

Usando um sistema diferente? O Couch CMS é um sistema de gerenciamento de conteúdo (CMS) simples e flexível, gratuito e de código aberto que permite que os web designers

Como usar o Sudo no Debian, CentOS e FreeBSD

Como usar o Sudo no Debian, CentOS e FreeBSD

Usar um usuário sudo para acessar um servidor e executar comandos no nível raiz é uma prática muito comum entre o Linux e o Unix Systems Administrator. O uso de um sud

Configurando um Chroot no Debian

Configurando um Chroot no Debian

Este artigo ensinará como configurar uma prisão chroot no Debian. Presumo que você esteja usando o Debian 7.x. Se você estiver executando o Debian 6 ou 8, isso pode funcionar, mas

Como instalar o PiVPN no Debian

Como instalar o PiVPN no Debian

Introdução Uma maneira fácil de configurar um servidor VPN no Debian é com o PiVPN. PiVPN é um instalador e wrapper para o OpenVPN. Ele cria comandos simples para você t

Como instalar o Kanboard no Debian 9

Como instalar o Kanboard no Debian 9

Usando um sistema diferente? Introdução O Kanboard é um programa de software de gerenciamento de projetos gratuito e de código aberto, projetado para facilitar e visualizar

Como instalar o Neos CMS no Debian 9

Como instalar o Neos CMS no Debian 9

Usando um sistema diferente? Neos é uma plataforma de aplicativos de conteúdo com um CMS e uma estrutura de aplicativos em seu núcleo. Este guia mostra como instalar

Configurar cactos no Debian Jessie

Configurar cactos no Debian Jessie

Introdução O Cacti é uma ferramenta de monitoramento e gráfico de código aberto totalmente baseada em dados RRD. Através do Cacti, você pode monitorar quase qualquer tipo de dispositivo

Como instalar o Java 8 e o DCEVM no Debian 8 (Jessie)

Como instalar o Java 8 e o DCEVM no Debian 8 (Jessie)

Java é uma linguagem de programação independente de plataforma / máquina virtual. Neste tutorial, instalaremos a implementação OpenJDK do Java 8 em um Debian

Servidor HTTP Git com Nginx no Debian 8

Servidor HTTP Git com Nginx no Debian 8

O Git é um sistema de controle de versão (VCS) que permite o rastreamento de alterações no código. Neste tutorial, mostraremos a instalação de um servidor HTTP (S) Git, um

Como instalar o MyCLI no Linux (CentOS, Debian, Fedora e Ubuntu)

Como instalar o MyCLI no Linux (CentOS, Debian, Fedora e Ubuntu)

Introdução O MyCLI é um cliente de linha de comando para MySQL e MariaDB que permite concluir automaticamente e ajuda na sintaxe de seus comandos SQL. MyCL

Usando vistas MySQL no Debian 7

Usando vistas MySQL no Debian 7

Introdução O MySQL possui um ótimo recurso conhecido como views. As visualizações são consultas armazenadas. Pense neles como um alias para uma consulta longa. Neste guia,

Como instalar o Matomo Analytics no Debian 9

Como instalar o Matomo Analytics no Debian 9

Usando um sistema diferente? O Matomo (anteriormente Piwik) é uma plataforma de análise de código aberto, uma alternativa aberta ao Google Analytics. Fonte Matomo está hospedado o

Monitorar o status do servidor Debian com o Munin

Monitorar o status do servidor Debian com o Munin

Munin é uma ferramenta de monitoramento para pesquisar processos e recursos em sua máquina e apresenta as informações em gráficos através de uma interface da web. Use o seguinte

Como instalar o fórum NodeBB no Debian 9

Como instalar o fórum NodeBB no Debian 9

Usando um sistema diferente? O NodeBB é um fórum baseado no Node.js. Ele utiliza soquetes da web para interações instantâneas e notificações em tempo real. Código fonte do NodeBB i

Como configurar o Samba com armazenamento em bloco no Debian 9

Como configurar o Samba com armazenamento em bloco no Debian 9

O Samba é uma solução de código aberto que permite aos usuários configurar compartilhamentos de arquivos e impressão rápidos e seguros. Neste artigo, abordarei como configurar a sagacidade do Samba

Adicionar intervalo de endereços IP ao seu servidor (CentOS / Ubuntu / Debian)

Adicionar intervalo de endereços IP ao seu servidor (CentOS / Ubuntu / Debian)

Introdução Neste tutorial, abordaremos o processo de adicionar um intervalo / sub-rede IP inteiro a um servidor Linux executando o CentOS, Debian ou Ubuntu. O processo

Instale o Plesk no Debian 8 (Jessie)

Instale o Plesk no Debian 8 (Jessie)

Usando um sistema diferente? O Plesk é um painel de controle proprietário de host da web que permite que os usuários administrem seus sites pessoais e / ou clientes, bancos de dados

Como instalar o Koel no Debian 9

Como instalar o Koel no Debian 9

Usando um sistema diferente? O Koel é um aplicativo simples de transmissão de áudio pessoal baseado na Web, escrito em Vue no lado do cliente e Laravel no lado do servidor. Koe

Como implantar o Ghost v0.11 LTS no Debian 8

Como implantar o Ghost v0.11 LTS no Debian 8

Usando um sistema diferente? O Ghost é uma plataforma de blog de código aberto que vem ganhando popularidade entre desenvolvedores e usuários comuns desde a sua 201

A IA pode lutar contra o aumento do número de ataques de ransomware

A IA pode lutar contra o aumento do número de ataques de ransomware

Os ataques de ransomware estão aumentando, mas a IA pode ajudar a lidar com os vírus de computador mais recentes? AI é a resposta? Leia aqui para saber se é AI boone ou bane

ReactOS: Este é o futuro do Windows?

ReactOS: Este é o futuro do Windows?

ReactOS, um sistema operacional de código aberto e gratuito está aqui com a versão mais recente. Será que ela pode atender às necessidades dos usuários modernos do Windows e derrubar a Microsoft? Vamos descobrir mais sobre esse estilo antigo, mas uma experiência de sistema operacional mais recente.

Fique conectado por meio do aplicativo WhatsApp Desktop 24 * 7

Fique conectado por meio do aplicativo WhatsApp Desktop 24 * 7

O Whatsapp finalmente lançou o aplicativo Desktop para usuários de Mac e Windows. Agora você pode acessar o Whatsapp do Windows ou Mac facilmente. Disponível para Windows 8+ e Mac OS 10.9+

Como a IA pode levar a automação de processos ao próximo nível?

Como a IA pode levar a automação de processos ao próximo nível?

Leia isto para saber como a Inteligência Artificial está se tornando popular entre as empresas de pequena escala e como está aumentando as probabilidades de fazê-las crescer e dar vantagem a seus concorrentes.

A atualização do suplemento do macOS Catalina 10.15.4 está causando mais problemas do que resolvendo

A atualização do suplemento do macOS Catalina 10.15.4 está causando mais problemas do que resolvendo

Recentemente, a Apple lançou o macOS Catalina 10.15.4, uma atualização suplementar para corrigir problemas, mas parece que a atualização está causando mais problemas, levando ao bloqueio de máquinas mac. Leia este artigo para saber mais

13 Ferramentas de Extração de Dados Comerciais de Big Data

13 Ferramentas de Extração de Dados Comerciais de Big Data

13 Ferramentas de Extração de Dados Comerciais de Big Data

O que é um sistema de arquivos de registro no diário e como ele funciona?

O que é um sistema de arquivos de registro no diário e como ele funciona?

Nosso computador armazena todos os dados de uma maneira organizada conhecida como sistema de arquivos Journaling. É um método eficiente que permite ao computador pesquisar e exibir arquivos assim que você clicar em search.https: //wethegeek.com/? P = 94116 & preview = true

Singularidade tecnológica: um futuro distante da civilização humana?

Singularidade tecnológica: um futuro distante da civilização humana?

À medida que a ciência evolui em um ritmo rápido, assumindo muitos de nossos esforços, os riscos de nos sujeitarmos a uma singularidade inexplicável também aumentam. Leia, o que a singularidade pode significar para nós.

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

Uma visão sobre 26 técnicas analíticas de Big Data: Parte 1

O impacto da inteligência artificial na saúde 2021

O impacto da inteligência artificial na saúde 2021

A IA na área da saúde deu grandes saltos nas últimas décadas. Portanto, o futuro da IA ​​na área da saúde ainda está crescendo dia a dia.