Hur man ställer in Quassel på Debian 9

IRC är populärt bland utvecklare och användare av programvara med öppen källkod. En av nackdelarna med IRC är att när du inte är online kan du missa viktiga konversationer eller omnämnanden av ditt smeknamn. Med Quassel och en liten VPS kan du ha IRC-uthållighet, komplett med ett webbaserat användargränssnitt och en sökbar backlog.

Jag kommer att anta att du redan vet hur man skapar en VPS i Vultr kontrollpanelen.

Först måste du logga in på din Vultr-kontrollpanel och skapa dig en helt ny VPS. I det här exemplet har jag ställt in en Debian 9, $2,50/månad VPS. Du kan välja vilken storlek som helst, men målet för detta är att vara så låg kostnad som möjligt. Du måste ge den ett namn, till exempel quassel.example.netoch se till att du har en DNS A-post konfigurerad.

Eftersom dessa instruktioner är fokuserade kring Debian, måste du ändra dem något om du planerar att använda en annan Linux-distribution som Ubuntu eller CentOS.

När din VPS är igång, vill du installera några paket för att komma igång med grunderna.

Du kommer att behöva installera Quassel-Core, PostgreSQL, Apache och PHP, tillsammans med ytterligare ett par bibliotek för att prata med SQL-servern.

apt-get install quassel-core postgresql libqt5sql5-psql apache2 php php-pgsql

Du kommer också att behöva Node.js. Webbdelen av din personliga IRC-molnserver kräver Node. Fullständiga installationsinstruktioner finns här , men det här är de enda två raderna du behöver:

# curl -sL https://deb.nodesource.com/setup_8.x | bash -
# apt-get install -y nodejs

Därefter måste du skapa en databas för Quassel-kärnan. Byt till Postgres-användaren och kör psql.

# su - postgres
$ psql

När du är vid PostgreSQL-prompten måste du skapa en användare för Quassel och dess databas:

CREATE USER quassel ENCRYPTED PASSWORD 'somepassword';
CREATE DATABASE quassel WITH OWNER quassel ENCODING 'UTF8';

Nu när grunderna är konfigurerade kan du nu starta Quassel-klienten och ansluta till din kärna.

När du startar Quassel-klienten på din lokala dator kommer du att få en anslutningsdialogruta. Ange IP-adressen eller värdnamnet för din VPS och portnumret (standard: 4242) och välj SSL. Om du har en proxyserver kan du ange proxyinformationen i dialogrutan.

Under den första anslutningen kommer du att guidas genom en annan guide för att konfigurera kärnan. Ange ditt första Quasselcore-användarnamn och lösenord. Den första användaren kommer att vara administratör. Välj sedan PostgreSQL-databasens backend och ange Quassel-databasens användarnamn och lösenord som definierats i föregående steg.

När du har konfigurerat grunderna för din kärna kan du nu ställa in webbdelen. Detta gör att du kan ansluta till din kärna från vilken webbläsare som helst. Vi kommer att använda Quassel-Webserver .

Skapa en användare för webbtjänsten:

# useradd -d /opt/quassel-webserver -M -r quassel-webserver

Dra nu ner Quassel-webbservern och ändra äganderätten till den tidigare skapade användaren:

# git clone https://github.com/magne4000/quassel-webserver.git /opt/quassel-webserver
# chown -R quassel-webserver:quasselweb-server /opt/quassel-webserver

Du måste sedan "installera" applikationen Node.js:

# su - quassel-webserver
$ npm install --production

Kopiera settings.jstill settings-user.js och ändra värdena host, forcedefaultoch prefixpath:

host: 'localhost',
forcedefault: 'true',
prefixpath: '/app'

När du är i /opt/quassel-webserversökvägen som root kan du installera servicefilen för Systemd.

# cp scripts/quassel-webserver.service /lib/systemd/system/quassel-webserver.service

Du måste redigera /lib/systemd/system/quassel-webserver.serviceoch ändra ExecStartraden:

ExecStart=/usr/bin/node /opt/quassel-webserver/app.js -l 127.0.0.1 -m http

