Zgradite svoje socialno omrežje z diasporo na CentOS 7

Diaspora je odprtokodno socialno omrežje, ki se zaveda zasebnosti. V tej vadnici se boste naučili, kako nastaviti in konfigurirati podstavek Diaspora v CentOS 7.

Predpogoji

  • Primerek strežnika CentOS 7.
  • Če poganja povprečno velik pod, bi moral vaš strežnik imeti vsaj 512 MB RAM-a (+ 1 GB prostora za zamenjavo) in spodoben večjedrni CPU.
  • Uporabnik sudo .

Namestite predpogojne pakete

Najprej prenesite in namestite najnovejšo izdajo EPEL.

sudo yum install epel-release

Namestite potrebne pakete.

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

Omogoči rediszagon, ko se sistem zažene.

sudo systemctl enable redis
sudo systemctl start redis

Namestite PostgreSQL

Diaspora podpira MySQL, MariaDB in PostgreSQL. V tem priročniku bomo uporabljali PostgreSQL.

Namestite PostgreSQL.

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

Omogočite PostgreSQL, da se zažene, ko se sistem zažene.

sudo systemctl enable postgresql
sudo systemctl start postgresql

Povežite se s PostgreSQL z postgresuporabnikom.

sudo -u postgres psql

Ustvarite uporabnika diaspore.

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

Dodajte namenskega uporabnika diaspore

To je uporabniški račun, ki bo vodil Diaspora.

sudo adduser --disabled-login diaspora

Preklopite na novega uporabnika.

sudo  su - diaspora

Namesti Ruby

Ruby lahko namestite na več načinov. Uporabljali bomo rbenvza upravljanje okolja in različic.

Najprej boste morali namestiti pakete, ki jih zahteva Ruby.

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

Namesti 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

Ponovno se povežite, da znova naložite pot.

exit
sudo su - diaspora

Namestite ruby-buildvtičnik za rbenvprevajanje Rubyja.

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

Namesti Ruby.

rbenv install 2.4.3
rbenv global 2.4.3

Nastavite poštni strežnik

Postfix bomo uporabili kot SMTP rele za pošiljanje e-pošte uporabnikom. Oglejte si ta članek, če želite izvedeti, kako namestiti preprost poštni strežnik s Postfixom kot MTA, Dovecot kot MDA in Sieve za razvrščanje pošte.

Namestite in konfigurirajte Diaspora

Klonirajte izvorno kodo za Diaspora.

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

Kopirajte vzorčno konfiguracijsko datoteko baze podatkov na lokacijo, ki jo zahteva Diaspora.

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

Odprite konfiguracijsko datoteko baze podatkov v urejevalniku besedil, da uredite nekatere nastavitve.

nano config/database.yml

Spremenite nastavitve baze podatkov, da se ujemajo z uporabnikom in geslom PostgreSQL, ki ste ju ustvarili prej.

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

Odprite konfiguracijsko datoteko Diaspora.

nano config/diaspora.yml

Za pravilno delovanje Diaspora boste morali posodobiti nekaj nastavitev v tej datoteki.

  • url: tukaj nastavite javni obrnjen URL za vaš pod.
  • certificate_authorities: Odstranite začetni #, da ga razkomentirate.
  • rails_environment: To morate nastaviti na produkcijo.
  • require_ssl: Nastavite to na false, da preprečite preusmeritev s http:// na https://.

Namestite zahtevane dragulje

Namestite Bundle, upravitelja knjižnice Ruby.

gem install bundler
script/configure_bundler

Opomba : Če imate napake v zvezi z vašo različico Rubyja, uredite .ruby-versionin postavite svojo (tukaj 2.4.3namesto 2.4).

Setup Database

Ustvarite in konfigurirajte bazo podatkov.

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

Predhodno sestavite sredstva

Ta ukaz rake bo vnaprej prevedel sredstva.

RAILS_ENV=production bin/rake assets:precompile

Diaspora systemd storitve

Obstaja veliko načinov za upravljanje diaspore kot storitve. V tej vadnici bomo uporabljali Systemd.

