Quassel instellen op Debian 9

IRC is populair bij ontwikkelaars en gebruikers van open source software. Een van de nadelen van IRC is dat wanneer u niet online bent, u mogelijk belangrijke gesprekken of vermeldingen van uw bijnaam mist. Met Quassel en een kleine VPS kunt u IRC-persistentie hebben, compleet met een webgebaseerde gebruikersinterface en een doorzoekbare achterstand.

Ik ga ervan uit dat je al weet hoe je een VPS moet maken in het Vultr-configuratiescherm.

Eerst moet je inloggen op je Vultr-configuratiescherm en jezelf een geheel nieuwe VPS maken. In dit voorbeeld heb ik een Debian 9, $ 2,50 / maand VPS opgezet. U kunt elke maat kiezen, maar het doel hiervan is om zo laag mogelijk te zijn. Je moet het een naam geven, zoals quassel.example.neten ervoor zorgen dat je een DNS A-record hebt geconfigureerd.

Aangezien deze instructies zijn gericht op Debian, zult u ze enigszins moeten wijzigen als u van plan bent een andere Linux-distributie te gebruiken, zoals Ubuntu of CentOS.

Zodra je VPS actief is, wil je een paar pakketten installeren om de basis op gang te krijgen.

U moet Quassel-Core, PostgreSQL, Apache en PHP installeren, samen met nog een paar bibliotheken om met de SQL-server te praten.

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

Je hebt ook Node.js. nodig Voor het webgedeelte van uw persoonlijke IRC-cloudserver is Node vereist. Volledige instructies om te installeren zijn hier te vinden , maar dit zijn de enige twee regels die je nodig hebt:

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

Vervolgens moet u een database maken voor de Quassel-kern. Schakel over naar de Postgres-gebruiker en ren psql.

# su - postgres
$ psql

Zodra u bij de PostgreSQL-prompt bent, moet u een gebruiker voor Quassel en de bijbehorende database maken:

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

Nu de basis is geconfigureerd, kunt u nu de Quassel-client starten en verbinding maken met uw kern.

Wanneer u de Quassel-client op uw lokale computer start, krijgt u een verbindingsdialoogvenster te zien. Voer het IP-adres of de hostnaam van je VPS en het poortnummer in (standaard: 4242) en selecteer SSL. Als u een proxyserver heeft, kunt u de proxydetails invoeren in het dialoogvenster.

Tijdens de eerste verbinding wordt u door een andere wizard geleid om de kern te configureren. Voer uw eerste gebruikersnaam en wachtwoord voor Quasselcore in. De eerste gebruiker is de beheerder. Selecteer vervolgens de PostgreSQL-databasebackend en geef de gebruikersnaam en het wachtwoord van de Quassel-database op zoals gedefinieerd in de vorige stap.

Nadat u de basis van uw kern heeft geconfigureerd, kunt u nu het webgedeelte instellen. Hiermee kunt u vanuit elke webbrowser verbinding maken met uw kern. We gaan Quassel-Webserver gebruiken .

Maak een gebruiker voor de webservice:

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

Trek nu de Quassel-webserver omlaag en wijzig het eigendom in de eerder gemaakte gebruiker:

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

Vervolgens moet u de toepassing Node.js "installeren":

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

Kopieer de settings.jsnaar settings-user.js en verander de host, forcedefaulten prefixpathwaarden:

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

In het /opt/quassel-webserverpad als root kunt u het servicebestand voor Systemd installeren.

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

U moet /lib/systemd/system/quassel-webserver.servicede ExecStartregel bewerken en wijzigen :

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

U kunt nu de Quassel-webserver inschakelen en starten:

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

U kunt controleren of de quassel-webserver actief is door uit te voeren systemctl status quassel-webserver.service. Als je het ziet Active: active (running), ben je helemaal klaar!

Vervolgens gaan we Apache configureren.

U moet een paar modules inschakelen om te beginnen, zoals proxy_http, proxy_wstunnelen rewrite.

# a2enmod proxy_http proxy_wstunnel rewrite

Maak een nieuw configuratiebestand voor 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>

En schakel uw site in:

a2ensite quassel

Start Apache opnieuw om de wijzigingen toe te passen:

systemctl restart apache2

Als alles goed is gegaan, kunt u nu naar uw quassel-webserverinstantie bladeren op http://quassel.example.net.

Vervolgens gaan we een zoektocht naar achterstanden opzetten . Dit vereist aanpassingen aan de quassel-coredatabase. Laten we eerst beginnen met het klonen van de broncode:

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

Eenmaal gekloond, hernoem het bestand qrs_config.default.phpnaar qrs_config.phpen bewerk het bestand. U moet uw database te definiëren db_name, db_user, db_pathen path_prefix. Het zou er ongeveer zo uit moeten zien:

