Debian 9da Diaspora ile Sosyal Ağınızı Kurun

Diaspora gizliliğe duyarlı, açık kaynaklı bir sosyal ağdır. Bu derste, Debian 9 üzerinde bir Diaspora bölmesinin nasıl kurulacağını ve yapılandırılacağını öğreneceksiniz.

Ön şartlar

  • Debian 9 sunucu örneği.
  • Ortalama boyutlu bir kapsül çalıştırırken, sunucunuzda en azından 512MB RAM (+ 1GB takas alanı) ve iyi bir çok çekirdekli CPU bulunmalıdır.
  • Bir sudo kullanıcısı.

Önkoşul Paketlerini Kurma

Önce sistemi güncelleyin ve gerekli paketleri yükleyin.

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

PostgreSQL'i yükleyin

Diaspora MySQL, MariaDB ve PostgreSQL'i desteklemektedir. Bu kılavuzda PostgreSQL kullanacağız.

PostgreSQL'i yükleyin.

sudo apt-get install PostgreSQL-server

PostgreSQL'e postgreskullanıcı ile bağlanın .

sudo -u postgres psql

Bir Diaspora kullanıcısı oluşturun.

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

Dedicated Diaspora Kullanıcısı Ekleme

Bu Diaspora çalıştıracak kullanıcı hesabı.

sudo adduser --disabled-login diaspora

Yeni kullanıcıya geç.

sudo  su - diaspora

Ruby'yi yükle

Ruby'yi kurmanın birkaç yolu vardır. rbenvÇevreyi ve sürümleri yönetmek için kullanacağız .

İlk olarak, Ruby'nin gerektirdiği paketleri kurmanız gerekecek.

sudo apt-get install autoconf bison build-essential libssl-dev libyaml-dev libreadline6-dev zlib1g-dev libncurses5-dev libffi-dev libgdbm3 libgdbm-dev

Yükleyin 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

Yolu yeniden yüklemek için yeniden bağlanın.

exit
sudo su - diaspora

Ruby'i derlemek için ruby-buildeklentiyi yükleyin rbenv:

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

Ruby'yi yükleyin.

rbenv install 2.4.3
rbenv global 2.4.3

Exim4'ü yükle

Kullanıcılara e-posta göndermek için Exim4'ü SMTP geçişi olarak kullanacağız.

Paketi kurun ve yapılandırın.

sudo apt-get install exim4
sudo dpkg-reconfigure exim4-config

Diaspora'yı kurun ve yapılandırın

Diasporanın kaynak kodunu kopyalayın.

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

Örnek veritabanı yapılandırma dosyasını Diaspora tarafından istenen konuma kopyalayın.

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

Bazı ayarları düzenlemek için veritabanı yapılandırma dosyasını bir metin düzenleyicide açın.

nano config/database.yml

Veritabanı ayarlarını, daha önce oluşturduğunuz PostgreSQL kullanıcısı ve parolasıyla eşleşecek şekilde değiştirin.

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

Diaspora yapılandırma dosyasını açın.

nano config/diaspora.yml

Diasporanın düzgün çalışması için bu dosyadaki birkaç ayarı güncellemeniz gerekir.

  • url: Herkese açık URL'yi bölgenize buradan ayarlayın.
  • certificate_authorities: #Başlığı kaldırmak için çıkarın .
  • rails_environment: Bunu olarak ayarlamanız gerekir production.
  • require_ssl: Bu ayarla falsebir yönlendirmeyi engellemek için http://için https://.

Gerekli Mücevherleri Yükleyin

Ruby kütüphane yöneticisi olan Bundle'yı yükleyin.

gem install bundler
script/configure_bundler

Not: Ruby sürümünüzle ilgili hatalarınız varsa .ruby-version, kendi sürümünüzü düzenleyin ve koyun ( 2.4.3yerine 2.4).

Veritabanı Kur

Veritaban��nı oluşturun ve yapılandırın.

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

Varlıkları önceden derleyin

Bu komisyon komutu varlıkları önceden derleyecektir.

RAILS_ENV=production bin/rake assets:precompile

Diaspora systemd Hizmetleri

Diasporayı bir hizmet olarak yönetmenin birçok yolu vardır. Bu derste Systemd kullanacağız.

İlk olarak, aşağıdaki dosyaları oluşturun.

  • systemd targetdosyası:touch /etc/systemd/system/diaspora.target
  • systemd webhizmet dosyası:touch /etc/systemd/system/diaspora-web.service
  • systemd sidekiqhizmet dosyası:touch /etc/systemd/system/diaspora-sidekiq.service

Daha önce oluşturduğunuz her dosya için aşağıdaki yapılandırma metnini yapıştırın.