Du kan nu aktivera och starta Quassel webbserver:

systemctl enable quassel-webserver.service
systemctl start quassel-webserver.service

Du kan kontrollera att quassel-webservern körs genom att köra systemctl status quassel-webserver.service. Om du ser Active: active (running), är du redo!

Därefter ska vi konfigurera Apache.

Du måste aktivera några moduler för att börja, som proxy_http, proxy_wstunneloch rewrite.

# a2enmod proxy_http proxy_wstunnel rewrite

Skapa en ny konfigurationsfil för Quassel:

# nano /etc/apache2/sites-available/quassel.conf

<VirtualHost *:80>

        ServerName quassel.example.net
        ServerAdmin quassel@example.net
        DocumentRoot /var/www/html
        ErrorLog ${APACHE_LOG_DIR}/error.log
        CustomLog ${APACHE_LOG_DIR}/access.log combined

        # Enable Rewrite
        RewriteEngine on

        # Redirect to /app by default
        RedirectMatch ^/$ /app

        # Quassel Webserver
        RewriteRule /app/p/socket(.*) ws://127.0.0.1:64080/app/p/socket$1 [P,L]
        ProxyPass /app http://127.0.0.1:64080/app

</VirtualHost>

Och aktivera din webbplats:

a2ensite quassel

Starta om Apache för att tillämpa ändringarna:

systemctl restart apache2

Om allt har gått bra kan du nu bläddra till din quassel-webserverinstans på http://quassel.example.net.

Därefter ska vi ställa in en eftersläpningssökning . Detta kommer att kräva ändringar av quassel-coredatabasen. Låt oss först börja med att klona källkoden:

# git clone https://github.com/justjanne/quassel-rest-search.git /opt/quassel-rest-search

När den har klonats, byt namn på filen qrs_config.default.phptill qrs_config.phpoch redigera filen. Du kommer att behöva definiera din databas db_name, db_user, db_pathoch path_prefix. Det borde se ut ungefär så här:

<?php
define('db_host', 'localhost');
define('db_port', 5432);
define('db_name', 'quassel');

//Only change this if you know what you are doing
define('db_connector', null);

define('db_user', 'quassel');
define('db_pass', 'somepassword');

define('backend', 'pgsql-smart');

define('path_prefix', '/search');

Därefter ändrar vi databasen för att användas av quassel-rest-search:

Byt till postgresanvändaren och kör psql:

# su - postgres
$ psql quassel

Lägg först till en ny kolumn i eftersläpningstabellen:

ALTER TABLE backlog ADD COLUMN tsv tsvector;

För det andra, lägg till de två nya indexen:

CREATE INDEX backlog_tsv_idx
  ON backlog
  USING gin(tsv);
CREATE INDEX backlog_tsv_filtered_idx
  ON backlog
  USING gin(tsv)
  WHERE (type & 23559) > 0;

För det tredje, ställ in en utlösare för att fylla i tsv-kolumnen:

CREATE TRIGGER tsvectorupdate
  BEFORE INSERT OR UPDATE
  ON backlog
  FOR EACH ROW
  EXECUTE PROCEDURE tsvector_update_trigger('tsv', 'pg_catalog.english', 'message');

För det fjärde, fyll i tsvkolumnen " ":

UPDATE backlog SET messageid = messageid;

Nu kan du uppdatera Apache-konfigurationen som vi skapade tidigare och lägga till:

# Quassel Search
Alias /search /opt/quassel-rest-search
<Directory /opt/quassel-rest-search>
        Require all granted
</Directory>

Starta om Apache:

systemctl restart apache2

Om allt gick bra kan du navigera till http://quassel.example.net/searchoch du kommer att se en inloggningsskärm.

Nu kan det vara ett bra tillfälle att säkra din webbserver med Let's Encrypt. Detaljer om hur man installerar och konfigurerar Let's Encrypt finns på EFF -webbplatsen eller här på Vultr docs .

Om du är orolig för att få slut på RAM, kanske du vill aktivera swap på din VPS. Vänligen följ denna Linux-swaphandledning .

Lämna en kommentar

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.

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.

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.

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