<?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');

Vervolgens passen we de database aan voor gebruik door quassel-rest-search:

Schakel over naar de postgresgebruiker en voer uit psql:

# su - postgres
$ psql quassel

Voeg eerst een nieuwe kolom toe aan de backlogtabel:

ALTER TABLE backlog ADD COLUMN tsv tsvector;

Voeg vervolgens de twee nieuwe indices toe:

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;

Ten derde, stel een trigger in om de tsv-kolom te vullen:

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

Ten vierde, vul de tsvkolom " " in:

UPDATE backlog SET messageid = messageid;

Nu kunt u de Apache-configuratie bijwerken die we eerder hebben gemaakt en toevoegen:

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

Start Apache opnieuw:

systemctl restart apache2

Als alles goed is gegaan, kunt u naar navigeren http://quassel.example.net/searchen ziet u een inlogscherm.

Dit is misschien een goed moment om uw webserver te beveiligen met Let's Encrypt. Details over het installeren en configureren van Let's Encrypt zijn te vinden op de EFF -website of hier op Vultr-documenten .

Als je je zorgen maakt over onvoldoende RAM, wil je misschien swap inschakelen op je VPS. Volg deze Linux swap-tutorial .



Leave a Comment

Kan AI vechten met toenemend aantal ransomware-aanvallen?

Kan AI vechten met toenemend aantal ransomware-aanvallen?

Ransomware-aanvallen nemen toe, maar kan AI helpen het nieuwste computervirus het hoofd te bieden? Is AI het antwoord? Lees hier weten is AI boezem of vloek

ReactOS: is dit de toekomst van Windows?

ReactOS: is dit de toekomst van Windows?

ReactOS, een open source en gratis besturingssysteem is hier met de nieuwste versie. Kan het voldoen aan de behoeften van moderne Windows-gebruikers en Microsoft uitschakelen? Laten we meer te weten komen over deze oude stijl, maar een nieuwere OS-ervaring.

Blijf verbonden via WhatsApp Desktop-app 24 * 7

Blijf verbonden via WhatsApp Desktop-app 24 * 7

WhatsApp heeft eindelijk de Desktop-app voor Mac- en Windows-gebruikers gelanceerd. Nu heb je eenvoudig toegang tot WhatsApp vanuit Windows of Mac. Beschikbaar voor Windows 8+ en Mac OS 10.9+

Hoe AI procesautomatisering naar een hoger niveau kan tillen?

Hoe AI procesautomatisering naar een hoger niveau kan tillen?

Lees dit om te weten hoe kunstmatige intelligentie populair wordt onder de kleinschalige bedrijven en hoe het de kansen vergroot om ze te laten groeien en hun concurrenten voorsprong te geven.

macOS Catalina 10.15.4 Supplement Update veroorzaakt meer problemen dan het oplost

macOS Catalina 10.15.4 Supplement Update veroorzaakt meer problemen dan het oplost

Onlangs heeft Apple macOS Catalina 10.15.4 uitgebracht, een aanvullende update om problemen op te lossen, maar het lijkt erop dat de update meer problemen veroorzaakt die ertoe leiden dat mac-machines worden gemetseld. Lees dit artikel voor meer informatie

13 Commerciële data-extractietools voor big data

13 Commerciële data-extractietools voor big data

13 Commerciële data-extractietools voor big data

Wat is een logboekbestandssysteem en hoe werkt het?

Wat is een logboekbestandssysteem en hoe werkt het?

Onze computer slaat alle gegevens op een georganiseerde manier op, het zogenaamde Journaling-bestandssysteem. Het is een efficiënte methode waarmee de computer bestanden kan zoeken en weergeven zodra u op zoeken drukt.https://wethegeek.com/?p=94116&preview=true

Technologische singulariteit: een verre toekomst van de menselijke beschaving?

Technologische singulariteit: een verre toekomst van de menselijke beschaving?

Naarmate de wetenschap zich snel ontwikkelt en veel van onze inspanningen overneemt, nemen ook de risico's toe om onszelf te onderwerpen aan een onverklaarbare singulariteit. Lees, wat singulariteit voor ons kan betekenen.

Een inzicht in 26 Big Data-analysetechnieken: deel 1

Een inzicht in 26 Big Data-analysetechnieken: deel 1

Een inzicht in 26 Big Data-analysetechnieken: deel 1

De impact van kunstmatige intelligentie in de gezondheidszorg 2021

De impact van kunstmatige intelligentie in de gezondheidszorg 2021

AI in de zorg heeft de afgelopen decennia grote sprongen gemaakt. De toekomst van AI in de gezondheidszorg groeit dus nog steeds met de dag.