Projects

GitLab Classrooms

GitLab Classroom is a modest clone of Github Classroom, aimed at GitLab.

Gaia

Gaia is a Terraform UI for your Terraform modules, and self-service infrastructure.


Posts

Tomcat 11 & Virtual Threads 🧵

- 23 mins read
Apache Tomcat est le plus célèbre des conteneurs de Servlets Java. Les versions se succèdent au fil des années. Avec Spring Boot, et son utilisation de la version «embedded», son usage en tant que serveur «installé» a diminué, mais il reste encore au cœur de la majorité de nos micro-services, parfois sans que les développeurs s’en rendent compte. Chaque version majeure de Tomcat apporte le support des nouvelles versions des API Java EE ou JEE.
Dans cet article, nous allons voir comment déployer SonarQube sur Clever Cloud en deux temps. Le premier consistera en un déploiement très simple, qui est équivalent à une installation locale. Dans un second temps, nous utiliserons une base de données PostgreSQL externalisée pour assurer la persistance des données. Cet article suppose que vous avez déjà un compte actif sur Clever Cloud, et que votre CLI est installé et configuré. L’installation du CLI est décrite dans la documentation de Clever Cloud.

Anatomie d'une requête HTTP

- 6 mins read
HTTP, pour Hypertext Transfer Protocol, est le protocole principal pour les échanges internet. Il est utilisé aussi bien par le navigateur que vous utilisez pour lire cet article, que pour faire communiquer des applications. Il s’appuie sur un éhange de requête et réponse, entre un client et un serveur, au format texte. L’avantage du format texte est qu’il est facile à implémenter dans tous les langages de programmation. Le protocole HTTP est spécifié par la RFC 2616, protocole dont la toute première version d’HTTP date de 1990.
Que ce soit pour un projet d’entreprise ou un projet open-source, la documentation utilisateur et technique est cruciale. Dans une documentation d’usage, les utilisateurs doivent pouvoir retrouver les instructions leur permettant d’accomplir les gestes métier de tous les jours. Pour la documentation technique, les administrateurs, opérateurs et développeurs doivent pouvoir retrouver les opérations d’installation, de mise à jour, ou encore de développement du produit. La documentation peut prendre plusieurs formes:
Lors du développement d’une application pour Kubernetes, le développeur est souvent lié à une boucle de feedback assez longue: Développement Contruction de l’image Docker (quelques secondes/minutes) Push de l’image sur un registry Déploiement sur Kubernetes (quelques minutes) Cette boucle est généralement implémentée par des pipelines de CI/CD. Ces pipelines augmentent encore le temps entre le développement et une application démarrée sur Kubernetes. Ce temps est relativement long lorsqu’on compare un cycle de développement local auquel un développeur peut être habitué.
Le problème Je suis le genre de développeur qui travaille toujours avec un terminal ouvert sur le côté, en plus de mon IDE. Je lance souvent des commandes mvn pour m’assurer que mon projet compile et que mes tests s’exécutent correctement. C’est un vieux réflexe qui date de l’époque où les IDE n’avaient qu’un support limité de Maven. Lancer ces commandes hors-IDE m’aide souvent à valider que tout fonctionnera bien dans un environnement de CI par exemple.
Adresse IP/URL du KeyLight La KeyLight se connecte à votre réseau WiFi. La première étape consiste à récupérer son adresse IP. La keylight répond aux requêtes mDNS (multicast dns). C’est d’ailleurs indiqué dans leur documentation: What Communication Protocol Is Used by Elgato Wi-Fi Products? mDNS Service Strings for Elgato Devices Pour obtenir l’IP du keylight, il suffit donc d’emettre une requête DNS: dig -p 5353 PTR _elg._tcp.local @224.0.0.251 ; <<>> DiG 9.

Réécrire une branche git

- 3 mins read
Je suis tombé sur un cas où un fichier a été ajouté dans git (commité), puis modifié par plusieurs commits successifs. Malheureusement, ce fichier contient des credentials. On va donc devoir supprimer ce fichier de tout l’historique git (oui ça implique une réécriture de la sainte branche main 😇). Trouver dans quel commit le fichier a été ajouté Le fichier que je recherche s’appelle config.json. Je vais faire un git log, pour trouver le commit qui a ajouté ce fichier.

xdotool cheatsheet

- 1 min read
I played a lot these days with xdotool, to try to automate some stuff for my Elgato Streamdeck. These are the things I try to do: Select a window, and send a Keyboard sequence (such as CTRL+B to mute/unmute a Teams call) Type emojis to the active window 😅 More a window around, or resize it Here are some links that I found about xdotool: Xdotool - Window Stack Xdotool - Examples Below are the commands I found useful during my research.
As I prepare and run a lot of scripts, sometimes I need to run a script at a precise time of the day. When a script must be only run once, cron is not a viable solution. So I discovered the at scheduler You need to install it first, using apt as usual. $ sudo apt install at Schedule a command to run use the command at with a time / date input the commands to run in the prompt type CTRL+D to exit (^D) $ at 9AM warning: commands will be executed using /bin/sh at> cd workspaces/github/dotfiles at> git pull at> <EOT> job 1 at Sat Apr 16 09:00:00 2022 This example will pull a repository contents at 9 AM tomorrow !