Byg dit sociale netværk med Diaspora på CentOS 7

Diaspora er et socialt netværk med åben kildekode, der er bevidst om privatlivets fred. I denne vejledning lærer du, hvordan du opsætter og konfigurerer en Diaspora-pod på CentOS 7.

Forudsætninger

  • En CentOS 7-serverinstans.
  • Når du kører en pod af gennemsnitlig størrelse, bør din server som minimum have 512 MB RAM (+1 GB swap-plads) og en anstændig multi-core CPU.
  • En sudo- bruger.

Installer forudsætningspakker

Først skal du downloade og installere den seneste EPEL-udgivelse.

sudo yum install epel-release

Installer de nødvendige pakker.

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 redisat starte, når dit system starter.

sudo systemctl enable redis
sudo systemctl start redis

Installer PostgreSQL

Diaspora understøtter MySQL, MariaDB og PostgreSQL. I denne guide vil vi bruge PostgreSQL.

Installer PostgreSQL.

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

Aktiver PostgreSQL for at starte, når dit system starter.

sudo systemctl enable postgresql
sudo systemctl start postgresql

Opret forbindelse til PostgreSQL med postgresbrugeren.

sudo -u postgres psql

Opret en diaspora-bruger.

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

Tilføj en dedikeret diasporabruger

Dette er den brugerkonto, der vil køre Diaspora.

sudo adduser --disabled-login diaspora

Skift til den nye bruger.

sudo  su - diaspora

Installer Ruby

Der er flere måder at installere Ruby på. Vi vil bruge rbenvtil at administrere miljøet og versionerne.

Først skal du installere de pakker, Ruby kræver.

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

Tilslut igen for at genindlæse stien.

exit
sudo su - diaspora

Installer ruby-buildplugin til rbenvat 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

Konfigurer en mailserver

Vi vil bruge Postfix som et SMTP-relæ til at sende e-mails til brugere. Se venligst denne artikel for at lære, hvordan man installerer en simpel mailserver med Postfix som MTA, Dovecot som MDA og Sieve til sortering af post.

Installer og konfigurer Diaspora

Klon kildekoden til Diaspora.

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

Kopier eksempeldatabasekonfigurationsfilen til den placering, der kræves af Diaspora.

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

Åbn databasekonfigurationsfilen i en teksteditor for at redigere nogle af indstillingerne.

nano config/database.yml

Skift databaseindstillingerne, så de matcher PostgreSQL-brugeren og adgangskoden, som du oprettede tidligere.

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

Åbn Diaspora-konfigurationsfilen.

nano config/diaspora.yml

Du skal opdatere nogle få indstillinger i denne fil for at Diaspora fungerer korrekt.

  • url: Indstil den offentlige webadresse til din pod her.
  • certificate_authorities: Fjern det indledende # for at fjerne kommentaren.
  • rails_environment: Du skal indstille dette til produktion.
  • require_ssl: Indstil dette til falsk for at forhindre en omdirigering fra http:// til https://.

Installer påkrævede ædelstene

Installer Bundle, Ruby-biblioteksadministratoren.

gem install bundler
script/configure_bundler

Bemærk : Hvis du har fejl vedrørende din Ruby-version, så rediger .ruby-versionog læg din egen (her i 2.4.3stedet for 2.4).

Opsætning af database

Opret og konfigurer databasen.

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

Forudkompilér aktiverne

Denne rake-kommando vil prækompilere aktiverne.

RAILS_ENV=production bin/rake assets:precompile

Diaspora systemd tjenester

Der er mange måder at administrere Diaspora som en service på. I denne tutorial vil vi bruge Systemd.

Først skal du oprette følgende filer.

  • systemd targetfil:

    touch /etc/systemd/system/diaspora.target
    
  • systemd webservice fil:

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

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

Indsæt følgende konfigurationstekst for hver fil, du oprettede 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 service fil:

