Ajouter HowtoMercure.md

This commit is contained in:
Alexis Ben Miloud--Josselin 2023-11-17 18:40:29 +01:00
parent d5da281195
commit 497101b30f

153
HowtoMercure.md Normal file
View file

@ -0,0 +1,153 @@
---
title: Howto Mercure
categories: web
...
* Documentation : <https://mercure.rocks/docs>
[Mercure](https://mercure.rocks/) est un logiciel libre de communication en temps réel écrit en Go.
## Installation
> Linstallation a été faite pour Mercure v0.15.5 sur Debian 11.
### Télécharger Mercure
Récupérer une archive depuis le [dépôt sur GitHub](https://github.com/dunglas/mercure/releases) puis vérifier sa somme de contrôle. Attention, larchive na pas de répertoire à sa racine, donc il vaut mieux se mettre dans un répertoire avant de lextraire. Par exemple :
~~~
# mkdir mercure-tmp
# cd mercure-tmp
# wget https://github.com/dunglas/mercure/releases/download/<VERSION>/mercure_Linux_x86_64.tar.gz
# sha256sum mercure_Linux_x86_64.tar.gz
# tar -xz -f mercure_Linux_x86_64.tar.gz
# chown -R root: .
~~~
Larchive devrait contenir les fichiers suivants.
~~~
COPYRIGHT
Caddyfile
Caddyfile.dev
LICENSE
README.md
mercure
~~~
### Installer les fichiers
~~~
# mkdir -p /usr/local/share/doc/mercure
# cp -a COPYRIGHT LICENSE README.md /usr/local/share/doc/mercure/
# mkdir /etc/mercure
# cp -a Caddyfile Caddyfile.dev /etc/mercure/
# cp -a mercure /usr/local/sbin/
~~~
### Créer une unité systemd
1. Créer le fichier `/etc/systemd/system/mercure.service` avec le contenu suivant.
~~~
[Unit]
Description=Mercure Hub (allow to push data updates to web browsers and other HTTP clients)
Documentation=https://mercure.rocks/docs
[Service]
WorkingDirectory=/var/lib/mercure
ExecStart=/usr/local/sbin/mercure run --config /etc/mercure/Caddyfile
ExecReload=/usr/local/sbin/mercure reload --config /etc/mercure/Caddyfile
Restart=on-failure
CapabilityBoundingSet=
NoNewPrivileges=yes
UMask=0027
RuntimeDirectory=mercure
StateDirectory=mercure
ConfigurationDirectory=mercure
LogsDirectory=mercure
ProtectSystem=strict
ProtectHome=yes
PrivateTmp=yes
PrivateDevices=yes
PrivateUsers=yes
ProtectKernelTunables=yes
ProtectKernelModules=yes
ProtectControlGroups=yes
RestrictNamespaces=
LockPersonality=yes
RestrictRealtime=yes
RemoveIPC=yes
SystemCallFilter=@system-service
SystemCallFilter=~@privileged
SystemCallErrorNumber=EPERM
SystemCallArchitectures=native
PrivateNetwork=no
RestrictAddressFamilies=AF_UNIX AF_INET AF_INET6
[Install]
WantedBy=multi-user.target
~~~
2. Recharger la configuration de systemd :`# systemctl daemon-reload`.
3. Activer et démarrer lunité : `# systemctl enable --now mercure.service`.
## Configuration
La configuration du service est dans le fichier `/etc/mercure/Caddyfile`. Voici un exemple de configuration (adapter le texte en majuscule entre `<>`) :
~~~
{
auto_https off
admin unix//run/mercure/admin.sock
}
<DOMAIN>:<PORT>
log {
format filter {
wrap console
fields {
uri query {
replace authorization REDACTED
}
}
}
output file /var/log/mercure/access.log
}
tls <PATH_TO_FULLCHAIN> <PATH_TO_PRIVKEY>
route {
encode zstd gzip
mercure {
transport_url bolt:///var/lib/mercure/mercure.db
publisher_jwt <PUBLISHER_KEY> <PUBLISHER_KEY_ALG>
subscriber_jwt <SUBSCRIBER_KEY> <SUBSCRIBER_KEY_ALG>
subscriptions
}
header / Content-Type "text/html; charset=utf-8"
respond / `<!DOCTYPE html>
<html lang=en>
<meta charset="utf-8">
<meta name="robots" content="noindex">
<title>Welcome to Mercure</title>
<h1>Welcome to Mercure</h1>
<p>The URL of your hub is <code>/.well-known/mercure</code>.
Read the documentation on <a href="https://mercure.rocks">Mercure.rocks, real-time apps made easy</a>.`
respond /healthz 200
respond "Not Found" 404
}
~~~
Note: Mercure embarque le serveur web [Caddy](https://caddyserver.com/).
## Mise à jour
Tout comme linstallation, [télécharger Mercure](#telecharger-mercure) et [installer les fichiers](#installer-les-fichiers) **sans réécrire complètement le fichier `/etc/mercure/Caddyfile`**. Pour finir, redémarrer le service : `# systemctl restart mercure.service`