target dosya:

[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 hizmet dosyası:

[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 hizmet dosyası:

[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

Önyükleme hizmetlerini etkinleştirin.

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

Hizmetleri yeniden başlatın.

sudo systemctl restart diaspora.target

Düzgün çalıştıklarından emin olun.

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

Nginx Ters Proxy

Statik kaynaklar sunmak için Nginx'i ters proxy olarak kullanacağız.

Let's Encrypt sertifikası almak için acme.sh kullanacağız .

acme.shKaynak kodu indirin .

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

Let's Encrypt sertifikası oluşturun.

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

Nginx'i yükleyin.

sudo apt-get install nginx

Diaspora kapsülümüz için yeni bir Nginx yapılandırma dosyası oluşturun.

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

Dosyayı aşağıdaki içerikle doldurun.

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

Not: değişikliğin example.comkendi kayıtlı alan adı için.

Tüm değişiklikler tamamlandıktan sonra, yapılandırma dosyasında hata olup olmadığını kontrol edin.

sudo nginx -t

Değişiklikleri uygulamak için Nginx'i yeniden başlatın.

sudo systemctl restart nginx

Şimdi tarayıcınızda Diaspora bölgenizin alan adını ziyaret ederseniz (örnek https://example.com:), Diaspora karşılama sayfasına ulaşacaksınız.

Diaspora Kullanıcısı Oluşturun

Bağlantıyı tıklayın ve Start by creating an account.yeni bir Diaspora kullanıcısı oluşturmak için ayrıntıları doldurun. Ardından, kullanıcınızın ana sayfasını görüntüleyebilir ve Diaspora sosyal ağını kullanmaya başlayabilirsiniz.

Bir hesap oluşturduktan sonra hesaba yönetici hakları verin:

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

Artık yönetici kontrol paneline erişiminiz var.

https://example.com/admins/dashboard

Sidekiq

Arka plan işlerini işleyen Sidekiq, adresinde bir web arayüzüne sahiptir https://example.com/sidekiq. Pod istatistiklerini adresinde bulabilirsiniz https://example.com/statistics.

logrotate

logrotateDiaspora günlüklerini yönetmek için kullanacağız .

logrotateDiaspora için yeni bir dosya oluşturun .

nano /etc/logrotate/diaspora

Ardından, aşağıdaki satırları ekleyin.

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

Bu, günlükleri haftalık olarak döndürecek, sıkıştıracak ve 52 hafta boyunca saklayacaktır.

Diasporayı Güncelle

Diasporayı güncelleme zamanı geldiğinde şu adımları izleyin.

İlk olarak sistemi güncelleyin.

sudo apt-get update
sudo apt-get dist-upgrade

Diaspora kaynak kodunu ile güncelleyin git.

su - diaspora
cd diaspora
git pull

Taşları güncelleyin.

gem install bundler
bin/bundle --full-index

Veritabanını taşıyın ve varlıkları yeniden derleyin.

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

Son olarak, Diasporayı yeniden başlatın.

systemctl restart diaspora.target


Debianda NFS Paylaşımı Ayarla

Debianda NFS Paylaşımı Ayarla

NFS, bilgisayarların bilgisayar ağı üzerindeki dosyalara erişmesine izin veren ağ tabanlı bir dosya sistemidir. Bu kılavuz, klasörleri NF üzerinden nasıl açığa çıkarabileceğinizi açıklar

Debian 9 Üzerinde Yakıt CMS Kurulumu

Debian 9 Üzerinde Yakıt CMS Kurulumu

Farklı Bir Sistem mi Kullanıyorsunuz? Fuel CMS, CodeIgniter tabanlı bir içerik yönetim sistemidir. Kaynak kodu GitHubda barındırılmaktadır. Bu kılavuz size

SSL / TLS ile vsFTPd Nasıl Güvenli Hale Getirilir

SSL / TLS ile vsFTPd Nasıl Güvenli Hale Getirilir

Çok Güvenli FTP arka plan programı, ya da sadece vsFTPd, özelleştirme yeteneği olan hafif bir yazılım parçasıdır. Bu derste bir müttefikimiz olacak

Debian 9 Üzerinde Thelia 2.3 Kurulumu

Debian 9 Üzerinde Thelia 2.3 Kurulumu

Farklı Bir Sistem mi Kullanıyorsunuz? Thelia, e-iş web siteleri oluşturmak ve PHP ile yazılmış çevrimiçi içeriği yönetmek için açık kaynaklı bir araçtır. Thelia kaynak kodu i

Debianda Chroot Oluşturma

Debianda Chroot Oluşturma

Bu makale size Debianda nasıl bir cezaevi hapishane kurulacağını öğretecek. Debian 7.x kullandığınızı varsayıyorum. Debian 6 veya 8 çalıştırıyorsanız, bu işe yarayabilir, bu

Debian 9 InvoicePlane Nasıl Kurulur

Debian 9 InvoicePlane Nasıl Kurulur

Farklı Bir Sistem mi Kullanıyorsunuz? InvoicePlane ücretsiz ve açık kaynaklı bir faturalandırma uygulamasıdır. Kaynak kodu bu Github deposunda bulunabilir. Bu rehber

Debian 9u Debian 10a Yükseltme

Debian 9u Debian 10a Yükseltme

Giriş Debian 10 (Buster), Debian 9un (Stretch) halefidir. 6 Temmuz 2019da piyasaya sürüldü. Bu derste, bir var olanı yükselteceğiz

Debian 9 LAMP VPS Arka Plan CMS 1.8.0 Kurulumu

Debian 9 LAMP VPS Arka Plan CMS 1.8.0 Kurulumu

Farklı Bir Sistem mi Kullanıyorsunuz? Backdrop CMS 1.8.0, basit ve esnek, mobil uyumlu, ücretsiz ve açık kaynaklı bir İçerik Yönetim Sistemidir (CMS)

Debian 9 Üzerinde BookStack Kurulumu

Debian 9 Üzerinde BookStack Kurulumu

Farklı Bir Sistem mi Kullanıyorsunuz? BookStack, bilgileri düzenlemek ve depolamak için basit, kendi kendine barındırılan, kullanımı kolay bir platformdur. BookStack tamamen ücretsiz ve açık

Ubuntu ve CentOS İçin Daha İyi İzleme Araçları

Ubuntu ve CentOS İçin Daha İyi İzleme Araçları

Giriş Linux sistemleri, süreçleri ve disk alanını izlemeye yardımcı olan varsayılan olarak top, df ve du gibi izleme araçlarıyla birlikte gelir. Çoğu zaman, onlar ar

CentOS 7, Ubuntu 16.04 ve Debian 9da Golang 1.8.3 Kurulumu

CentOS 7, Ubuntu 16.04 ve Debian 9da Golang 1.8.3 Kurulumu

Golang, Google tarafından geliştirilen bir programlama dilidir. Çok yönlülüğü, sadeliği ve güvenilirliği sayesinde Golang en popüler topluluklardan biri haline geldi

Debian 9a Cıvata CMS Takma (Uzatma)

Debian 9a Cıvata CMS Takma (Uzatma)

Farklı Bir Sistem mi Kullanıyorsunuz? Bolt PHP ile yazılmış açık kaynaklı bir CMSdir. Cıvata kaynak kodu GitHubda barındırılıyor. Bu kılavuz size Bolt CMnin nasıl kurulacağını gösterecektir

Munin ile Debian Sunucu Durumunu İzleme

Munin ile Debian Sunucu Durumunu İzleme

Munin, makinenizdeki süreçleri ve kaynakları araştırmak için bir izleme aracıdır ve bilgileri bir web arayüzü aracılığıyla grafiklerde sunar. Aşağıdaki kullanın

Debian 10da Apachede TLS 1.3ü Etkinleştirme

Debian 10da Apachede TLS 1.3ü Etkinleştirme

Farklı Bir Sistem mi Kullanıyorsunuz? TLS 1.3, 2018de RFC 8446da önerilen bir standart olarak yayınlanan Taşıma Katmanı Güvenliği (TLS) protokolünün bir sürümüdür

Debian 9 Üzerinde PyroCMS Kurulumu

Debian 9 Üzerinde PyroCMS Kurulumu

Farklı Bir Sistem mi Kullanıyorsunuz? PyroCMS, PHP ile yazılmış açık kaynaklı bir CMSdir. PyroCMS kaynak kodu GitHubda barındırılmaktadır. Bu kılavuzda entir boyunca yürüyün

Sunucunuza IP Adresi Aralığı Ekleyin (CentOS / Ubuntu / Debian)

Sunucunuza IP Adresi Aralığı Ekleyin (CentOS / Ubuntu / Debian)

Giriş Bu eğitimde, CentOS, Debian veya Ubuntu çalıştıran bir Linux sunucusuna tüm IP aralığını / alt ağını ekleme işlemini ele alacağız. Süreç

Counter Strikeı Ayarlama: Debianda Kaynak

Counter Strikeı Ayarlama: Debianda Kaynak

Bu kılavuzda, Debian 7de Counter Strike: Source oyun sunucusu kuracağız. Bu komutlar Debian 7de test edildi, ancak aynı zamanda o

Debian Üzerinde Snort Nasıl Yapılandırılır

Debian Üzerinde Snort Nasıl Yapılandırılır

Snort, ücretsiz bir ağ saldırı tespit sistemidir (IDS). Daha az resmi terimle, ağınızı şüpheli etkinlikler için gerçek zamanlı olarak izlemenizi sağlar

Debian 9 Üzerinde Dolibarr Kurulumu

Debian 9 Üzerinde Dolibarr Kurulumu

Farklı Bir Sistem mi Kullanıyorsunuz? Dolibarr, işletmeler için açık kaynaklı bir kurumsal kaynak planlaması (ERP) ve müşteri ilişkileri yönetimi (CRM). Dolibarr

26 Büyük Veri Analitik Tekniğine Bir Bakış: 1. Bölüm

26 Büyük Veri Analitik Tekniğine Bir Bakış: 1. Bölüm

26 Büyük Veri Analitik Tekniğine Bir Bakış: 1. Bölüm

Nintendo Switch Hakkında Son Derece Çılgın 6 Şey

Nintendo Switch Hakkında Son Derece Çılgın 6 Şey

Birçoğunuz Switch'in Mart 2017'de çıkacağını ve yeni özelliklerini biliyorsunuz. Bilmeyenler için, 'Switch'i 'olmazsa olmaz bir gadget' yapan özelliklerin bir listesini hazırladık.

Hala Teslim Edilmeyen Teknoloji Sözleri

Hala Teslim Edilmeyen Teknoloji Sözleri

Teknoloji devlerinin sözlerini yerine getirmesini mi bekliyorsunuz? teslim edilmeyenleri kontrol edin.

Büyük Veri Referans Mimarisi Katmanlarının İşlevleri

Büyük Veri Referans Mimarisi Katmanlarının İşlevleri

Büyük Veri Mimarisindeki farklı katmanları ve işlevlerini en basit şekilde öğrenmek için blogu okuyun.

Yapay Zeka Süreç Otomasyonunu Nasıl Bir Sonraki Seviyeye Taşıyabilir?

Yapay Zeka Süreç Otomasyonunu Nasıl Bir Sonraki Seviyeye Taşıyabilir?

Yapay Zekanın küçük ölçekli şirketler arasında nasıl popüler hale geldiğini ve onları büyütme ve rakiplerine üstünlük sağlama olasılıklarını nasıl artırdığını öğrenmek için bunu okuyun.

CAPTCHA: İnsan-AI Ayrımı İçin Ne Kadar Geçerli Bir Teknik Kalabilir?

CAPTCHA: İnsan-AI Ayrımı İçin Ne Kadar Geçerli Bir Teknik Kalabilir?

CAPTCHA, son birkaç yılda kullanıcıların çözmesi oldukça zorlaştı. Gelecekte spam ve bot tespitinde etkili kalabilecek mi?

Teknolojik Tekillik: İnsan Uygarlığının Uzak Bir Geleceği mi?

Teknolojik Tekillik: İnsan Uygarlığının Uzak Bir Geleceği mi?

Bilim hızla gelişip birçok çabamızı üstlendikçe, kendimizi açıklanamaz bir Tekilliğe maruz bırakmanın riskleri de artıyor. Okuyun, tekillik bizim için ne anlama gelebilir.

Teletıp ve Uzaktan Sağlık Hizmeti: Gelecek Burada

Teletıp ve Uzaktan Sağlık Hizmeti: Gelecek Burada

Teletıp, uzaktan sağlık hizmetleri ve gelecek nesiller üzerindeki etkisi nedir? Pandemi durumunda iyi bir yer mi değil mi? Bir görünüm bulmak için blogu okuyun!

Hackerların Nasıl Para Kazandığını Hiç Merak Ettiniz mi?

Hackerların Nasıl Para Kazandığını Hiç Merak Ettiniz mi?

Bilgisayar korsanlarının çok para kazandığını duymuş olabilirsiniz, ancak bu kadar parayı nasıl kazandıklarını hiç merak ettiniz mi? Hadi tartışalım.

macOS Catalina 10.15.4 Ek Güncellemesi Çözmekten Daha Fazla Soruna Neden Oluyor

macOS Catalina 10.15.4 Ek Güncellemesi Çözmekten Daha Fazla Soruna Neden Oluyor

Son zamanlarda Apple, sorunları gidermek için macOS Catalina 10.15.4'ü ek bir güncelleme yayınladı, ancak güncelleme, mac makinelerinde tuğla oluşmasına neden olan daha fazla soruna neden oluyor gibi görünüyor. Daha fazla bilgi edinmek için bu makaleyi okuyun