Opsæt Cacti på Debian Jessie
Introduktion Cacti er et open source overvågnings- og grafværktøj, som er fuldt baseret på RRD-data. Gennem Cacti kan du overvåge næsten enhver type enhed
Diaspora er et socialt netværk med åben kildekode, der er bevidst om privatlivets fred. I denne øvelse lærer du, hvordan du opsætter og konfigurerer en Diaspora-pod på Debian 9.
Først skal du opdatere systemet og installere de nødvendige pakker.
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
Diaspora understøtter MySQL, MariaDB og PostgreSQL. I denne guide vil vi bruge PostgreSQL.
Installer PostgreSQL.
sudo apt-get install PostgreSQL-server
Opret forbindelse til PostgreSQL med postgres
brugeren.
sudo -u postgres psql
Opret en diaspora-bruger.
CREATE USER diaspora WITH CREATEDB PASSWORD '<password>';
Dette er den brugerkonto, der vil køre Diaspora.
sudo adduser --disabled-login diaspora
Skift til den nye bruger.
sudo su - diaspora
Der er flere måder at installere Ruby på. Vi vil bruge rbenv
til at administrere miljøet og versionerne.
Først skal du installere de pakker, Ruby kræver.
sudo apt-get install autoconf bison build-essential libssl-dev libyaml-dev libreadline6-dev zlib1g-dev libncurses5-dev libffi-dev libgdbm3 libgdbm-dev
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-build
plugin til rbenv
at 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
Vi vil bruge Exim4 som et SMTP-relæ til at sende e-mails til brugere.
Installer og konfigurer pakken.
sudo apt-get install exim4
sudo dpkg-reconfigure exim4-config
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 #
ledningen for at fjerne kommentaren.rails_environment
: Du skal indstille dette til production
.require_ssl
: Indstil dette til for false
at forhindre en omdirigering fra http://
til https://
.Installer Bundle, Ruby-biblioteksadministratoren.
gem install bundler
script/configure_bundler
Bemærk: Hvis du har fejl vedrørende din Ruby-version, skal du redigere .ruby-version
og sætte din egen (her i 2.4.3
stedet for 2.4
).
Opret og konfigurer databasen.
RAILS_ENV=production bin/rake db:create db:migrate
Denne rake-kommando vil prækompilere aktiverne.
RAILS_ENV=production bin/rake assets:precompile
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.
target
fil:touch /etc/systemd/system/diaspora.target
web
service fil:touch /etc/systemd/system/diaspora-web.service
sidekiq
service 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
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.sh
kildekoden.
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 apt-get 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.com
til 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 nu besøger din Diaspora-pods domænenavn i din browser (eksempel: https://example.com
), kommer du til Diaspora-velkomstsiden.
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, 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
.
Vi vil bruge logrotate
til at administrere diaspora-logfiler.
Opret en ny logrotate
fil 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.
Når det er tid til at opdatere Diaspora, skal du følge disse trin.
Først skal du opdatere systemet.
sudo apt-get update
sudo apt-get dist-upgrade
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
Introduktion Cacti er et open source overvågnings- og grafværktøj, som er fuldt baseret på RRD-data. Gennem Cacti kan du overvåge næsten enhver type enhed
Bruger du et andet system? Denne vejledning viser dig, hvordan du installerer groupware iRedMail på en ny installation af Debian Wheezy. Du bør bruge en serve
Bruger du et andet system? Hvis du køber en Debian-server, bør du altid have de nyeste sikkerhedsrettelser og opdateringer, uanset om du sover eller ej
Denne vejledning forklarer, hvordan man opsætter en DNS-server ved hjælp af Bind9 på Debian eller Ubuntu. Gennem hele artiklen skal du erstatte dit-domænenavn.com i overensstemmelse hermed. Ved th
I denne artikel vil vi se, hvordan du kompilerer og installerer Nginx mainline fra de officielle kilder til Nginx med PageSpeed-modulet, som giver dig mulighed for at
Bruger du et andet system? Introduktion Kanboard er et gratis og open source projektstyringssoftwareprogram, som er designet til at lette og visualisere
Bruger du et andet system? Gitea er et alternativt open source, selvhostet versionskontrolsystem drevet af Git. Gitea er skrevet på Golang og er
Introduktion Lynis er et gratis, open source-systemrevisionsværktøj, der bruges af mange systemadministratorer til at verificere integriteten og hærde deres systemer. jeg
Bruger du et andet system? Thelia er et open source-værktøj til at skabe e-business-websteder og administrere onlineindhold skrevet i PHP. Thelia kildekode i
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
Golang er et programmeringssprog udviklet af Google. Takket være sin alsidighed, enkelhed og pålidelighed er Golang blevet en af de mest populære
Hvis du har glemt din MySQL root-adgangskode, kan du nulstille den ved at følge trinene i denne artikel. Processen er ret enkel og fungerer på disse
Der er tidspunkter, hvor vi skal dele filer, der skal kunne ses af Windows-klienter. Da Fuse-baserede systemer kun virker på Linux, må du godt introducere
I denne vejledning vil vi opsætte en Counter Strike: Source-spilserver på Debian 7. Disse kommandoer blev testet på Debian 7, men de burde også virke o
I denne vejledning lærer du, hvordan du opsætter en Unturned 2.2.5-server på en Vultr VPS, der kører Debian 8. Bemærk: Dette er en redigeret version af Unturned, der ikke
I denne vejledning lærer du, hvordan du installerer Cachet på Debian 8. Cachet er et kraftfuldt open source-statussidesystem. Installation Denne vejledning er i gang
Introduktion I denne skrive-up, gå godt igennem, hvordan du sikkerhedskopierer flere MySQL- eller MariaDB-databaser, der sidder på den samme maskine ved hjælp af et brugerdefineret bash-script
Denne artikel vil lære dig, hvordan du opsætter et chroot-fængsel på Debian. Jeg går ud fra, at du bruger Debian 7.x. Hvis du kører Debian 6 eller 8, kan dette virke, men
Bruger du et andet system? Reader Self 3.5 er en enkel og fleksibel, gratis og open source, selvhostet RSS-læser og Google Reader-alternativ. Læser Sel
Bruger du et andet system? Backdrop CMS 1.8.0 er et enkelt og fleksibelt, mobilvenligt, gratis og open source Content Management System (CMS), der giver os mulighed for
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.
Er du også et offer for DDOS-angreb og forvirret over forebyggelsesmetoderne? Læs denne artikel for at løse dine spørgsmål.
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.
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.
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...
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.
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.
Læs bloggen for at kende forskellige lag i Big Data-arkitekturen og deres funktionaliteter på den enkleste måde.
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.
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