<rss xmlns:atom="http://www.w3.org/2005/Atom" version="2.0"><channel><title>Git - Balise - arleo.eu</title><link>https://www.arleo.eu/tags/git/</link><description>Git - Balise - arleo.eu</description><generator>Hugo -- gohugo.io</generator><language>fr</language><lastBuildDate>Sat, 09 May 2026 12:40:58 +0200</lastBuildDate><atom:link href="https://www.arleo.eu/tags/git/" rel="self" type="application/rss+xml"/><item><title>Stratégie 4 : séparer le contenu (MCP) de la structure (Git)</title><link>https://www.arleo.eu/posts/strategie-4-mcp-vs-git/</link><pubDate>Sat, 09 May 2026 12:40:58 +0200</pubDate><author>Jmr</author><guid>https://www.arleo.eu/posts/strategie-4-mcp-vs-git/</guid><description><![CDATA[<div class="featured-image">
                <img src="/images/strategie-4-mcp-vs-git-featured.jpg" referrerpolicy="no-referrer">
            </div><h2 id="le-problème">Le problème</h2>
<p>Tu as un site Hugo. Tu veux pouvoir :</p>
<ol>
<li><strong>Éditer le contenu via Claude.ai</strong> (publier un article, corriger une coquille, mettre à jour un draft) sans toucher à un terminal SSH.</li>
<li><strong>Versionner la structure</strong> (layouts, themes, hugo.toml, scripts de déploiement) dans Git, comme un dev sérieux.</li>
</ol>
<p>Premier réflexe : « tout dans Git ». Les articles aussi. Le MCP commit, push, le webhook GitHub fait un rebuild. Propre, dans la philosophie GitOps.</p>
<p>Sauf que ça ne marche pas si bien. Voici pourquoi, et la solution simple que j&rsquo;appelle la <strong>Stratégie 4</strong>.</p>
<h2 id="pourquoi--tout-dans-git--casse-en-pratique">Pourquoi « tout dans Git » casse en pratique</h2>
<p>Imaginons que ton MCP fait un <code>git commit</code> à chaque <code>create_page</code>. Stratégie naïve, mais souvent proposée. Voici les problèmes :</p>
<h3 id="problème-1--conflit-mcp--git">Problème 1 — Conflit MCP ↔ Git</h3>
<p>Tu push depuis ton laptop un nouveau layout (<code>layouts/index.html</code> modifié). Au même moment, le MCP est en train de commiter une nouvelle version d&rsquo;un article. Race condition, le MCP peut faire un <code>git pull --rebase</code> qui échoue, ou pire, écraser ton commit local.</p>
<h3 id="problème-2--identité-git-du-mcp">Problème 2 — Identité Git du MCP</h3>
<p>Le MCP commit en tant que qui ? Avec quelle clé GPG ? Si tu as une politique « commits signés obligatoires », le MCP doit gérer une clé GPG, qu&rsquo;il faut sécuriser, faire tourner, etc.</p>
<h3 id="problème-3--auto-commit-indésirable">Problème 3 — Auto-commit indésirable</h3>
<p>Tu fais un test, tu crées un article draft pour expérimenter, tu le supprimes. Mais le MCP a déjà commité. Maintenant tu as un commit &ldquo;wip test&rdquo; dans l&rsquo;historique, à rebaser ou squasher manuellement.</p>
<h3 id="problème-4--réversibilité-asymétrique">Problème 4 — Réversibilité asymétrique</h3>
<p>Un <code>git revert</code> côté repo n&rsquo;a aucun effet sur les fichiers que le MCP a déjà créés. Tu te retrouves avec un repo et un état filesystem désynchronisés.</p>
<h2 id="la-stratégie-4--séparer-les-zones">La Stratégie 4 : séparer les zones</h2>
<p>L&rsquo;idée : <strong>MCP et Git n&rsquo;écrivent jamais sur les mêmes fichiers</strong>.</p>
<table>
  <thead>
      <tr>
          <th>Zone</th>
          <th>Qui édite</th>
          <th>Versionné dans Git ?</th>
      </tr>
  </thead>
  <tbody>
      <tr>
          <td><code>content/**/*.md</code></td>
          <td><strong>MCP exclusivement</strong></td>
          <td>❌ NON (<code>.gitignore</code>)</td>
      </tr>
      <tr>
          <td><code>layouts/</code>, <code>themes/</code>, <code>static/</code>, <code>hugo.toml</code>, <code>deploy.sh</code></td>
          <td><strong>Git push exclusivement</strong></td>
          <td>✅ OUI</td>
      </tr>
  </tbody>
</table>
<p>Le <code>.gitignore</code> côté repo :</p>
<div class="code-block code-line-numbers open" data-start="0">
    <div class="code-header language-">
        <span class="code-title"><i class="arrow fas fa-angle-right" aria-hidden="true"></i></span>
        <span class="ellipses"><i class="fas fa-ellipsis-h" aria-hidden="true"></i></span>
        <span class="copy" title="Copier dans le presse-papiers"><i class="far fa-copy" aria-hidden="true"></i></span>
    </div><pre tabindex="0"><code>content/
public/
resources/</code></pre></div>
<p>Implications :</p>
<ul>
<li>Le MCP peut écrire dans <code>content/</code> quand il veut. Aucun conflit Git possible.</li>
<li>Tu peux faire <code>git reset --hard</code> côté repo en confiance — <code>content/</code> reste intact.</li>
<li>Pas besoin que le MCP gère une identité Git.</li>
<li>Pas de &ldquo;commit pollution&rdquo;.</li>
</ul>
<h2 id="trade-off--pas-de-versioning-du-contenu">Trade-off : pas de versioning du contenu</h2>
<p>Tu perds le versioning Git du contenu. C&rsquo;est une perte réelle :</p>
<ul>
<li>Pas de <code>git blame</code> sur un article pour voir qui a écrit quoi.</li>
<li>Pas de <code>git log content/csp-nonce/index.fr.md</code> pour voir l&rsquo;historique.</li>
<li>Pas de PR review pour les articles.</li>
</ul>
<p><strong>Mitigation</strong> : snapshots VM + backup <code>content/</code> chiffré quotidien sur QNAP. Ça couvre la <strong>récupération en cas de désastre</strong>, mais pas le versioning fin (qui-a-changé-quoi-quand).</p>
<p>Pour mon homelab perso (un seul auteur, articles techniques, pas de workflow de validation éditoriale), c&rsquo;est un trade-off acceptable. Pour un blog d&rsquo;équipe avec 10 contributeurs, je reconsidérerais.</p>
<h2 id="architecture-finale">Architecture finale</h2>]]></description></item></channel></rss>