Bygg ditt sociala nätverk med Diaspora på CentOS 7

Diaspora är ett integritetsmedvetet socialt nätverk med öppen källkod. I den här handledningen kommer du att lära dig hur du ställer in och konfigurerar en Diaspora-pod på CentOS 7.

Förutsättningar

  • En CentOS 7-serverinstans.
  • Om du kör en pod av medelstor storlek, bör din server ha åtminstone 512 MB RAM (+1 GB växlingsutrymme) och en anständig processor med flera kärnor.
  • En sudo- användare.

Installera förutsättningspaket

Först, ladda ner och installera den senaste EPEL-versionen.

sudo yum install epel-release

Installera nödvändiga paket.

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

Aktivera för redisatt starta när ditt system startar.

sudo systemctl enable redis
sudo systemctl start redis

Installera PostgreSQL

Diaspora stöder MySQL, MariaDB och PostgreSQL. I den här guiden kommer vi att använda PostgreSQL.

Installera PostgreSQL.

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

Aktivera PostgreSQL för att starta när ditt system startar.

sudo systemctl enable postgresql
sudo systemctl start postgresql

Anslut till PostgreSQL med postgresanvändaren.

sudo -u postgres psql

Skapa en Diaspora-användare.

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

Lägg till en dedikerad diasporanvändare

Detta är användarkontot som kommer att köra Diaspora.

sudo adduser --disabled-login diaspora

Byt till den nya användaren.

sudo  su - diaspora

Installera Ruby

Det finns flera sätt att installera Ruby. Vi kommer att använda för rbenvatt hantera miljön och versionerna.

Först måste du installera de paket som 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

Installera 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

Återanslut för att ladda om sökvägen.

exit
sudo su - diaspora

Installera ruby-buildplugin för rbenvatt kompilera Ruby.

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

Installera Ruby.

rbenv install 2.4.3
rbenv global 2.4.3

Konfigurera en e-postserver

Vi kommer att använda Postfix som ett SMTP-relä för att skicka e-postmeddelanden till användare. Se den här artikeln för att lära dig hur man installerar en enkel e-postserver, med Postfix som MTA, Dovecot som MDA och Sieve för att sortera post.

Installera och konfigurera Diaspora

Klona källkoden för Diaspora.

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

Kopiera exempeldatabaskonfigurationsfilen till den plats som krävs av Diaspora.

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

Öppna databaskonfigurationsfilen i en textredigerare för att redigera några av inställningarna.

nano config/database.yml

Ändra databasinställningarna så att de matchar PostgreSQL-användaren och lösenordet som du skapade tidigare.

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

Öppna Diaspora-konfigurationsfilen.

nano config/diaspora.yml

Du måste uppdatera några inställningar i den här filen för att Diaspora ska fungera korrekt.

  • url: Ställ in den offentliga webbadressen till din pod här.
  • certificate_authorities: Ta bort det inledande # för att avkommentera det.
  • rails_environment: Du måste ställa in detta på produktion.
  • require_ssl: Ställ in detta på false för att förhindra en omdirigering från http:// till https://.

Installera nödvändiga ädelstenar

Installera Bundle, Ruby bibliotekshanteraren.

gem install bundler
script/configure_bundler

Obs : Om du har fel angående din Ruby-version, redigera .ruby-versionoch lägg in din egen (här 2.4.3istället för 2.4).

Ställ in databas

Skapa och konfigurera databasen.

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

Förkompilera tillgångarna

Detta rake-kommando kommer att förkompilera tillgångarna.

RAILS_ENV=production bin/rake assets:precompile

Diaspora systemd tjänster

Det finns många sätt att hantera Diaspora som en tjänst. I den här handledningen kommer vi att använda Systemd.

Skapa först följande filer.

  • systemd targetfil:

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

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

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

Klistra in följande konfigurationstext för varje fil som du skapade tidigare.

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 servicefil:

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

