[{"data":1,"prerenderedAt":705},["ShallowReactive",2],{"/fr-fr/blog/what-s-new-in-git-2-50-0/":3,"navigation-fr-fr":34,"banner-fr-fr":453,"footer-fr-fr":465,"Justin Tobler":677,"next-steps-fr-fr":690},{"_path":4,"_dir":5,"_draft":6,"_partial":6,"_locale":7,"seo":8,"content":13,"config":24,"_id":27,"_type":28,"title":29,"_source":30,"_file":31,"_stem":32,"_extension":33},"/fr-fr/blog/what-s-new-in-git-2-50-0","blog",false,"",{"noIndex":6,"title":9,"description":10,"ogTitle":9,"ogDescription":11,"ogImage":12},"Nouveautés de Git 2.50.0","Découvrez les contributions de l'équipe Git de GitLab et de la communauté Git, dont git-diff-pairs(1) et git-rev-list(1), pour la mise à jour de références par lot.\n\n\n","Découvrez les contributions de l'équipe Git de GitLab et de la communauté Git, dont git-diff-pairs(1) et git-rev-list(1), pour la mise à jour de références par lot.\n","https://res.cloudinary.com/about-gitlab-com/image/upload/f_auto,q_auto,w_1640,h_1000,c_lfill/v1749663087/Blog/Hero%20Images/git3-cover.png",{"body":14,"title":9,"description":15,"heroImage":12,"authors":16,"date":18,"category":19,"tags":20},"Le projet Git a récemment publié la [version 2.50.0 de Git](https://lore.kernel.org/git/xmqq1prj1umb.fsf@gitster.g/T/#u). Découvrons les points forts de cette nouvelle version, qui comprend les contributions de l'équipe Git de GitLab et de la communauté Git.\n\n## Nouvelle commande git-diff-pairs(1)\n\nLes diffs sont au cœur de chaque revue de code et affichent toutes les modifications apportées entre deux révisions. Dans GitLab, ils apparaissent à plusieurs endroits, généralement dans l'onglet [« Modifications »](https://docs.gitlab.com/user/project/merge_requests/changes/) d'une merge request. En arrière-plan, la génération de diff est optimisée par [`git-diff(1)`](https://git-scm.com/docs/git-diff).\n\nPar exemple :\n\n```shell\n$ git diff HEAD~1 HEAD\n```\n\nCette commande renvoie le diff complet de tous les fichiers modifiés. Son utilisation peut poser un problème d'évolutivité, car le nombre de fichiers modifiés entre différentes versions du code peut être très important, et le backend GitLab risque de dépasser une délai d'attente maximal qu'il s'impose pour exécuter cette commande. Pour les grands ensembles de modifications, il est préférable de pouvoir diviser le calcul des diffs en blocs plus petits et plus faciles à assimiler.\n\nPour ce faire, vous pouvez utiliser [`git-diff-tree(1)`](https://git-scm.com/docs/git-diff-tree/fr) pour récupérer des informations sur tous les fichiers modifiés :\n\n```shell\n$ git diff-tree -r -M --abbrev HEAD~ HEAD\n:100644 100644 c9adfed339 99acf81487 M Documentation/RelNotes/2.50.0.adoc\n:100755 100755 1047b8d11d 208e91a17f M GIT-VERSION-GEN\n```\n\nGit appelle ce résultat le [format « brut »](https://git-scm.com/docs/git-diff-tree/fr). En bref, chaque ligne de sortie répertorie les paires de fichiers et les métadonnées associées en lien avec les modifications apportées entre les révisions de début et de fin. En comparaison avec la génération de la sortie de « correctif » pour les modifications importantes, ce processus est relativement rapide et fournit un résumé de tous les éléments qui ont été modifiés. Cette commande peut éventuellement effectuer détection de changement de nom en ajoutant `-M` pour vérifier si les modifications identifiées étaient dues à un changement de nom de fichier.\n\nAvec ces informations, nous pourrions utiliser `git-diff(1)` pour calculer chacun des diffs de paire de fichiers individuellement.\n\\\nPar exemple, nous pouvons fournir directement des ID de blob :\n\n```shell\n$ git diff 1047b8d11de767d290170979a9a20de1f5692e26 208e91a17f04558ca66bc19d73457ca64d5385f\n```\n\nNous pouvons répéter ce processus pour chacune des paires de fichiers, mais lancer un processus Git distinct pour chaque diff de fichier n'est pas une approche efficace. De plus, lorsque vous utilisez des ID de blob, le diff perd certaines informations contextuelles telles que le statut de modification et les modes de fichier qui sont stockés dans l'objet arbre parent. En réalité, nous avons besoin d'un mécanisme permettant d'alimenter des informations « brutes » sur les paires de fichiers et de générer la sortie de correctifs correspondants.\n\nAvec la version 2.50.0, Git dispose d’une nouvelle commande intégrée `git-diff-pairs(1)`, qui prend en charge les informations de paires de fichiers au format « brut » en tant qu'entrée sur stdin pour déterminer avec précision les correctifs à générer.\n\nL'exemple suivant montre comment cette commande peut être utilisée :\n\n```shell\n$ git diff-tree -r -z -M HEAD~ HEAD | git diff-pairs -z\n```\n\nDe cette façon, la sortie générée est identique à celle obtenue avec `git-diff(1)`. En utilisant une commande distincte pour générer la sortie de correctif, la sortie « brute » de `git-diff-tree(1)` peut être divisée en lots plus petits de paires de fichiers et envoyée vers des processus `git-diff-pairs(1)` distincts. Cette approche résout le problème d'évolutivité mentionné précédemment, car le calcul des diffs ne s'effectue plus en une seule fois. Les futures versions de GitLab pourraient s'appuyer sur ce mécanisme pour améliorer les performances de génération de diff, en particulier lorsque de grands ensembles de modifications sont concernés.\n\nPour plus d'informations sur ce changement, consultez ce [fil de discussion](https://lore.kernel.org/git/20250228213346.1335224-1-jltobler@gmail.com/).\n\\\nCe projet a été mené par [Justin Tobler](https://gitlab.com/justintobler).\n\n## Mises à jour des références par lots\n\nGit fournit la commande `git-update-ref(1)` pour effectuer des mises à jour de références. Lorsqu'elle est associée à `--stdin`, il est possible de regrouper plusieurs mises à jour de références en une seule transaction en indiquant des instructions pour chaque mise à jour à effectuer sur stdin. La mise à jour des références par lot offre également un comportement atomique : si une seule mise à jour échoue, la transaction est annulée et aucune référence n'est mise à jour.\n\nVoici un exemple illustrant ce comportement :\n\n```shell\n# Create repository with three empty commits and branch named \"foo\"\n$ git init\n$ git commit --allow-empty -m 1\n$ git commit --allow-empty -m 2\n$ git commit --allow-empty -m 3\n$ git branch foo\n# Print out the commit IDs\n$ git rev-list HEAD\ncf469bdf5436ea1ded57670b5f5a0797f72f1afc\n5a74cd330f04b96ce0666af89682d4d7580c354c\n5a6b339a8ebffde8c0590553045403dbda831518\n# Attempt to create a new reference and update existing reference in transaction.\n# Update is expected to fail because the specified old object ID doesn’t match.\n$ git update-ref --stdin \u003C\u003CEOF\n> create refs/heads/bar cf469bdf5436ea1ded57670b5f5a0797f72f1afc\n> update refs/heads/foo 5a6b339a8ebffde8c0590553045403dbda831518 5a74cd330f04b96ce0666af89682d4d7580c354c\n> EOF\nfatal: cannot lock ref 'refs/heads/foo': is at cf469bdf5436ea1ded57670b5f5a0797f72f1afc but expected 5a74cd330f04b96ce0666af89682d4d7580c354c\n# The \"bar\" reference was not created.\n$ git switch bar\nfatal: invalid reference: bar\n```\n\nEn comparaison avec la mise à jour de nombreuses références une par une, la mise à jour par lot est également beaucoup plus efficace. Toutefois, dans certaines circonstances, il peut être acceptable qu'un sous-ensemble des mises à jour de références demandées échoue. Cela ne remet pas en cause les gains de productivité obtenus grâce aux mises à jour par lot.\n\nAvec cette version, `git-update-ref(1)` met à disposition la nouvelle option `--batch-updates`, qui permet aux mises à jour de se poursuivre même lorsqu'une ou plusieurs mises à jour de références échouent.\n\nDans ce mode, les échecs individuels sont signalés dans le format suivant :\n\n```text\nrejected SP (\u003Cold-oid> | \u003Cold-target>) SP (\u003Cnew-oid> | \u003Cnew-target>) SP \u003Crejection-reason> LF\n```\n\nCela permet de poursuivre les mises à jour de références réussies, tout en fournissant un contexte indiquant celles qui ont été rejetées et pour quelle raison.\n\nVoici ce que nous obtenons en utilisant le même exemple de dépôt que dans l'exemple précédent :\n\n```shell\n# Attempt to create a new reference and update existing reference in transaction.\n$ git update-ref --stdin --batch-updates \u003C\u003CEOF\n> create refs/heads/bar cf469bdf5436ea1ded57670b5f5a0797f72f1afc\n> update refs/heads/foo 5a6b339a8ebffde8c0590553045403dbda831518 5a74cd330f04b96ce0666af89682d4d7580c354c\n> EOF\nrejected refs/heads/foo 5a6b339a8ebffde8c0590553045403dbda831518 5a74cd330f04b96ce0666af89682d4d7580c354c incorrect old value provided\n# The \"bar\" reference was created even though the update to \"foo\" was rejected.\n$ git switch bar\nSwitched to branch 'bar'\n```\n\nCette fois, avec l'option `--batch-updates`, la création de la référence a réussi même si la mise à jour n'a pas fonctionné. Cette série de correctifs est un aperçu des futures améliorations des performances de `git-fetch(1)` et `git-receive-pack(1)` lors de la mise à jour de références par lot.\n\nPour plus d'informations, consultez ce [fil de discussion](https://lore.kernel.org/git/20250408085120.614893-1-karthik.188@gmail.com/).\n\nCe projet a été mené par [Karthik Nayak](https://gitlab.com/knayakgl).\n\n## Nouvelle option de filtre pour git-cat-file(1)\n\nAvec `git-cat-file(1)`, il est possible d’afficher des informations pour tous les objets contenus dans le dépôt via l'option `--batch–all-objects`.\n\nEn voici un exemple :\n\n```shell\n# Setup simple repository.\n$ git init\n$ echo foo >foo\n$ git add foo\n$ git commit -m init\n# Create an unreachable object.\n$ git commit --amend --no-edit\n# Use git-cat-file(1) to print info about all objects including unreachable objects.\n$ git cat-file --batch-all-objects --batch-check='%(objecttype) %(objectname)'\ncommit 0b07e71d14897f218f23d9a6e39605b466454ece\ntree 205f6b799e7d5c2524468ca006a0131aa57ecce7\nblob 257cc5642cb1a054f08cc83f2d943e56fd3ebe99\ncommit c999f781fd7214b3caab82f560ffd079ddad0115\n```\n\nDans certains cas, un utilisateur peut effectuer une recherche dans tous les objets du dépôt, mais n'afficher qu'un sous-ensemble basé sur un attribut spécifique.\n\nPar exemple, si nous voulons voir uniquement les objets qui correspondent à des commits, nous pouvons utiliser `grep(1)` :\n\n```shell\n$ git cat-file --batch-all-objects --batch-check='%(objecttype) %(objectname)' | grep ^commit\ncommit 0b07e71d14897f218f23d9a6e39605b466454ece\ncommit c999f781fd7214b3caab82f560ffd079ddad0115\n```\n\nBien que cela fonctionne, un des inconvénients du filtrage de la sortie est que `git-cat-file(1)` doit toujours parcourir tous les objets du dépôt, même ceux qui n'intéressent pas l'utilisateur. Cette approche peut se révéler assez inefficace.\n\nAvec la version 2.50.0, `git-cat-file(1)` dispose désormais de l'option `--filter`, qui n'affiche que les objets correspondant aux critères spécifiés. Celle-ci est similaire à l'option du même nom pour `git-rev-list(1)`, mais seul un sous-ensemble des filtres est pris en charge : `blob:none`, `blob:limit=`, ainsi que `object:type=`.\n\nComme dans l'exemple précédent, il est possible de filtrer les objets par type avec [Git](https://about.gitlab.com/fr-fr/blog/what-is-git/ \"Qu'est-ce que Git ?\") directement :\n\n```shell\n$ git cat-file --batch-all-objects --batch-check='%(objecttype) %(objectname)' --filter='object:type=commit'\ncommit 0b07e71d14897f218f23d9a6e39605b466454ece\ncommit c999f781fd7214b3caab82f560ffd079ddad0115\n```\n\nCette approche facilite le traitement par Git, mais également la recherche dans les grands dépôts contenant de nombreux objets. Si un dépôt dispose d'index bitmap, Git peut rechercher efficacement des objets d'un type spécifique, sans scanner le fichier d'empaquetage («packfile»), ce qui accélère de manière considérable le processus.\n\nLes benchmarks effectués sur le [dépôt Chromium](https://github.com/chromium/chromium.git) montrent des améliorations significatives :\n\n```text\nBenchmark 1: git cat-file --batch-check --batch-all-objects --unordered --buffer --no-filter\nTime (mean ± σ): 82.806 s ± 6.363 s [User: 30.956 s, System: 8.264 s]\nRange (min … max): 73.936 s … 89.690 s 10 runs\nBenchmark 2: git cat-file --batch-check --batch-all-objects --unordered --buffer --filter=object:type=tag\nTime (mean ± σ): 20.8 ms ± 1.3 ms [User: 6.1 ms, System: 14.5 ms]\nRange (min … max): 18.2 ms … 23.6 ms 127 runs\nBenchmark 3: git cat-file --batch-check --batch-all-objects --unordered --buffer --filter=object:type=commit\nTime (mean ± σ): 1.551 s ± 0.008 s [User: 1.401 s, System: 0.147 s]\nRange (min … max): 1.541 s … 1.566 s 10 runs\nBenchmark 4: git cat-file --batch-check --batch-all-objects --unordered --buffer --filter=object:type=tree\nTime (mean ± σ): 11.169 s ± 0.046 s [User: 10.076 s, System: 1.063 s]\nRange (min … max): 11.114 s … 11.245 s 10 runs\nBenchmark 5: git cat-file --batch-check --batch-all-objects --unordered --buffer --filter=object:type=blob\nTime (mean ± σ): 67.342 s ± 3.368 s [User: 20.318 s, System: 7.787 s]\nRange (min … max): 62.836 s … 73.618 s 10 runs\nBenchmark 6: git cat-file --batch-check --batch-all-objects --unordered --buffer --filter=blob:none\nTime (mean ± σ): 13.032 s ± 0.072 s [User: 11.638 s, System: 1.368 s]\nRange (min … max): 12.960 s … 13.199 s 10 runs\nSummary\ngit cat-file --batch-check --batch-all-objects --unordered --buffer --filter=object:type=tag\n74.75 ± 4.61 times faster than git cat-file --batch-check --batch-all-objects --unordered --buffer --filter=object:type=commit\n538.17 ± 33.17 times faster than git cat-file --batch-check --batch-all-objects --unordered --buffer --filter=object:type=tree\n627.98 ± 38.77 times faster than git cat-file --batch-check --batch-all-objects --unordered --buffer --filter=blob:none\n3244.93 ± 257.23 times faster than git cat-file --batch-check --batch-all-objects --unordered --buffer --filter=object:type=blob\n3990.07 ± 392.72 times faster than git cat-file --batch-check --batch-all-objects --unordered --buffer --no-filter\n```\n\nIl est intéressant de noter que ces résultats indiquent que le temps de calcul est maintenant proportionnel au nombre d'objets pour un type donné plutôt qu'au nombre total d'objets dans le fichier d'empaquetage. Pour plus d'informations, consultez ce [fil de discussion](https://lore.kernel.org/git/20250221-pks-cat-file-object-type-filter-v1-0-0852530888e2@pks.im/).\n\n*Ce projet a été mené par [Patrick Steinhardt](https://gitlab.com/pks-gitlab).*\n\n## Amélioration des performances lors de la génération de paquets\n\nAvec Git, vous pouvez générer une archive d'un dépôt qui contient un ensemble spécifié de références et d'objets accessibles qui l'accompagnent via la commande [`git-bundle(1)`](https://git-scm.com/docs/git-bundle/fr). Cette opération est utilisée par GitLab pour générer des sauvegardes de dépôt et dans le cadre du mécanisme [`bundle-URI`](https://git-scm.com/docs/bundle-uri).\n\nPour les grands dépôts contenant des millions de références, cette opération peut prendre plusieurs heures, voire même plusieurs jours. Par exemple, avec le dépôt principal de GitLab ([gitlab-org/gitlab](https://gitlab.com/gitlab-org/gitlab)), les temps de sauvegarde étaient d'environ 48 heures. Des recherches ont révélé la présence d'un goulot d'étranglement des performances en raison de la façon dont Git effectuait une vérification pour éviter que des références dupliquées ne soient incluses dans le paquet. L'implémentation a utilisé une boucle `for` imbriquée pour itérer et comparer toutes les références répertoriées, ce qui a entraîné une complexité temporelle O(N^2). Cette façon de procéder n'est pas adaptée en cas d'augmentation du nombre de références dans un dépôt.\n\nDans la version 2.50.0, ce problème a été résolu en remplaçant les boucles imbriquées par une structure de données de mappage, ce qui a permis d'accélérer considérablement le processus. Le benchmark suivant montre l'amélioration des performances lors de la création d'un paquet avec un dépôt contenant 100 000 références :\n\n```text\nBenchmark 1: bundle (refcount = 100000, revision = master)\nTime (mean ± σ): 14.653 s ± 0.203 s [User: 13.940 s, System: 0.762 s]\nRange (min … max): 14.237 s … 14.920 s 10 runs\nBenchmark 2: bundle (refcount = 100000, revision = HEAD)\nTime (mean ± σ): 2.394 s ± 0.023 s [User: 1.684 s, System: 0.798 s]\nRange (min … max): 2.364 s … 2.425 s 10 runs\nSummary\nbundle (refcount = 100000, revision = HEAD) ran\n6.12 ± 0.10 times faster than bundle (refcount = 100000, revision = master)\n```\n\nPour en savoir plus, découvrez notre article de blog qui explique [comment nous avons réduit les temps de sauvegarde du dépôt GitLab de 48 heures à 41 minutes](https://about.gitlab.com/blog/how-we-decreased-gitlab-repo-backup-times-from-48-hours-to-41-minutes/) et consultez ce [fil de discussion](https://lore.kernel.org/git/20250401-488-generating-bundles-with-many-references-has-non-linear-performance-v1-0-6d23b2d96557@gmail.com/).\n\n*Ce projet a été mené par [Karthik Nayak](https://gitlab.com/knayakgl).*\n\n## Meilleur dégroupage des URI de paquets\n\nÀ l'aide du mécanisme [bundle-uri](https://git-scm.com/docs/bundle-uri) dans Git, il est possible de fournir aux clients les emplacements pour récupérer les paquets dans le but d'accélérer les clones et les récupérations. Lorsqu'un client télécharge un paquet, les références sous `refs/heads/*` et les objets qui les accompagnent sont copiés du paquet dans le dépôt. Un paquet peut contenir des références supplémentaires en dehors de `refs/heads/*` telles que `refs/tags/*`, qui sont simplement ignorées lors de l'utilisation de l'URI du paquet sur le clone.\n\nDans Git 2.50.0, cette restriction est levée. Par conséquent, toutes les références correspondant à `refs/*` contenues dans le paquet téléchargé sont copiées.\n\n[Scott Chacon](https://github.com/schacon), qui a contribué à cette fonctionnalité, montre la différence lors du clonage de [gitlab-org/gitlab-foss](https://gitlab.com/gitlab-org/gitlab-foss) :\n\n```shell\n$ git-v2.49 clone --bundle-uri=gitlab-base.bundle https://gitlab.com/gitlab-org/gitlab-foss.git gl-2.49\nCloning into 'gl2.49'...\nremote: Enumerating objects: 1092703, done.\nremote: Counting objects: 100% (973405/973405), done.\nremote: Compressing objects: 100% (385827/385827), done.\nremote: Total 959773 (delta 710976), reused 766809 (delta 554276), pack-reused 0 (from 0)\nReceiving objects: 100% (959773/959773), 366.94 MiB | 20.87 MiB/s, done.\nResolving deltas: 100% (710976/710976), completed with 9081 local objects.\nChecking objects: 100% (4194304/4194304), done.\nChecking connectivity: 959668, done.\nUpdating files: 100% (59972/59972), done.\n$ git-v2.50 clone --bundle-uri=gitlab-base.bundle https://gitlab.com/gitlab-org/gitlab-foss.git gl-2.50\nCloning into 'gl-2.50'...\nremote: Enumerating objects: 65538, done.\nremote: Counting objects: 100% (56054/56054), done.\nremote: Compressing objects: 100% (28950/28950), done.\nremote: Total 43877 (delta 27401), reused 25170 (delta 13546), pack-reused 0 (from 0)\nReceiving objects: 100% (43877/43877), 40.42 MiB | 22.27 MiB/s, done.\nResolving deltas: 100% (27401/27401), completed with 8564 local objects.\nUpdating files: 100% (59972/59972), done.\n```\n\nEn comparant ces résultats, nous constatons que Git 2.50.0 récupère 43 887 objets (40,42 MiB) après l'extraction du paquet, tandis que Git 2.49.0 récupère un total de 959 773 objets (366,94 MiB). Git 2.50.0 récupère environ 95 % d'objets en moins et 90 % de données en moins, ce qui est avantageux aussi bien pour le client que le serveur. Le serveur doit traiter beaucoup moins de données à destination du client, et ce dernier doit télécharger et extraire moins de données. Dans l'exemple fourni par Scott, cela a conduit à une accélération de 25 %.\n\nPour en savoir plus, consultez ce [fil de discussion](https://lore.kernel.org/git/pull.1897.git.git.1740489585344.gitgitgadget@gmail.com/).\n\n*Cette série de correctifs a été fournie par Scott Chacon.*\n\n## En savoir plus\n\nCet article n'a mis en évidence que quelques-unes des contributions apportées par GitLab et la communauté Git pour cette nouvelle version. Vous pouvez approfondir ce sujet en lisant [l'annonce officielle](https://lore.kernel.org/git/xmqqa5fg9bsz.fsf@gitster.g/) du projet Git et en consultant ces [ressources](https://about.gitlab.com/blog/tags/git/).","Découvrez les contributions de l'équipe Git de GitLab et de la communauté Git, dont git-diff-pairs(1) et git-rev-list(1), pour la mise à jour de références par lot.",[17],"Justin Tobler","2025-07-02","open-source",[21,22,23],"community","git","open source",{"featured":6,"template":25,"slug":26},"BlogPost","what-s-new-in-git-2-50-0","content:fr-fr:blog:what-s-new-in-git-2-50-0.yml","yaml","What S New In Git 2 50 0","content","fr-fr/blog/what-s-new-in-git-2-50-0.yml","fr-fr/blog/what-s-new-in-git-2-50-0","yml",{"_path":35,"_dir":36,"_draft":6,"_partial":6,"_locale":7,"data":37,"_id":449,"_type":28,"title":450,"_source":30,"_file":451,"_stem":452,"_extension":33},"/shared/fr-fr/main-navigation","fr-fr",{"logo":38,"freeTrial":43,"sales":48,"login":53,"items":58,"search":390,"minimal":426,"duo":440},{"config":39},{"href":40,"dataGaName":41,"dataGaLocation":42},"/fr-fr/","gitlab logo","header",{"text":44,"config":45},"Commencer un essai gratuit",{"href":46,"dataGaName":47,"dataGaLocation":42},"https://gitlab.com/-/trial_registrations/new?glm_source=about.gitlab.com&glm_content=default-saas-trial/","free trial",{"text":49,"config":50},"Contacter l'équipe commerciale",{"href":51,"dataGaName":52,"dataGaLocation":42},"/fr-fr/sales/","sales",{"text":54,"config":55},"Connexion",{"href":56,"dataGaName":57,"dataGaLocation":42},"https://gitlab.com/users/sign_in/","sign in",[59,103,202,207,311,371],{"text":60,"config":61,"cards":63,"footer":86},"Plateforme",{"dataNavLevelOne":62},"platform",[64,70,78],{"title":60,"description":65,"link":66},"La plateforme DevSecOps alimentée par l'IA la plus complète",{"text":67,"config":68},"Découvrir notre plateforme",{"href":69,"dataGaName":62,"dataGaLocation":42},"/fr-fr/platform/",{"title":71,"description":72,"link":73},"GitLab Duo (IA)","Créez des logiciels plus rapidement en tirant parti de l'IA à chaque étape du développement",{"text":74,"config":75},"Découvrez GitLab Duo",{"href":76,"dataGaName":77,"dataGaLocation":42},"/fr-fr/gitlab-duo/","gitlab duo ai",{"title":79,"description":80,"link":81},"Choisir GitLab","10 raisons pour lesquelles les entreprises choisissent GitLab",{"text":82,"config":83},"En savoir plus",{"href":84,"dataGaName":85,"dataGaLocation":42},"/fr-fr/why-gitlab/","why gitlab",{"title":87,"items":88},"Démarrer avec",[89,94,99],{"text":90,"config":91},"Ingénierie de plateforme",{"href":92,"dataGaName":93,"dataGaLocation":42},"/fr-fr/solutions/platform-engineering/","platform engineering",{"text":95,"config":96},"Expérience développeur",{"href":97,"dataGaName":98,"dataGaLocation":42},"/fr-fr/developer-experience/","Developer experience",{"text":100,"config":101},"MLOps",{"href":102,"dataGaName":100,"dataGaLocation":42},"/fr-fr/topics/devops/the-role-of-ai-in-devops/",{"text":104,"left":105,"config":106,"link":108,"lists":112,"footer":184},"Produit",true,{"dataNavLevelOne":107},"solutions",{"text":109,"config":110},"Voir toutes les solutions",{"href":111,"dataGaName":107,"dataGaLocation":42},"/fr-fr/solutions/",[113,139,162],{"title":114,"description":115,"link":116,"items":121},"Automatisation","CI/CD et automatisation pour accélérer le déploiement",{"config":117},{"icon":118,"href":119,"dataGaName":120,"dataGaLocation":42},"AutomatedCodeAlt","/fr-fr/solutions/delivery-automation/","automated software delivery",[122,126,130,135],{"text":123,"config":124},"CI/CD",{"href":125,"dataGaLocation":42,"dataGaName":123},"/fr-fr/solutions/continuous-integration/",{"text":127,"config":128},"Développement assisté par l'IA",{"href":76,"dataGaLocation":42,"dataGaName":129},"AI assisted development",{"text":131,"config":132},"Gestion du code source",{"href":133,"dataGaLocation":42,"dataGaName":134},"/fr-fr/solutions/source-code-management/","Source Code Management",{"text":136,"config":137},"Livraison de logiciels automatisée",{"href":119,"dataGaLocation":42,"dataGaName":138},"Automated software delivery",{"title":140,"description":141,"link":142,"items":147},"Securité","Livrez du code plus rapidement sans compromettre la sécurité",{"config":143},{"href":144,"dataGaName":145,"dataGaLocation":42,"icon":146},"/fr-fr/solutions/security-compliance/","security and compliance","ShieldCheckLight",[148,152,157],{"text":149,"config":150},"Sécurité et conformité",{"href":144,"dataGaLocation":42,"dataGaName":151},"Security & Compliance",{"text":153,"config":154},"Sécurité de la chaîne d'approvisionnement logicielle",{"href":155,"dataGaLocation":42,"dataGaName":156},"/fr-fr/solutions/supply-chain/","Software supply chain security",{"text":158,"config":159},"Conformité et gouvernance",{"href":160,"dataGaLocation":42,"dataGaName":161},"/fr-fr/solutions/continuous-software-compliance/","Compliance and governance",{"title":163,"link":164,"items":169},"Mesures",{"config":165},{"icon":166,"href":167,"dataGaName":168,"dataGaLocation":42},"DigitalTransformation","/fr-fr/solutions/visibility-measurement/","visibility and measurement",[170,174,179],{"text":171,"config":172},"Visibilité et mesures",{"href":167,"dataGaLocation":42,"dataGaName":173},"Visibility and Measurement",{"text":175,"config":176},"Gestion de la chaîne de valeur",{"href":177,"dataGaLocation":42,"dataGaName":178},"/fr-fr/solutions/value-stream-management/","Value Stream Management",{"text":180,"config":181},"Données d'analyse et informations clés",{"href":182,"dataGaLocation":42,"dataGaName":183},"/fr-fr/solutions/analytics-and-insights/","Analytics and insights",{"title":185,"items":186},"GitLab pour",[187,192,197],{"text":188,"config":189},"Entreprises",{"href":190,"dataGaLocation":42,"dataGaName":191},"/fr-fr/enterprise/","enterprise",{"text":193,"config":194},"PME",{"href":195,"dataGaLocation":42,"dataGaName":196},"/fr-fr/small-business/","small business",{"text":198,"config":199},"Secteur public",{"href":200,"dataGaLocation":42,"dataGaName":201},"/fr-fr/solutions/public-sector/","public sector",{"text":203,"config":204},"Tarifs",{"href":205,"dataGaName":206,"dataGaLocation":42,"dataNavLevelOne":206},"/fr-fr/pricing/","pricing",{"text":208,"config":209,"link":211,"lists":215,"feature":298},"Ressources",{"dataNavLevelOne":210},"resources",{"text":212,"config":213},"Afficher toutes les ressources",{"href":214,"dataGaName":210,"dataGaLocation":42},"/fr-fr/resources/",[216,249,271],{"title":217,"items":218},"Premiers pas",[219,224,229,234,239,244],{"text":220,"config":221},"Installation",{"href":222,"dataGaName":223,"dataGaLocation":42},"/fr-fr/install/","install",{"text":225,"config":226},"Guides de démarrage rapide",{"href":227,"dataGaName":228,"dataGaLocation":42},"/fr-fr/get-started/","quick setup checklists",{"text":230,"config":231},"Apprentissage",{"href":232,"dataGaLocation":42,"dataGaName":233},"https://university.gitlab.com/","learn",{"text":235,"config":236},"Documentation sur le produit",{"href":237,"dataGaName":238,"dataGaLocation":42},"https://docs.gitlab.com/","product documentation",{"text":240,"config":241},"Vidéos sur les bonnes pratiques",{"href":242,"dataGaName":243,"dataGaLocation":42},"/fr-fr/getting-started-videos/","best practice videos",{"text":245,"config":246},"Intégrations",{"href":247,"dataGaName":248,"dataGaLocation":42},"/fr-fr/integrations/","integrations",{"title":250,"items":251},"Découvrir",[252,257,261,266],{"text":253,"config":254},"Histoires de succès client",{"href":255,"dataGaName":256,"dataGaLocation":42},"/fr-fr/customers/","customer success stories",{"text":258,"config":259},"Blog",{"href":260,"dataGaName":5,"dataGaLocation":42},"/fr-fr/blog/",{"text":262,"config":263},"Travail à distance",{"href":264,"dataGaName":265,"dataGaLocation":42},"https://handbook.gitlab.com/handbook/company/culture/all-remote/","remote",{"text":267,"config":268},"TeamOps",{"href":269,"dataGaName":270,"dataGaLocation":42},"/fr-fr/teamops/","teamops",{"title":272,"items":273},"Connecter",[274,279,283,288,293],{"text":275,"config":276},"Services GitLab",{"href":277,"dataGaName":278,"dataGaLocation":42},"/fr-fr/services/","services",{"text":280,"config":281},"Communauté",{"href":282,"dataGaName":21,"dataGaLocation":42},"/community/",{"text":284,"config":285},"Forum",{"href":286,"dataGaName":287,"dataGaLocation":42},"https://forum.gitlab.com/","forum",{"text":289,"config":290},"Événements",{"href":291,"dataGaName":292,"dataGaLocation":42},"/events/","events",{"text":294,"config":295},"Partenaires",{"href":296,"dataGaName":297,"dataGaLocation":42},"/fr-fr/partners/","partners",{"backgroundColor":299,"textColor":300,"text":301,"image":302,"link":306},"#2f2a6b","#fff","L'avenir du développement logiciel. Tendances et perspectives.",{"altText":303,"config":304},"carte promo The Source",{"src":305},"/images/navigation/the-source-promo-card.svg",{"text":307,"config":308},"Lire les articles les plus récents",{"href":309,"dataGaName":310,"dataGaLocation":42},"/fr-fr/the-source/","the source",{"text":312,"config":313,"lists":315},"Société",{"dataNavLevelOne":314},"company",[316],{"items":317},[318,323,329,331,336,341,346,351,356,361,366],{"text":319,"config":320},"À propos",{"href":321,"dataGaName":322,"dataGaLocation":42},"/fr-fr/company/","about",{"text":324,"config":325,"footerGa":328},"Emplois",{"href":326,"dataGaName":327,"dataGaLocation":42},"/jobs/","jobs",{"dataGaName":327},{"text":289,"config":330},{"href":291,"dataGaName":292,"dataGaLocation":42},{"text":332,"config":333},"Leadership",{"href":334,"dataGaName":335,"dataGaLocation":42},"/company/team/e-group/","leadership",{"text":337,"config":338},"Équipe",{"href":339,"dataGaName":340,"dataGaLocation":42},"/company/team/","team",{"text":342,"config":343},"Manuel",{"href":344,"dataGaName":345,"dataGaLocation":42},"https://handbook.gitlab.com/","handbook",{"text":347,"config":348},"Relations avec les investisseurs",{"href":349,"dataGaName":350,"dataGaLocation":42},"https://ir.gitlab.com/","investor relations",{"text":352,"config":353},"Centre de confiance",{"href":354,"dataGaName":355,"dataGaLocation":42},"/fr-fr/security/","trust center",{"text":357,"config":358},"Centre pour la transparence de l'IA",{"href":359,"dataGaName":360,"dataGaLocation":42},"/fr-fr/ai-transparency-center/","ai transparency center",{"text":362,"config":363},"Newsletter",{"href":364,"dataGaName":365,"dataGaLocation":42},"/company/contact/","newsletter",{"text":367,"config":368},"Presse",{"href":369,"dataGaName":370,"dataGaLocation":42},"/press/","press",{"text":372,"config":373,"lists":374},"Nous contacter",{"dataNavLevelOne":314},[375],{"items":376},[377,380,385],{"text":49,"config":378},{"href":51,"dataGaName":379,"dataGaLocation":42},"talk to sales",{"text":381,"config":382},"Aide",{"href":383,"dataGaName":384,"dataGaLocation":42},"/support/","get help",{"text":386,"config":387},"Portail clients GitLab",{"href":388,"dataGaName":389,"dataGaLocation":42},"https://customers.gitlab.com/customers/sign_in/","customer portal",{"close":391,"login":392,"suggestions":399},"Fermer",{"text":393,"link":394},"Pour rechercher des dépôts et des projets, connectez-vous à",{"text":395,"config":396},"gitlab.com",{"href":56,"dataGaName":397,"dataGaLocation":398},"search login","search",{"text":400,"default":401},"Suggestions",[402,405,410,412,417,422],{"text":71,"config":403},{"href":76,"dataGaName":404,"dataGaLocation":398},"GitLab Duo (AI)",{"text":406,"config":407},"Suggestions de code (IA)",{"href":408,"dataGaName":409,"dataGaLocation":398},"/fr-fr/solutions/code-suggestions/","Code Suggestions (AI)",{"text":123,"config":411},{"href":125,"dataGaName":123,"dataGaLocation":398},{"text":413,"config":414},"GitLab sur AWS",{"href":415,"dataGaName":416,"dataGaLocation":398},"/fr-fr/partners/technology-partners/aws/","GitLab on AWS",{"text":418,"config":419},"GitLab sur Google Cloud ",{"href":420,"dataGaName":421,"dataGaLocation":398},"/fr-fr/partners/technology-partners/google-cloud-platform/","GitLab on Google Cloud",{"text":423,"config":424},"Pourquoi utiliser GitLab ?",{"href":84,"dataGaName":425,"dataGaLocation":398},"Why GitLab?",{"freeTrial":427,"mobileIcon":432,"desktopIcon":437},{"text":428,"config":429},"Commencer votre essai gratuit",{"href":430,"dataGaName":47,"dataGaLocation":431},"https://gitlab.com/-/trials/new/","nav",{"altText":433,"config":434},"Icône GitLab",{"src":435,"dataGaName":436,"dataGaLocation":431},"/images/brand/gitlab-logo-tanuki.svg","gitlab icon",{"altText":433,"config":438},{"src":439,"dataGaName":436,"dataGaLocation":431},"/images/brand/gitlab-logo-type.svg",{"freeTrial":441,"mobileIcon":445,"desktopIcon":447},{"text":442,"config":443},"En savoir plus sur GitLab Duo",{"href":76,"dataGaName":444,"dataGaLocation":431},"gitlab duo",{"altText":433,"config":446},{"src":435,"dataGaName":436,"dataGaLocation":431},{"altText":433,"config":448},{"src":439,"dataGaName":436,"dataGaLocation":431},"content:shared:fr-fr:main-navigation.yml","Main Navigation","shared/fr-fr/main-navigation.yml","shared/fr-fr/main-navigation",{"_path":454,"_dir":36,"_draft":6,"_partial":6,"_locale":7,"title":455,"button":456,"config":460,"_id":462,"_type":28,"_source":30,"_file":463,"_stem":464,"_extension":33},"/shared/fr-fr/banner","GitLab Duo Agent Platform est maintenant disponible en version bêta publique !",{"text":82,"config":457},{"href":458,"dataGaName":459,"dataGaLocation":42},"/gitlab-duo/agent-platform/","duo banner",{"layout":461},"release","content:shared:fr-fr:banner.yml","shared/fr-fr/banner.yml","shared/fr-fr/banner",{"_path":466,"_dir":36,"_draft":6,"_partial":6,"_locale":7,"data":467,"_id":673,"_type":28,"title":674,"_source":30,"_file":675,"_stem":676,"_extension":33},"/shared/fr-fr/main-footer",{"text":468,"source":469,"edit":475,"contribute":480,"config":485,"items":490,"minimal":664},"Git est une marque déposée de Software Freedom Conservancy et notre utilisation de « GitLab » est sous licence",{"text":470,"config":471},"Afficher le code source de la page",{"href":472,"dataGaName":473,"dataGaLocation":474},"https://gitlab.com/gitlab-com/marketing/digital-experience/about-gitlab-com/","page source","footer",{"text":476,"config":477},"Modifier cette page",{"href":478,"dataGaName":479,"dataGaLocation":474},"https://gitlab.com/gitlab-com/marketing/digital-experience/about-gitlab-com/-/blob/main/content/","web ide",{"text":481,"config":482},"Veuillez contribuer",{"href":483,"dataGaName":484,"dataGaLocation":474},"https://gitlab.com/gitlab-com/marketing/digital-experience/about-gitlab-com/-/blob/main/CONTRIBUTING.md/","please contribute",{"twitter":486,"facebook":487,"youtube":488,"linkedin":489},"https://twitter.com/gitlab","https://www.facebook.com/gitlab","https://www.youtube.com/channel/UCnMGQ8QHMAnVIsI3xJrihhg","https://www.linkedin.com/company/gitlab-com",[491,514,568,601,635],{"title":60,"links":492,"subMenu":497},[493],{"text":494,"config":495},"Plateforme DevSecOps",{"href":69,"dataGaName":496,"dataGaLocation":474},"devsecops platform",[498],{"title":203,"links":499},[500,504,509],{"text":501,"config":502},"Voir les forfaits",{"href":205,"dataGaName":503,"dataGaLocation":474},"view plans",{"text":505,"config":506},"Pourquoi choisir GitLab Premium ?",{"href":507,"dataGaName":508,"dataGaLocation":474},"/fr-fr/pricing/premium/","why premium",{"text":510,"config":511},"Pourquoi choisir GitLab Ultimate ?",{"href":512,"dataGaName":513,"dataGaLocation":474},"/fr-fr/pricing/ultimate/","why ultimate",{"title":515,"links":516},"Solutions",[517,522,525,527,532,537,541,544,547,552,554,556,558,563],{"text":518,"config":519},"Transformation digitale",{"href":520,"dataGaName":521,"dataGaLocation":474},"/fr-fr/topics/digital-transformation/","digital transformation",{"text":149,"config":523},{"href":144,"dataGaName":524,"dataGaLocation":474},"security & compliance",{"text":136,"config":526},{"href":119,"dataGaName":120,"dataGaLocation":474},{"text":528,"config":529},"Développement agile",{"href":530,"dataGaName":531,"dataGaLocation":474},"/fr-fr/solutions/agile-delivery/","agile delivery",{"text":533,"config":534},"Transformation cloud",{"href":535,"dataGaName":536,"dataGaLocation":474},"/fr-fr/topics/cloud-native/","cloud transformation",{"text":538,"config":539},"SCM",{"href":133,"dataGaName":540,"dataGaLocation":474},"source code management",{"text":123,"config":542},{"href":125,"dataGaName":543,"dataGaLocation":474},"continuous integration & delivery",{"text":175,"config":545},{"href":177,"dataGaName":546,"dataGaLocation":474},"value stream management",{"text":548,"config":549},"GitOps",{"href":550,"dataGaName":551,"dataGaLocation":474},"/fr-fr/solutions/gitops/","gitops",{"text":188,"config":553},{"href":190,"dataGaName":191,"dataGaLocation":474},{"text":193,"config":555},{"href":195,"dataGaName":196,"dataGaLocation":474},{"text":198,"config":557},{"href":200,"dataGaName":201,"dataGaLocation":474},{"text":559,"config":560},"Formation",{"href":561,"dataGaName":562,"dataGaLocation":474},"/fr-fr/solutions/education/","education",{"text":564,"config":565},"Services financiers",{"href":566,"dataGaName":567,"dataGaLocation":474},"/fr-fr/solutions/finance/","financial services",{"title":208,"links":569},[570,572,574,576,579,581,585,587,589,591,593,595,597,599],{"text":220,"config":571},{"href":222,"dataGaName":223,"dataGaLocation":474},{"text":225,"config":573},{"href":227,"dataGaName":228,"dataGaLocation":474},{"text":230,"config":575},{"href":232,"dataGaName":233,"dataGaLocation":474},{"text":235,"config":577},{"href":237,"dataGaName":578,"dataGaLocation":474},"docs",{"text":258,"config":580},{"href":260,"dataGaName":5},{"text":582,"config":583},"Histoires de réussite client",{"href":584,"dataGaLocation":474},"/customers/",{"text":253,"config":586},{"href":255,"dataGaName":256,"dataGaLocation":474},{"text":262,"config":588},{"href":264,"dataGaName":265,"dataGaLocation":474},{"text":275,"config":590},{"href":277,"dataGaName":278,"dataGaLocation":474},{"text":267,"config":592},{"href":269,"dataGaName":270,"dataGaLocation":474},{"text":280,"config":594},{"href":282,"dataGaName":21,"dataGaLocation":474},{"text":284,"config":596},{"href":286,"dataGaName":287,"dataGaLocation":474},{"text":289,"config":598},{"href":291,"dataGaName":292,"dataGaLocation":474},{"text":294,"config":600},{"href":296,"dataGaName":297,"dataGaLocation":474},{"title":312,"links":602},[603,605,607,609,611,613,615,619,624,626,628,630],{"text":319,"config":604},{"href":321,"dataGaName":314,"dataGaLocation":474},{"text":324,"config":606},{"href":326,"dataGaName":327,"dataGaLocation":474},{"text":332,"config":608},{"href":334,"dataGaName":335,"dataGaLocation":474},{"text":337,"config":610},{"href":339,"dataGaName":340,"dataGaLocation":474},{"text":342,"config":612},{"href":344,"dataGaName":345,"dataGaLocation":474},{"text":347,"config":614},{"href":349,"dataGaName":350,"dataGaLocation":474},{"text":616,"config":617},"Sustainability",{"href":618,"dataGaName":616,"dataGaLocation":474},"/sustainability/",{"text":620,"config":621},"Diversité, inclusion et appartenance (DIB)",{"href":622,"dataGaName":623,"dataGaLocation":474},"/fr-fr/diversity-inclusion-belonging/","Diversity, inclusion and belonging",{"text":352,"config":625},{"href":354,"dataGaName":355,"dataGaLocation":474},{"text":362,"config":627},{"href":364,"dataGaName":365,"dataGaLocation":474},{"text":367,"config":629},{"href":369,"dataGaName":370,"dataGaLocation":474},{"text":631,"config":632},"Déclaration de transparence sur l'esclavage moderne",{"href":633,"dataGaName":634,"dataGaLocation":474},"https://handbook.gitlab.com/handbook/legal/modern-slavery-act-transparency-statement/","modern slavery transparency statement",{"title":372,"links":636},[637,640,642,644,649,654,659],{"text":638,"config":639},"Échanger avec un expert",{"href":51,"dataGaName":52,"dataGaLocation":474},{"text":381,"config":641},{"href":383,"dataGaName":384,"dataGaLocation":474},{"text":386,"config":643},{"href":388,"dataGaName":389,"dataGaLocation":474},{"text":645,"config":646},"Statut",{"href":647,"dataGaName":648,"dataGaLocation":474},"https://status.gitlab.com/","status",{"text":650,"config":651},"Conditions d'utilisation",{"href":652,"dataGaName":653},"/terms/","terms of use",{"text":655,"config":656},"Déclaration de confidentialité",{"href":657,"dataGaName":658,"dataGaLocation":474},"/fr-fr/privacy/","privacy statement",{"text":660,"config":661},"Préférences en matière de cookies",{"dataGaName":662,"dataGaLocation":474,"id":663,"isOneTrustButton":105},"cookie preferences","ot-sdk-btn",{"items":665},[666,668,671],{"text":650,"config":667},{"href":652,"dataGaName":653,"dataGaLocation":474},{"text":669,"config":670},"Politique de confidentialité",{"href":657,"dataGaName":658,"dataGaLocation":474},{"text":660,"config":672},{"dataGaName":662,"dataGaLocation":474,"id":663,"isOneTrustButton":105},"content:shared:fr-fr:main-footer.yml","Main Footer","shared/fr-fr/main-footer.yml","shared/fr-fr/main-footer",[678],{"_path":679,"_dir":680,"_draft":6,"_partial":6,"_locale":7,"content":681,"config":685,"_id":687,"_type":28,"title":17,"_source":30,"_file":688,"_stem":689,"_extension":33},"/en-us/blog/authors/justin-tobler","authors",{"name":17,"config":682},{"headshot":683,"ctfId":684},"https://res.cloudinary.com/about-gitlab-com/image/upload/v1749664737/Blog/Author%20Headshots/james_tobler_headshot.png","5pnOIbNI1Sc5IFnReNHNtv",{"template":686},"BlogAuthor","content:en-us:blog:authors:justin-tobler.yml","en-us/blog/authors/justin-tobler.yml","en-us/blog/authors/justin-tobler",{"_path":691,"_dir":36,"_draft":6,"_partial":6,"_locale":7,"header":692,"eyebrow":693,"blurb":694,"button":695,"secondaryButton":699,"_id":701,"_type":28,"title":702,"_source":30,"_file":703,"_stem":704,"_extension":33},"/shared/fr-fr/next-steps","Commencez à livrer des logiciels de meilleurs qualité plus rapidement","Plus de 50 % des entreprises du classement Fortune 100 font confiance à GitLab","Découvrez comment la plateforme DevSecOps intelligente\n\n\npeut aider votre équipe.\n",{"text":44,"config":696},{"href":697,"dataGaName":47,"dataGaLocation":698},"https://gitlab.com/-/trial_registrations/new?glm_content=default-saas-trial&glm_source=about.gitlab.com/","feature",{"text":49,"config":700},{"href":51,"dataGaName":52,"dataGaLocation":698},"content:shared:fr-fr:next-steps.yml","Next Steps","shared/fr-fr/next-steps.yml","shared/fr-fr/next-steps",1754424544917]