Najprej ustvarite naslednje datoteke.

  • sistemska targetdatoteka:

    touch /etc/systemd/system/diaspora.target
    
  • sistemska webservisna datoteka:

    touch /etc/systemd/system/diaspora-web.service
    
  • sistemska sidekiqservisna datoteka:

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

Prilepite naslednje konfiguracijsko besedilo za vsako datoteko, ki ste jo ustvarili prej.

target mapa:

[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 servisna datoteka:

[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 servisna datoteka:

[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

Omogoči storitve zagona.

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

Znova zaženite storitve.

sudo systemctl restart diaspora.target

Prepričajte se, da pravilno delujejo.

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

Nginx Reverse Proxy

Nginx bomo uporabili kot povratni proxy za serviranje statičnih virov.

Za pridobitev certifikata Let's Encrypt bomo uporabili acme.sh.

Prenesite acme.shizvorno kodo.

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

Ustvarite potrdilo 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

Namestite Nginx.

sudo yum install nginx

Ustvarite novo konfiguracijsko datoteko Nginx za naš Diaspora pod.

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

Napolnite datoteko z naslednjo vsebino.

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

Opomba : spremenite example.comv lastno registrirano ime domene.

Ko so vse spremembe končane, preverite konfiguracijsko datoteko za morebitne napake.

sudo nginx -t

Znova zaženite Nginx, da uveljavite spremembe.

sudo systemctl restart nginx

Če uporabljate požarni zid, zaženite naslednje ukaze, da dovolite HTTPin HTTPSpromet.

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

Če zdaj v brskalniku obiščete ime domene vašega Diaspora pod ( https://example.com), boste dosegli pozdravno stran Diaspora.

Ustvarite uporabnika diaspore

Kliknite povezavo v Start by creating an account.in izpolnite podrobnosti, da ustvarite novega uporabnika diaspore. Nato si boste lahko ogledali domačo stran svojega uporabnika in začeli uporabljati socialno omrežje Diaspora.

Ko ustvarite račun, mu dodelite skrbniške pravice.

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

Zdaj imate dostop do skrbniške nadzorne plošče.

https://example.com/admins/dashboard

Sidekiq

Sidekiq, ki skrbi za obdelavo opravil v ozadju, ima spletni vmesnik na voljo na https://example.com/sidekiq. Statistika pod je na voljo na https://example.com/statistics.

Logrotirajte

Uporabljali bomo logrotateza upravljanje dnevnikov diaspore.

Ustvarite novo logrotatedatoteko za Diaspora.

nano /etc/logrotate/diaspora

Nato dodajte naslednje vrstice.

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

To bo tedensko vrtelo hlode, jih stisnilo in obdržalo 52 tednov.

Posodobite diasporo

Ko pride čas za posodobitev Diaspore, sledite tem korakom.

Najprej nadgradite nameščene pakete.

sudo yum update

Posodobite izvorno kodo Diaspore z git.

su - diaspora
cd diaspora
git pull

Posodobite dragulje.

gem install bundler
bin/bundle --full-index

Preselite bazo podatkov in ponovno prevedite sredstva.

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

Končno znova zaženite Diasporo.

systemctl restart diaspora.target

Namestite Plesk na CentOS 7

Namestite Plesk na CentOS 7

Uporaba drugega sistema? Plesk je lastniška nadzorna plošča spletnega gostitelja, ki uporabnikom omogoča upravljanje svojih osebnih in/ali strank spletnih mest, baz podatkov

Kako namestiti Squid Proxy na CentOS

Kako namestiti Squid Proxy na CentOS

Squid je priljubljen brezplačen program za Linux, ki vam omogoča ustvarjanje spletnega proxyja za posredovanje. V tem priročniku boste videli, kako namestiti Squid na CentOS, da vas obrne

Kako namestiti Lighttpd (LLMP Stack) na CentOS 6

Kako namestiti Lighttpd (LLMP Stack) na CentOS 6

Uvod Lighttpd je razdelek Apache, katerega namen je biti veliko manj intenziven vir. Je lahek, od tod tudi njegovo ime, in je precej preprost za uporabo. Namestite

Konfiguriranje statičnega omrežja in IPv6 na CentOS 7

Konfiguriranje statičnega omrežja in IPv6 na CentOS 7

VULTR je pred kratkim naredil spremembe na svoji strani in zdaj bi moralo vse delovati v redu iz škatle z omogočenim NetworkManagerjem. Če želite onemogočiti

Spreminjanje Icinga2 za uporabo modela Master/Client na CentOS 6 ali CentOS 7

Spreminjanje Icinga2 za uporabo modela Master/Client na CentOS 6 ali CentOS 7

Icinga2 je zmogljiv sistem za spremljanje in če se uporablja v modelu glavni-odjemalec, lahko nadomesti potrebo po nadzornih pregledih, ki temeljijo na NRPE. Glavni naročnik

Kako namestiti Apache Cassandra 3.11.x na CentOS 7

Kako namestiti Apache Cassandra 3.11.x na CentOS 7

Uporaba drugega sistema? Apache Cassandra je brezplačen in odprtokodni sistem za upravljanje baz podatkov NoSQL, ki je zasnovan tako, da zagotavlja razširljivost, visoko

Kako namestiti Microweber na CentOS 7

Kako namestiti Microweber na CentOS 7

Uporaba drugega sistema? Microweber je odprtokodna povleci in spusti CMS in spletna trgovina. Izvorna koda Microweber gostuje na GitHubu. Ta vodnik vam bo pokazal

Kako namestiti Mattermost 4.1 na CentOS 7

Kako namestiti Mattermost 4.1 na CentOS 7

Uporaba drugega sistema? Mattermost je odprtokodna alternativa sporočilni storitvi Slack SAAS, ki jo gosti sami. Z drugimi besedami, z Mattermostom si pribl

Ustvarjanje omrežja strežnikov Minecraft z BungeeCord na Debian 8, Debian 9 ali CentOS 7

Ustvarjanje omrežja strežnikov Minecraft z BungeeCord na Debian 8, Debian 9 ali CentOS 7

Kaj potrebujete Vultr VPS z vsaj 1 GB RAM-a. SSH dostop (z root/administrativnimi pravicami). 1. korak: Namestitev BungeeCord Najprej najprej

Omogočamo šifriranje na Plesku

Omogočamo šifriranje na Plesku

Nadzorna plošča Plesk ima zelo lepo integracijo za Lets Encrypt. Lets Encrypt je eden edinih ponudnikov SSL, ki izdaja potrdila v celoti

Namestite MariaDB 10 na CentOS 6

Namestite MariaDB 10 na CentOS 6

V času pisanja je MariaDB 10.1 razvojna različica MariaDB. Temelji na MariaDB 5.5 in vključuje funkcije, prenesene nazaj iz MySQL 5.6. Ther

Omogoča šifriranje na cPanelu

Omogoča šifriranje na cPanelu

Lets Encrypt je certifikacijski organ, ki je namenjen brezplačnemu zagotavljanju certifikatov SSL. cPanel je zgradil lepo integracijo za vas in vašo stranko

Kako namestiti Concrete5 na CentOS 7

Kako namestiti Concrete5 na CentOS 7

Uporaba drugega sistema? Concrete5 je odprtokodni CMS, ki ponuja številne značilne in uporabne funkcije za pomoč urednikom pri preprosti izdelavi vsebine.

Kako namestiti pregledno ploščo na CentOS 7

Kako namestiti pregledno ploščo na CentOS 7

Uporaba drugega sistema? Review Board je brezplačno in odprtokodno orodje za pregledovanje izvorne kode, dokumentacije, slik in še veliko več. Gre za spletno programsko opremo

Nastavite preverjanje pristnosti HTTP z Nginxom na CentOS 7

Nastavite preverjanje pristnosti HTTP z Nginxom na CentOS 7

V tem priročniku se boste naučili, kako nastaviti preverjanje pristnosti HTTP za spletni strežnik Nginx, ki deluje na CentOS 7. Zahteve Za začetek boste potrebovali

Kako namestiti YOURLS na CentOS 7

Kako namestiti YOURLS na CentOS 7

YOURLS (Your Own URL Shortener) je odprtokodna aplikacija za krajšanje URL-jev in analitiko podatkov. V tem članku bomo obravnavali postopek namestitve

Kako namestiti in konfigurirati ArangoDB na CentOS 7

Kako namestiti in konfigurirati ArangoDB na CentOS 7

Uporaba drugega sistema? Uvod ArangoDB je odprtokodna baza podatkov NoSQL s prilagodljivim podatkovnim modelom za dokumente, grafe in ključe-vrednosti. je

Uporaba Etckeeperja za nadzor različic /etc

Uporaba Etckeeperja za nadzor različic /etc

Uvod Imenik /etc/ igra ključno vlogo pri delovanju sistema Linux. Razlog za to je skoraj vsaka sistemska konfiguracija

Zakaj bi morali uporabljati SSHFS? Kako namestiti oddaljeni datotečni sistem s SSHFS na CentOS 6

Zakaj bi morali uporabljati SSHFS? Kako namestiti oddaljeni datotečni sistem s SSHFS na CentOS 6

Številni sistemski skrbniki upravljajo velike količine strežnikov. Ko je treba do datotek dostopati prek različnih strežnikov, se prijavite v vsakega posebej ca

Nastavitev strežnika Half Life 2 na CentOS 6

Nastavitev strežnika Half Life 2 na CentOS 6

Ta vadnica bo obravnavala postopek namestitve igralnega strežnika Half Life 2 na sistem CentOS 6. 1. korak: Namestitev predpogojev Za nastavitev ou

Vzpon strojev: aplikacije AI v resničnem svetu

Vzpon strojev: aplikacije AI v resničnem svetu

Umetna inteligenca ni v prihodnosti, tukaj je prav v sedanjosti. V tem blogu preberite, kako so aplikacije umetne inteligence vplivale na različne sektorje.

DDOS napadi: kratek pregled

DDOS napadi: kratek pregled

Ste tudi vi žrtev DDOS napadov in ste zmedeni glede načinov preprečevanja? Preberite ta članek, če želite rešiti svoja vprašanja.

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Ste se kdaj vprašali, kako hekerji zaslužijo denar?

Morda ste že slišali, da hekerji zaslužijo veliko denarja, a ste se kdaj vprašali, kako zaslužijo takšen denar? razpravljajmo.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Revolucionarni Googlovi izumi, ki vam bodo olajšali življenje.

Ali želite videti revolucionarne izume Googla in kako so ti izumi danes spremenili življenje vsakega človeka? Nato preberite v blogu in si oglejte Googlove izume.

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Friday Essential: Kaj se je zgodilo z avtomobili, ki jih poganja umetna inteligenca?

Koncept samovozečih avtomobilov, ki zapeljejo na ceste s pomočjo umetne inteligence, so sanje, ki jih imamo že nekaj časa. A kljub številnim obljubam jih ni nikjer. Preberite ta blog, če želite izvedeti več…

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Tehnološka singularnost: oddaljena prihodnost človeške civilizacije?

Ker se znanost hitro razvija in prevzame veliko naših prizadevanj, se povečuje tudi tveganje, da se podvržemo nerazložljivi singularnosti. Preberite, kaj bi za nas lahko pomenila singularnost.

Razvoj shranjevanja podatkov – Infografika

Razvoj shranjevanja podatkov – Infografika

Metode shranjevanja podatkov so se lahko razvijale od rojstva podatkov. Ta blog pokriva razvoj shranjevanja podatkov na podlagi infografike.

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Funkcionalnosti slojev referenčne arhitekture velikih podatkov

Preberite blog, če želite na najpreprostejši način spoznati različne plasti v arhitekturi velikih podatkov in njihove funkcionalnosti.

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

6 neverjetnih prednosti pametnih naprav za dom v našem življenju

V tem digitalno vodenem svetu so pametne naprave za dom postale ključni del življenja. Tukaj je nekaj neverjetnih prednosti pametnih naprav za dom o tem, kako naredijo naše življenje vredno življenja in poenostavijo.

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Posodobitev dodatka macOS Catalina 10.15.4 povzroča več težav kot jih rešuje

Pred kratkim je Apple izdal macOS Catalina 10.15.4 dopolnilno posodobitev za odpravo težav, vendar se zdi, da posodobitev povzroča več težav, ki vodijo do opečenja računalnikov Mac. Preberite ta članek, če želite izvedeti več