Bygg ditt sosiale nettverk med Diaspora på CentOS 7

Diaspora er et personvernbevisst, åpen kildekode sosialt nettverk. I denne opplæringen lærer du hvordan du setter opp og konfigurerer en Diaspora-pod på CentOS 7.

Forutsetninger

  • En CentOS 7-serverforekomst.
  • Når du kjører en pod av gjennomsnittlig størrelse, bør serveren din ha minst 512 MB RAM (+1 GB bytteplass) og en anstendig multi-core CPU.
  • En sudo- bruker.

Installer forutsetningspakker

Først laster du ned og installer den nyeste EPEL-versjonen.

sudo yum install epel-release

Installer de nødvendige pakkene.

sudo yum install tar make automake gcc gcc-c++ git net-tools cmake libcurl-devel libxml2-devel libffi-devel libxslt-devel wget redis ImageMagick nodejs postgresql-devel

Aktiver for rediså starte når systemet starter.

sudo systemctl enable redis
sudo systemctl start redis

Installer PostgreSQL

Diaspora støtter MySQL, MariaDB og PostgreSQL. I denne veiledningen vil vi bruke PostgreSQL.

Installer PostgreSQL.

sudo yum install postgresql-server postgresql-contrib postgresql-setup initdb

Aktiver PostgreSQL for å starte når systemet starter opp.

sudo systemctl enable postgresql
sudo systemctl start postgresql

Koble til PostgreSQL med postgresbrukeren.

sudo -u postgres psql

Opprett en Diaspora-bruker.

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

Legg til en dedikert diasporabruker

Dette er brukerkontoen som skal kjøre Diaspora.

sudo adduser --disabled-login diaspora

Bytt til den nye brukeren.

sudo  su - diaspora

Installer Ruby

Det er flere måter å installere Ruby på. Vi vil bruke rbenvtil å administrere miljøet og versjonene.

Først må du installere pakkene Ruby krever.

sudo yum install -y git-core zlib zlib-devel gcc-c++ patch readline readline-devel libyaml-devel libffi-devel openssl-devel make bzip2 autoconf automake libtool bison curl sqlite-devel

Installer 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

Koble til på nytt for å laste banen på nytt.

exit
sudo su - diaspora

Installer ruby-buildplugin for rbenvå kompilere Ruby.

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

Installer Ruby.

rbenv install 2.4.3
rbenv global 2.4.3

Sett opp en e-postserver

Vi vil bruke Postfix som et SMTP-relé for å sende e-post til brukere. Se denne artikkelen for å lære hvordan du installerer en enkel e-postserver, med Postfix som MTA, Dovecot som MDA og Sieve for sortering av post.

Installer og konfigurer Diaspora

Klon kildekoden for Diaspora.

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

Kopier eksempeldatabasekonfigurasjonsfilen til plasseringen som kreves av Diaspora.

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

Åpne databasekonfigurasjonsfilen i et tekstredigeringsprogram for å redigere noen av innstillingene.

nano config/database.yml

Endre databaseinnstillingene slik at de samsvarer med PostgreSQL-brukeren og passordet du opprettet tidligere.

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

Åpne Diaspora-konfigurasjonsfilen.

nano config/diaspora.yml

Du må oppdatere noen få innstillinger i denne filen for at Diaspora skal fungere skikkelig.

  • url: Angi den offentlige nettadressen til poden din her.
  • certificate_authorities: Fjern innledende # for å fjerne kommentaren.
  • rails_environment: Du må sette dette til produksjon.
  • require_ssl: Sett dette til usann for å forhindre en omdirigering fra http:// til https://.

Installer nødvendige Gems

Installer Bundle, Ruby biblioteksjef.

gem install bundler
script/configure_bundler

Merk : Hvis du har feil angående Ruby-versjonen din, rediger .ruby-versionog legg inn din egen (her i 2.4.3stedet for 2.4).

Sett opp database

Opprett og konfigurer databasen.

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

Forhåndskompiler eiendelene

Denne rake-kommandoen vil forhåndskompilere eiendelene.

RAILS_ENV=production bin/rake assets:precompile

Diaspora systemd tjenester

