🇫🇷 Serveur Pwic.wiki fonctionnant avec Python et SQLite
🦜 Accueil Démonstration Fonctionnalités Installation Support au logiciel
⭐ Special ⏰ History 📤 Email 🖨️ Print 💾 MD 💾 ODT
📌
1. Approche générale 2. Tutoriaux en vidéo 3. FAQ technique 3.1. Comment puis-je vérifier si Pwic.wiki contient la fonctionnalité dont j'ai besoin ? 3.2. Est-ce que Pwic.wiki est stable et sûr à utiliser ? 3.3. Quelle est la structure des fichiers ? 3.4. Comment vous assurez-vous de la qualité du code ? 3.5. Quelles sont les possibilités de personnalisation de Pwic.wiki? 3.6. Est-ce que le site actuel utilise du code spécifique ? 3.7. Pourquoi certaines pages sont délivrées par nginx sur ce site ? 3.8. Est-ce que Pwic.wiki fonctionne sur un Raspberry Pi 5 ? 3.9. Est-ce que Pwic.wiki fonctionne avec Docker ? 3.10. Est-ce que Pwic.wiki peut utiliser HTTPS avec Let's Encrypt ? 3.11. Quelle est l'empreinte mémoire brute de Pwic.wiki ? 3.12. Comment puis-je utiliser plusieurs processeurs à la fois ? 3.13. Comment résoudre la lenteur de la base de données ? 3.14. Quelles sont les métriques de Pwic.wiki ? 3.15. Quel standard Markdown est supporté ? 3.16. Quel standard OpenDocument est supporté ? 3.17. Où est la liste des colorateurs syntaxiques supportés ? 3.18. Est-ce que vous développerez un outil de suivi de bogues rapide et efficace basé sur Pwic.wiki ? 3.19. Puis-je contacter votre équipe en privé ?

Related pages: 🇬🇧 Support for the application

1. Approche générale

Les problèmes et demandes d'améliorations doivent être soumises dans le tracker public sur Github. Faîtes attention à ne pas exposer de données sensibles.

Parce que le code source de Pwic.wiki peut être étendu à des endroits précis, si vos besoins se gèrent avec quelques lignes spécifiques à ces endroits, elles ne réintègreront pas le code public. Il est possible de discuter de nouvelles fonctionnalités si elles peuvent intéresser d'autres utilisateurs.

À date, nous n'offrons aucun service d'écriture de code pour des extensions ou des bots. Mais nous pouvons discuter pour estimer leur faisabilité. Si tel n'était pas le cas, le code public pourra être modifié pour offrir les points d'extension nécessaires.

2. Tutoriaux en vidéo

Les vidéos de la chaîne YouTube sont sous-titrées en anglais.

3. FAQ technique

3.1. Comment puis-je vérifier si Pwic.wiki contient la fonctionnalité dont j'ai besoin ?

Les fonctionnalités sont listées sur ce site. Vous pouvez aussi les comparer sur le site WikiMatrix.org.

3.2. Est-ce que Pwic.wiki est stable et sûr à utiliser ?

Pwic.wiki propose une version stable 1.0 depuis juillet 2022, mais aussi une version de développement via le dépôt Git. Vous choisissez la version de votre choix. Mais pour ce site web, il s'agira toujours de la dernière version de développement pour illustrer comment elle performe. Le cycle de développement interne privilégie toujours la résolution des bugs connus à l'ajout de nouvelles fonctionnalités.

3.3. Quelle est la structure des fichiers ?

Structure des fichiers de Pwic.wiki

3.4. Comment vous assurez-vous de la qualité du code ?

Les deux outils flake8 et mypy sont principalement utilisés pour vérifier la syntaxe et le typage des variables au sein des appels de fonctions. Ces contrôles sont statiques mais permettent d'anticiper les problèmes courants. Le code est testé dynamiquement à l'usage, car il sert notamment pour le site web officiel. Récemment, la validation a été étendue de façon discrétionnaire à CodeFactor.io qui regroupe des outils tiers comme pylint, stylelint ou bandit.

3.5. Quelles sont les possibilités de personnalisation de Pwic.wiki?

Vous pouvez :

3.6. Est-ce que le site actuel utilise du code spécifique ?

Tout à fait et en accord avec la conception de Pwic.wiki. Ce site utilise l'exacte version que vous pouvez télécharger.

Les changements implémentés limitent certains abus dans la gestion de l'espace de démonstration. Alors si vous ne pouvez pas vous connecter, vous pourrez le faire en installant votre instance du logiciel.

3.7. Pourquoi certaines pages sont délivrées par nginx sur ce site ?

Le reverse proxy nginx est utilisé pour servir les fichiers statiques comme cela est recommandé dans la documentation d'aiohttp. Ce n'est pas obligatoire mais c'est mieux pour réduire la charge de calcul et les temps de chargement. Dans notre cas, c'est aussi un élément obligatoire pour partager le port 80 principal avec d'autres logiciels privés et sites web (comme musique.pwic.wiki).

3.8. Est-ce que Pwic.wiki fonctionne sur un Raspberry Pi 5 ?