[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 service fil:

[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 opstartstjenester.

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

Genstart tjenesterne.

sudo systemctl restart diaspora.target

Sørg for, at de kører korrekt.

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

Nginx omvendt proxy

Vi vil bruge Nginx som en omvendt proxy til at betjene statiske ressourcer.

Vi vil bruge acme.sh til at få et Let's Encrypt-certifikat.

Download acme.shkildekoden.

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

Generer et Let's Encrypt-certifikat.

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

Opret en ny Nginx-konfigurationsfil til vores Diaspora-pod.

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

Udfyld filen med følgende indhold.

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

Bemærk : skift example.comtil dit eget registrerede domænenavn.

Når alle ændringer er gennemført, skal du kontrollere konfigurationsfilen for eventuelle fejl.

sudo nginx -t

Genstart Nginx for at anvende ændringerne.

sudo systemctl restart nginx

Hvis du kører en firewall, skal du køre følgende kommandoer for at tillade HTTPog HTTPStrafik.

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

Hvis du nu besøger din Diaspora-pods domænenavn i din browser ( https://example.com), kommer du til Diaspora-velkomstsiden.

Opret en diasporabruger

Klik på linket i Start by creating an account., og udfyld detaljerne for at oprette en ny Diaspora-bruger. Derefter vil du være i stand til at se din brugers hjemmeside og begynde at bruge det sociale netværk Diaspora.

Når du har oprettet en konto, skal du give den administratorrettigheder.

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

Du har nu adgang til admin-dashboardet.

https://example.com/admins/dashboard

Sidekiq

Sidekiq, som håndterer baggrundsjobsbehandling, har en webgrænseflade tilgængelig på https://example.com/sidekiq. Pod-statistikken er tilgængelig på https://example.com/statistics.

Logroter

Vi vil bruge logrotatetil at administrere diaspora-logfiler.

Opret en ny logrotatefil til Diaspora.

nano /etc/logrotate/diaspora

Tilføj derefter følgende linjer.

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

Dette vil rotere logfilerne ugentligt, komprimere dem og opbevare dem i 52 uger.

Opdater Diaspora

Når det er tid til at opdatere Diaspora, skal du følge disse trin.

Først skal du opgradere installerede pakker.

sudo yum update

Opdater Diaspora-kildekoden med git.

su - diaspora
cd diaspora
git pull

Opdater ædelstenene.

gem install bundler
bin/bundle --full-index

Migrer databasen og kompiler aktiverne igen.

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

Til sidst genstart Diaspora.

systemctl restart diaspora.target

Installer Plesk på CentOS 7

Installer Plesk på CentOS 7

Bruger du et andet system? Plesk er et proprietært webhost kontrolpanel, der giver brugerne mulighed for at administrere deres personlige og/eller klienters websteder, databaser

Sådan installeres Squid Proxy på CentOS

Sådan installeres Squid Proxy på CentOS

Squid er et populært, gratis Linux-program, der giver dig mulighed for at oprette en webproxy til videresendelse. I denne vejledning vil du se, hvordan du installerer Squid på CentOS for at gøre dig

Sådan installeres Lighttpd (LLMP Stack) på CentOS 6

Sådan installeres Lighttpd (LLMP Stack) på CentOS 6

Introduktion Lighttpd er en forgrening af Apache, der sigter mod at være meget mindre ressourcekrævende. Den er let, deraf navnet, og den er ret enkel at bruge. Installer

Konfiguration af statisk netværk og IPv6 på CentOS 7

Konfiguration af statisk netværk og IPv6 på CentOS 7

VULTR har for nylig foretaget ændringer i deres ende, og alt skulle nu fungere fint ud af boksen med NetworkManager aktiveret. Skulle du ønske at deaktivere

Ændring af Icinga2 til at bruge Master/Client Model på CentOS 6 eller CentOS 7

Ændring af Icinga2 til at bruge Master/Client Model på CentOS 6 eller CentOS 7

Icinga2 er et kraftfuldt overvågningssystem, og når det bruges i en master-klient-model, kan det erstatte behovet for NRPE-baserede overvågningstjek. Mester-klienten

Sådan installeres Apache Cassandra 3.11.x på CentOS 7

Sådan installeres Apache Cassandra 3.11.x på CentOS 7

Bruger du et andet system? Apache Cassandra er et gratis og open source NoSQL-databasestyringssystem, der er designet til at give skalerbarhed, høj

Sådan installeres Microweber på CentOS 7

Sådan installeres Microweber på CentOS 7

Bruger du et andet system? Microweber er en open source træk og slip CMS og online shop. Microweber-kildekoden er hostet på GitHub. Denne guide vil vise dig

Sådan installeres Mattermost 4.1 på CentOS 7

Sådan installeres Mattermost 4.1 på CentOS 7

Bruger du et andet system? Mattermost er et open source, selvhostet alternativ til Slack SAAS-meddelelsestjenesten. Med andre ord, med Mattermost er du ca

Oprettelse af et netværk af Minecraft-servere med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Oprettelse af et netværk af Minecraft-servere med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Hvad skal du bruge En Vultr VPS med mindst 1 GB RAM. SSH-adgang (med root/administrative rettigheder). Trin 1: Installation af BungeeCord Første ting først

Lad os kryptere på Plesk

Lad os kryptere på Plesk

Plesk-kontrolpanelet har en meget flot integration til Lets Encrypt. Lets Encrypt er en af ​​de eneste SSL-udbydere, der udleverer certifikater komplet

Lader kryptere på cPanel

Lader kryptere på cPanel

Lets Encrypt er en certifikatmyndighed dedikeret til at levere SSL-certifikater gratis. cPanel har bygget en pæn integration, så du og din klient

Sådan installeres Concrete5 på CentOS 7

Sådan installeres Concrete5 på CentOS 7

Bruger du et andet system? Concrete5 er et open source CMS, som tilbyder mange karakteristiske og nyttige funktioner til at hjælpe redaktører med at producere indhold nemt og

Sådan installeres Review Board på CentOS 7

Sådan installeres Review Board på CentOS 7

Bruger du et andet system? Review Board er et gratis og open source-værktøj til gennemgang af kildekode, dokumentation, billeder og mange flere. Det er webbaseret software

Konfigurer HTTP-godkendelse med Nginx på CentOS 7

Konfigurer HTTP-godkendelse med Nginx på CentOS 7

I denne vejledning lærer du, hvordan du opsætter HTTP-godkendelse for en Nginx-webserver, der kører på CentOS 7. Krav For at komme i gang skal du bruge

Sådan installeres YOURLS på CentOS 7

Sådan installeres YOURLS på CentOS 7

YOURLS (Your Own URL Shortener) er en open source URL-forkortelse og dataanalyseapplikation. I denne artikel vil vi dække installationsprocessen

Sådan installeres og konfigureres ArangoDB på CentOS 7

Sådan installeres og konfigureres ArangoDB på CentOS 7

Bruger du et andet system? Introduktion ArangoDB er en open source NoSQL-database med en fleksibel datamodel for dokumenter, grafer og nøgleværdier. det er

Brug af Etckeeper til versionskontrol af /etc

Brug af Etckeeper til versionskontrol af /etc

Introduktion /etc/-biblioteket spiller en afgørende rolle i den måde et Linux-system fungerer på. Årsagen til dette er, at næsten alle systemkonfigurationer

Hvorfor skal du bruge SSHFS? Sådan monteres et eksternt filsystem med SSHFS på CentOS 6

Hvorfor skal du bruge SSHFS? Sådan monteres et eksternt filsystem med SSHFS på CentOS 6

Mange systemadministratorer administrerer store mængder servere. Når filer skal tilgås på tværs af forskellige servere, logges ind på hver enkelt individuelt ca

Opsætning af en Half Life 2-server på CentOS 6

Opsætning af en Half Life 2-server på CentOS 6

Denne vejledning vil dække processen med at installere en Half Life 2-spilserver på CentOS 6 System. Trin 1: Installation af forudsætninger For at opsætte ou

Sådan installeres Laravel GitScrum på CentOS 7

Sådan installeres Laravel GitScrum på CentOS 7

Laravel GitScrum eller GitScrum er et open source-produktivitetsværktøj designet til at hjælpe udviklingsteams med at implementere Scrum-metoden på en måde, der ligner t.

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 lige i nuet I denne blog Læs, hvordan kunstig intelligens-applikationer har påvirket forskellige sektorer.

DDOS-angreb: et kort overblik

DDOS-angreb: et kort overblik

Er du også et offer for DDOS-angreb og forvirret over forebyggelsesmetoderne? Læs denne artikel for at løse dine spørgsmål.

Har du nogensinde spekuleret på, hvordan tjener hackere penge?

Har du nogensinde spekuleret på, hvordan tjener hackere penge?

Du har måske hørt, at hackere tjener mange penge, men har du nogensinde spekuleret på, hvordan tjener de den slags penge? lad os diskutere.

Revolutionære opfindelser fra Google, der vil gøre dit liv lettere.

Revolutionære opfindelser fra Google, der vil gøre dit liv lettere.

Vil du se revolutionerende opfindelser fra Google, og hvordan disse opfindelser ændrede livet for ethvert menneske i dag? Læs derefter til bloggen for at se opfindelser fra Google.

Fredag ​​Essential: Hvad skete der med AI-drevne biler?

Fredag ​​Essential: Hvad skete der med AI-drevne biler?

Konceptet med selvkørende biler til at køre på vejene ved hjælp af kunstig intelligens er en drøm, vi har haft i et stykke tid nu. Men på trods af flere løfter er de ingen steder at se. Læs denne blog for at lære mere...

Teknologisk singularitet: En fjern fremtid for menneskelig civilisation?

Teknologisk singularitet: En fjern fremtid for menneskelig civilisation?

Efterhånden som videnskaben udvikler sig i et hurtigt tempo og overtager en stor del af vores indsats, stiger risikoen for at udsætte os selv for en uforklarlig Singularitet. Læs, hvad singularitet kunne betyde for os.

Udvikling af datalagring – Infografik

Udvikling af datalagring – Infografik

Opbevaringsmetoderne for dataene har været under udvikling, kan være siden fødslen af ​​dataene. Denne blog dækker udviklingen af ​​datalagring på basis af en infografik.

Funktioner af Big Data Reference Architecture Layers

Funktioner af Big Data Reference Architecture Layers

Læs bloggen for at kende forskellige lag i Big Data-arkitekturen og deres funktionaliteter på den enkleste måde.

6 fantastiske fordele ved at have smarte hjemmeenheder i vores liv

6 fantastiske fordele ved at have smarte hjemmeenheder i vores liv

I denne digitalt drevne verden er smarte hjemmeenheder blevet en afgørende del af livet. Her er et par fantastiske fordele ved smarte hjemmeenheder om, hvordan de gør vores liv værd at leve og enklere.

macOS Catalina 10.15.4-tillægsopdatering forårsager flere problemer end at løse

macOS Catalina 10.15.4-tillægsopdatering forårsager flere problemer end at løse

For nylig udgav Apple macOS Catalina 10.15.4 en supplerende opdatering for at løse problemer, men det ser ud til, at opdateringen forårsager flere problemer, hvilket fører til mursten af ​​mac-maskiner. Læs denne artikel for at lære mere