Det er mange måter å administrere Diaspora som en tjeneste. I denne opplæringen vil vi bruke Systemd.

Lag først følgende filer.

  • systemd targetfil:

    touch /etc/systemd/system/diaspora.target
    
  • systemd webtjenestefil:

    touch /etc/systemd/system/diaspora-web.service
    
  • systemd sidekiqtjenestefil:

    touch /etc/systemd/system/diaspora-sidekiq.service
    

Lim inn følgende konfigurasjonstekst for hver fil du opprettet tidligere.

target fil:

[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 tjenestefil:

[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 tjenestefil:

[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

Aktiver oppstartstjenester.

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

Start tjenestene på nytt.

sudo systemctl restart diaspora.target

Sørg for at de fungerer som de skal.

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

Nginx omvendt proxy

Vi vil bruke Nginx som en omvendt proxy for å betjene statiske ressurser.

Vi vil bruke acme.sh for å få et Let's Encrypt-sertifikat.

Last ned acme.shkildekoden.

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

Generer et Let's Encrypt-sertifikat.

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

Installer Nginx.

sudo yum install nginx

Lag en ny Nginx-konfigurasjonsfil for vår Diaspora-pod.

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

Fyll filen med følgende innhold.

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

Merk : endre example.comtil ditt eget registrerte domenenavn.

Etter at alle modifikasjoner er fullført, sjekk konfigurasjonsfilen for eventuelle feil.

sudo nginx -t

Start Nginx på nytt for å bruke endringene.

sudo systemctl restart nginx

Hvis du kjører en brannmur, kjør følgende kommandoer for å tillate HTTPog HTTPStrafikkere.

sudo firewall-cmd --permanent --zone=public --add-service=http 
sudo firewall-cmd --permanent --zone=public --add-service=https
sudo firewall-cmd --reload

Hvis du nå besøker din Diaspora-pods domenenavn i nettleseren din ( https://example.com), kommer du til Diaspora-velkomstsiden.

Opprett en diasporabruker

Klikk på lenken i Start by creating an account., og fyll ut detaljene for å opprette en ny Diaspora-bruker. Deretter vil du kunne se brukerens hjemmeside og begynne å bruke det sosiale nettverket Diaspora.

Etter at du har opprettet en konto, gi den administratorrettigheter.

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

Du har nå tilgang til admin-dashbordet.

https://example.com/admins/dashboard

Sidekiq

Sidekiq, som håndterer bakgrunnsjobbbehandling, har et webgrensesnitt tilgjengelig på https://example.com/sidekiq. Podstatistikken er tilgjengelig på https://example.com/statistics.

Loggroter

Vi vil bruke logrotatetil å administrere Diaspora-logger.

Opprett en ny logrotatefil for Diaspora.

nano /etc/logrotate/diaspora

Deretter legger du til følgende linjer.

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

Dette vil rotere loggene ukentlig, komprimere dem og beholde dem i 52 uker.

Oppdater Diaspora

Når det er på tide å oppdatere Diaspora, følg disse trinnene.

Først oppgraderer du installerte pakker.

sudo yum update

Oppdater Diaspora-kildekoden med git.

su - diaspora
cd diaspora
git pull

Oppdater edelstenene.

gem install bundler
bin/bundle --full-index

Migrer databasen og kompiler ressursene på nytt.

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

Til slutt, start Diaspora på nytt.

systemctl restart diaspora.target

Installer Plesk på CentOS 7

Installer Plesk på CentOS 7

Bruker du et annet system? Plesk er et proprietært kontrollpanel for webverten som lar brukere administrere sine personlige og/eller klienters nettsteder, databaser

Slik installerer du Squid Proxy på CentOS

Slik installerer du Squid Proxy på CentOS

Squid er et populært, gratis Linux-program som lar deg lage en webproxy for videresending. I denne veiledningen vil du se hvordan du installerer Squid på CentOS for å gjøre deg om

Slik installerer du Lighttpd (LLMP Stack) på CentOS 6

Slik installerer du Lighttpd (LLMP Stack) på CentOS 6

Introduksjon Lighttpd er en apachegaffel som har som mål å være mye mindre ressurskrevende. Den er lett, derav navnet, og er ganske enkel å bruke. Installer

Konfigurering av statisk nettverk og IPv6 på CentOS 7

Konfigurering av statisk nettverk og IPv6 på CentOS 7

VULTR har nylig gjort endringer på sin side, og alt skal nå fungere bra ut av boksen med NetworkManager aktivert. Skulle du ønske å deaktivere

Endring av Icinga2 for å bruke hoved-/klientmodell på CentOS 6 eller CentOS 7

Endring av Icinga2 for å bruke hoved-/klientmodell på CentOS 6 eller CentOS 7

Icinga2 er et kraftig overvåkingssystem, og når det brukes i en master-klient-modell, kan det erstatte behovet for NRPE-baserte overvåkingskontroller. Mester-klienten

Slik installerer du Apache Cassandra 3.11.x på CentOS 7

Slik installerer du Apache Cassandra 3.11.x på CentOS 7

Bruker du et annet system? Apache Cassandra er et gratis og åpen kildekode NoSQL-databasebehandlingssystem som er designet for å gi skalerbarhet, høy

Slik installerer du Microweber på CentOS 7

Slik installerer du Microweber på CentOS 7

Bruker du et annet system? Microweber er en åpen kildekode dra og slipp CMS og nettbutikk. Microweber-kildekoden er vert på GitHub. Denne guiden vil vise deg

Hvordan installere Vanilla Forum på CentOS 7

Hvordan installere Vanilla Forum på CentOS 7

Bruker du et annet system? Vanilla forum er en åpen kildekode-forumapplikasjon skrevet i PHP. Det er en fullt tilpassbar, enkel å bruke og støtter ekstern

Slik installerer du Mattermost 4.1 på CentOS 7

Slik installerer du Mattermost 4.1 på CentOS 7

Bruker du et annet system? Mattermost er et åpen kildekode, selvdrevet alternativ til Slack SAAS-meldingstjenesten. Med andre ord, med Mattermost kan du ca

Opprette et nettverk av Minecraft-servere med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Opprette et nettverk av Minecraft-servere med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Hva du trenger En Vultr VPS med minst 1 GB RAM. SSH-tilgang (med root/administratorrettigheter). Trinn 1: Installere BungeeCord Først

La oss kryptere på Plesk

La oss kryptere på Plesk

Plesk-kontrollpanelet har en veldig fin integrasjon for Lets Encrypt. Lets Encrypt er en av de eneste SSL-leverandørene som gir ut sertifikater komplett

La oss kryptere på cPanel

La oss kryptere på cPanel

Lets Encrypt er en sertifiseringsinstans dedikert til å tilby SSL-sertifikater gratis. cPanel har bygget en ryddig integrasjon slik at du og din klient

Hvordan installere Concrete5 på CentOS 7

Hvordan installere Concrete5 på CentOS 7

Bruker du et annet system? Concrete5 er et åpen kildekode CMS som tilbyr mange karakteristiske og nyttige funksjoner for å hjelpe redaktører med å produsere innhold enkelt og

Slik installerer du Review Board på CentOS 7

Slik installerer du Review Board på CentOS 7

Bruker du et annet system? Review Board er et gratis og åpen kildekodeverktøy for gjennomgang av kildekode, dokumentasjon, bilder og mye mer. Det er nettbasert programvare

Sett opp HTTP-autentisering med Nginx på CentOS 7

Sett opp HTTP-autentisering med Nginx på CentOS 7

I denne veiledningen lærer du hvordan du setter opp HTTP-autentisering for en Nginx-webserver som kjører på CentOS 7. Krav For å komme i gang trenger du

Slik installerer du GoAccess på CentOS 7

Slik installerer du GoAccess på CentOS 7

Bruker du et annet system? GoAccess er en åpen kildekode-nettlogganalysator. Du kan bruke den til analyse av logger på sanntidsbasis i enten terminalen eller

Hvordan installere YOURLS på CentOS 7

Hvordan installere YOURLS på CentOS 7

YOURLS (Your Own URL Shortener) er en åpen kildekode-applikasjon for URL-forkorting og dataanalyse. I denne artikkelen vil vi dekke installasjonsprosessen

Hvordan installere og konfigurere ArangoDB på CentOS 7

Hvordan installere og konfigurere ArangoDB på CentOS 7

Bruker du et annet system? Introduksjon ArangoDB er en åpen kildekode NoSQL-database med en fleksibel datamodell for dokumenter, grafer og nøkkelverdier. Det er

Bruke Etckeeper for versjonskontroll av /etc

Bruke Etckeeper for versjonskontroll av /etc

Innledning /etc/-katalogen spiller en kritisk rolle i måten et Linux-system fungerer på. Grunnen til dette er fordi nesten alle systemkonfigurasjoner

Hvorfor bør du bruke SSHFS? Hvordan montere et eksternt filsystem med SSHFS på CentOS 6

Hvorfor bør du bruke SSHFS? Hvordan montere et eksternt filsystem med SSHFS på CentOS 6

Mange systemadministratorer administrerer store mengder servere. Når filer må åpnes på tvers av forskjellige servere, logger du på hver enkelt individuelt ca

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Kunstig intelligens er ikke i fremtiden, det er her akkurat i nåtiden I denne bloggen Les hvordan kunstig intelligens-applikasjoner har påvirket ulike sektorer.

DDOS-angrep: en kort oversikt

DDOS-angrep: en kort oversikt

Er du også et offer for DDOS-angrep og forvirret over forebyggingsmetodene? Les denne artikkelen for å løse spørsmålene dine.

Har du noen gang lurt på hvordan hackere tjener penger?

Har du noen gang lurt på hvordan hackere tjener penger?

Du har kanskje hørt at hackere tjener mye penger, men har du noen gang lurt på hvordan tjener de den slags penger? la oss diskutere.

Revolusjonerende oppfinnelser fra Google som vil gjøre livet ditt enkelt.

Revolusjonerende oppfinnelser fra Google som vil gjøre livet ditt enkelt.

Vil du se revolusjonerende oppfinnelser fra Google og hvordan disse oppfinnelsene forandret livet til alle mennesker i dag? Les deretter til bloggen for å se oppfinnelser fra Google.

Fredag ​​Essential: Hva skjedde med AI-drevne biler?

Fredag ​​Essential: Hva skjedde med AI-drevne biler?

Konseptet med selvkjørende biler som skal ut på veiene ved hjelp av kunstig intelligens er en drøm vi har hatt en stund nå. Men til tross for flere løfter, er de ingen steder å se. Les denne bloggen for å lære mer...

Teknologisk singularitet: en fjern fremtid for menneskelig sivilisasjon?

Teknologisk singularitet: en fjern fremtid for menneskelig sivilisasjon?

Ettersom vitenskapen utvikler seg raskt og tar over mye av innsatsen vår, øker også risikoen for å utsette oss for en uforklarlig singularitet. Les hva singularitet kan bety for oss.

Evolusjon av datalagring – infografikk

Evolusjon av datalagring – infografikk

Lagringsmetodene for dataene har vært i utvikling kan være siden fødselen av dataene. Denne bloggen dekker utviklingen av datalagring på grunnlag av en infografikk.

Funksjonaliteter til Big Data Reference Architecture Layers

Funksjonaliteter til Big Data Reference Architecture Layers

Les bloggen for å kjenne ulike lag i Big Data Architecture og deres funksjoner på den enkleste måten.

6 fantastiske fordeler ved å ha smarte hjemmeenheter i livene våre

6 fantastiske fordeler ved å ha smarte hjemmeenheter i livene våre

I denne digitaldrevne verden har smarthusenheter blitt en avgjørende del av livet. Her er noen fantastiske fordeler med smarthusenheter om hvordan de gjør livet vårt verdt å leve og enklere.

macOS Catalina 10.15.4 tilleggsoppdatering forårsaker flere problemer enn å løse

macOS Catalina 10.15.4 tilleggsoppdatering forårsaker flere problemer enn å løse

Nylig lanserte Apple macOS Catalina 10.15.4 en tilleggsoppdatering for å fikse problemer, men det ser ut til at oppdateringen forårsaker flere problemer som fører til muring av mac-maskiner. Les denne artikkelen for å lære mer