[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

Aktivera starttjänster.

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

Starta om tjänsterna.

sudo systemctl restart diaspora.target

Se till att de fungerar korrekt.

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

Nginx omvänd proxy

Vi kommer att använda Nginx som en omvänd proxy för att tjäna statiska resurser.

Vi kommer att använda acme.sh för att få ett Let's Encrypt-certifikat.

Ladda ner acme.shkällkoden.

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

Generera ett 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

Installera Nginx.

sudo yum install nginx

Skapa en ny Nginx-konfigurationsfil för vår Diaspora-pod.

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

Fyll filen med följande innehåll.

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

Obs : byt example.comtill ditt eget registrerade domännamn.

När alla ändringar har slutförts, kontrollera konfigurationsfilen för eventuella fel.

sudo nginx -t

Starta om Nginx för att tillämpa ändringarna.

sudo systemctl restart nginx

Om du kör en brandvägg, kör följande kommandon för att tillåta HTTPoch HTTPStrafikera.

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

Om du nu besöker din Diaspora pods domännamn i din webbläsare ( https://example.com), kommer du till Diasporas välkomstsida.

Skapa en diasporanvändare

Klicka på länken i Start by creating an account.och fyll i detaljerna för att skapa en ny Diaspora-användare. Sedan kommer du att kunna se din användares hemsida och börja använda det sociala nätverket Diaspora.

När du har skapat ett konto, ge det administratörsrättigheter.

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

Du har nu tillgång till admin-instrumentpanelen.

https://example.com/admins/dashboard

Sidekiq

Sidekiq, som hanterar bearbetning av bakgrundsjobb, har ett webbgränssnitt tillgängligt på https://example.com/sidekiq. Podstatistiken finns tillgänglig på https://example.com/statistics.

Loggrotera

Vi kommer att använda för logrotateatt hantera diasporaloggar.

Skapa en ny logrotatefil för Diaspora.

nano /etc/logrotate/diaspora

Lägg sedan till följande rader.

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

Detta kommer att rotera loggarna varje vecka, komprimera dem och behålla dem i 52 veckor.

Uppdatera Diaspora

När det är dags att uppdatera Diaspora, följ dessa steg.

Uppgradera först installerade paket.

sudo yum update

Uppdatera Diaspora-källkoden med git.

su - diaspora
cd diaspora
git pull

Uppdatera ädelstenarna.

gem install bundler
bin/bundle --full-index

Migrera databasen och kompilera om tillgångarna.

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

Slutligen, starta om Diaspora.

systemctl restart diaspora.target

Installera Plesk på CentOS 7

Installera Plesk på CentOS 7

Använder du ett annat system? Plesk är en egen kontrollpanel för webbhotell som tillåter användare att administrera sina personliga och/eller klienters webbplatser, databaser

Hur man installerar Squid Proxy på CentOS

Hur man installerar Squid Proxy på CentOS

Squid är ett populärt, gratis Linux-program som låter dig skapa en webbproxy för vidarebefordran. I den här guiden ser du hur du installerar Squid på CentOS för att förvandla dig

Hur man installerar Lighttpd (LLMP Stack) på CentOS 6

Hur man installerar Lighttpd (LLMP Stack) på CentOS 6

Inledning Lighttpd är en apachegaffel som syftar till att vara mycket mindre resurskrävande. Den är lätt, därav namnet, och är ganska enkel att använda. Installera

Konfigurera statiskt nätverk och IPv6 på CentOS 7

Konfigurera statiskt nätverk och IPv6 på CentOS 7

VULTR har nyligen gjort ändringar på deras sida, och allt borde nu fungera bra direkt när NetworkManager är aktiverat. Om du vill inaktivera

Ändra Icinga2 för att använda Master/Client Model på CentOS 6 eller CentOS 7

Ändra Icinga2 för att använda Master/Client Model på CentOS 6 eller CentOS 7

Icinga2 är ett kraftfullt övervakningssystem, och när det används i en master-klient-modell kan det ersätta behovet av NRPE-baserade övervakningskontroller. Master-klienten

Hur man installerar Apache Cassandra 3.11.x på CentOS 7

Hur man installerar Apache Cassandra 3.11.x på CentOS 7

Använder du ett annat system? Apache Cassandra är ett gratis NoSQL-databashanteringssystem med öppen källkod som är designat för att ge skalbarhet, hög

Hur man installerar Microweber på CentOS 7

Hur man installerar Microweber på CentOS 7

Använder du ett annat system? Microweber är en öppen källkod för dra och släpp CMS och onlinebutik. Microweber källkod finns på GitHub. Denna guide kommer att visa dig

Hur man installerar Vanilla Forum på CentOS 7

Hur man installerar Vanilla Forum på CentOS 7

Använder du ett annat system? Vanilla forum är en open source forumapplikation skriven i PHP. Det är en helt anpassningsbar, enkel att använda och stöder externa

Hur man installerar Mattermost 4.1 på CentOS 7

Hur man installerar Mattermost 4.1 på CentOS 7

Använder du ett annat system? Mattermost är ett alternativ med öppen källkod, självvärd till meddelandetjänsten Slack SAAS. Med andra ord, med Mattermost, du ca

Skapa ett nätverk av Minecraft-servrar med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Skapa ett nätverk av Minecraft-servrar med BungeeCord på Debian 8, Debian 9 eller CentOS 7

Vad du behöver En Vultr VPS med minst 1 GB RAM. SSH-åtkomst (med root-/administrativa privilegier). Steg 1: Installera BungeeCord Först till kvarn

Låt oss kryptera på Plesk

Låt oss kryptera på Plesk

Plesks kontrollpanel har en mycket trevlig integration för Lets Encrypt. Lets Encrypt är en av de enda SSL-leverantörerna som ger ut certifikat fullständigt

Låter kryptera på cPanel

Låter kryptera på cPanel

Lets Encrypt är en certifikatmyndighet dedikerad till att tillhandahålla SSL-certifikat gratis. cPanel har byggt en snygg integration så att du och din klient

Hur man installerar Concrete5 på CentOS 7

Hur man installerar Concrete5 på CentOS 7

Använder du ett annat system? Concrete5 är ett CMS med öppen källkod som erbjuder många distinkta och användbara funktioner för att hjälpa redaktörer att producera innehåll enkelt och

Hur man installerar Review Board på CentOS 7

Hur man installerar Review Board på CentOS 7

Använder du ett annat system? Review Board är ett gratis och öppen källkodsverktyg för att granska källkod, dokumentation, bilder och många fler. Det är webbaserad mjukvara

Ställ in HTTP-autentisering med Nginx på CentOS 7

Ställ in HTTP-autentisering med Nginx på CentOS 7

I den här guiden lär du dig hur du ställer in HTTP-autentisering för en Nginx-webbserver som körs på CentOS 7. Krav För att komma igång behöver du

Hur man installerar YOURLS på CentOS 7

Hur man installerar YOURLS på CentOS 7

YOURLS (Your Own URL Shortener) är ett webbadressförkortnings- och dataanalysprogram med öppen källkod. I den här artikeln kommer vi att täcka installationsprocessen

Hur man installerar och konfigurerar ArangoDB på CentOS 7

Hur man installerar och konfigurerar ArangoDB på CentOS 7

Använder du ett annat system? Inledning ArangoDB är en NoSQL-databas med öppen källkod med en flexibel datamodell för dokument, grafer och nyckel-värden. Det är

Använda Etckeeper för versionskontroll av /etc

Använda Etckeeper för versionskontroll av /etc

Inledning Katalogen /etc/ spelar en avgörande roll för hur ett Linux-system fungerar. Anledningen till detta är att nästan varje systemkonfiguration

Varför ska du använda SSHFS? Hur man monterar ett fjärrfilsystem med SSHFS på CentOS 6

Varför ska du använda SSHFS? Hur man monterar ett fjärrfilsystem med SSHFS på CentOS 6

Många systemadministratörer hanterar stora mängder servrar. När filer behöver nås över olika servrar, logga in på var och en individuellt ca

Konfigurera en Half Life 2-server på CentOS 6

Konfigurera en Half Life 2-server på CentOS 6

Denna handledning kommer att täcka processen att installera en Half Life 2-spelserver på CentOS 6 System. Steg 1: Installera förutsättningarna För att ställa in ou

The Rise of Machines: Real World Applications of AI

The Rise of Machines: Real World Applications of AI

Artificiell intelligens är inte i framtiden, det är här i nuet I den här bloggen Läs hur Artificiell intelligens-applikationer har påverkat olika sektorer.

DDOS-attacker: En kort översikt

DDOS-attacker: En kort översikt

Är du också ett offer för DDOS-attacker och förvirrad över de förebyggande metoderna? Läs den här artikeln för att lösa dina frågor.

Har du någonsin undrat hur hackare tjänar pengar?

Har du någonsin undrat hur hackare tjänar pengar?

Du kanske har hört att hackare tjänar mycket pengar, men har du någonsin undrat hur de tjänar den typen av pengar? låt oss diskutera.

Revolutionerande uppfinningar från Google som gör ditt liv lätt.

Revolutionerande uppfinningar från Google som gör ditt liv lätt.

Vill du se revolutionerande uppfinningar av Google och hur dessa uppfinningar förändrade livet för varje människa idag? Läs sedan till bloggen för att se uppfinningar av Google.

Fredag ​​Essential: Vad hände med AI-drivna bilar?

Fredag ​​Essential: Vad hände med AI-drivna bilar?

Konceptet med att självkörande bilar ska ut på vägarna med hjälp av artificiell intelligens är en dröm vi har ett tag nu. Men trots flera löften finns de ingenstans att se. Läs den här bloggen för att lära dig mer...

Technological Singularity: A Distant Future of Human Civilization?

Technological Singularity: A Distant Future of Human Civilization?

När vetenskapen utvecklas i snabb takt och tar över en hel del av våra ansträngningar, ökar också riskerna för att utsätta oss för en oförklarlig singularitet. Läs, vad singularitet kan betyda för oss.

Utveckling av datalagring – Infographic

Utveckling av datalagring – Infographic

Lagringsmetoderna för data har utvecklats kan vara sedan födelsen av data. Den här bloggen tar upp utvecklingen av datalagring på basis av en infografik.

Funktioner för Big Data Reference Architecture Layers

Funktioner för Big Data Reference Architecture Layers

Läs bloggen för att känna till olika lager i Big Data Architecture och deras funktionaliteter på enklaste sätt.

6 fantastiska fördelar med att ha smarta hemenheter i våra liv

6 fantastiska fördelar med att ha smarta hemenheter i våra liv

I denna digitala värld har smarta hemenheter blivit en avgörande del av livet. Här är några fantastiska fördelar med smarta hemenheter om hur de gör vårt liv värt att leva och enklare.

macOS Catalina 10.15.4 tilläggsuppdatering orsakar fler problem än att lösa

macOS Catalina 10.15.4 tilläggsuppdatering orsakar fler problem än att lösa

Nyligen släppte Apple macOS Catalina 10.15.4, en tilläggsuppdatering för att åtgärda problem, men det verkar som om uppdateringen orsakar fler problem som leder till att mac-datorer blir murade. Läs den här artikeln för att lära dig mer