Le logiciel en version 1.2 est validé pour fonctionner avec Raspberry OS dérivé de Debian Bookworm 12.2. Vous êtes actuellement connecté sur cette machine qui supporte l'IPv4 et IPv6 à la fois :

Raspberry Pi 5

3.9. Est-ce que Pwic.wiki fonctionne avec Docker ?

Oui, la procédure indicative est décrite ici.

3.10. Est-ce que Pwic.wiki peut utiliser HTTPS avec Let's Encrypt ?

Oui, la procédure est décrite ici. Vous aurez a minima besoin d'acheter un nom de domaine.

3.11. Quelle est l'empreinte mémoire brute de Pwic.wiki ?

Voici un extrait du processus Pwic.wiki tout juste lancé à vide dans une machine virtuelle dotée de 2 Go de mémoire :

User PID %CPU %Mem VSZ RSS TTY Stat Start Time Command
pwic 979 0.4 1.9 62500 39288 pts/0 S 23:23 0:00 python3 pwic.py

Après 1 mois de fonctionnement dans une machine réelle avec 8 Go de mémoire :

User PID %CPU %Mem VSZ RSS TTY Stat Start Time Command
pwic 859 0.0 1.0 247392 85792 ? S1 Nov04 0:23 python3 pwic.py

3.12. Comment puis-je utiliser plusieurs processeurs à la fois ?

Si vous avez des besoins accrus en calcul, vous devez suivre cette procédure. L'idée est de lancer plusieurs instances de Pwic.wiki sur des ports internes différents et derrière un reverse proxy. Si vous n'utilisez pas l'option keep_sessions, chaque nœud aura sa propre authentification et vous ne pourrez pas basculer sur un autre nœud.

L'instance Pwic.wiki de notre serveur n'utilise qu'un seul CPU.

3.13. Comment résoudre la lenteur de la base de données ?

Par conception de l'API, chaque appel correspond à une transaction, c'est-à-dire à un ensemble de mises à jour annulables jusqu'à ce qu'elles soient sauvegardées sur la surface du disque dur. La vérification que les données sont bien physiquement sauvegardées prend du temps, d'autant plus que les appels à l'API sont répétés. Cela explique pourquoi il n'est pas possible de faire plus de 20 mises à jour par seconde. Ce comportement est documenté, normal et sûr.

La seule façon de faire une mise à jour en masse consiste à écrire dans la base de données directement avec un script, mais ce n'est pas recommandé, car cela court-circuite toutes les protections. Vous devez utiliser l'API mais vous ne souhaitez pas être limité pour autant. Pour libérer la base de données et éviter les ralentissements du disque dur, vous devez activer le mode asynchrone via l'option db_async. Des milliers d'ajouts peuvent alors être faits chaque seconde, mais vos modifications peuvent cependant être perdues si le serveur n'a plus d'alimentation électrique. Cette option doit être utilisée si votre site a une forte activité.

3.14. Quelles sont les métriques de Pwic.wiki ?

Au 28 avril 2024 avec l'aide de AlDanial/cloc v1.92 et après quelques ajustements :

Langage Fichiers Blancs Commentaires Code
Python 9 1340 4303 8682
HTML 25 309 6 2704
PO File 2 648 56 1324
JavaScript 14 126 63 1275
Sass 2 224 63 803
XML 2 0 4 202
Markdown 1 38 0 132
CSS 1 1 0 8
Bourne Shell 1 1 1 8
DOS Batch 1 1 1 8
Somme : 58 2688 4497 15146

3.15. Quel standard Markdown est supporté ?

L’implémentation réalisée par la dépendance python-markdown2 s'appuie sur CommonMark et est compatible avec Github dans les grandes lignes.

3.16. Quel standard OpenDocument est supporté ?

L'intégration avec OpenDocument Text (ODT) se réfère à la spécification "Open Document Format for Office Applications (OpenDocument) Version 1.2" publiée en 2011.

3.17. Où est la liste des colorateurs syntaxiques supportés ?

Si vous installez la dépendance optionnelle pygments, vous pouvez colorer vos codes source. Par simple hasard, l'exemple suivant utilise le colorateur abap :

REPORT zlexers. START-OF-SELECTION. WRITE 'Référez-vous aux <short names> à ce lien: https://pygments.org/docs/lexers/'. WRITE 'Téléchargez cette page au format MD pour voir la syntaxe autour de ```'.

3.18. Est-ce que vous développerez un outil de suivi de bogues rapide et efficace basé sur Pwic.wiki ?

En raison des temps et coûts requis, ce n'est pas à l'ordre du jour mais fondamentalement souhaité.

3.19. Puis-je contacter votre équipe en privé ?

Si vous découvrez un problème critique que vous ne souhaitez pas divulguer, prenez contact par courriel à "support pwic.wiki" (devinez le caractère manquant). Sinon, veuillez utiliser le tracker public dont le lien est donné tout en haut.

Revision #1 was last modified by gitbra
on 2025-01-08 at 00:00:00 — 7293c1f62b16d5af

🔝 Top of the page 🔝