Capitalisation boursière: $2.1775T 0.75%
Volume(24h): $67.2016B -11.18%
Indice de peur et de cupidité:

18 - Peur extrême

  • Capitalisation boursière: $2.1775T 0.75%
  • Volume(24h): $67.2016B -11.18%
  • Indice de peur et de cupidité:
  • Capitalisation boursière: $2.1775T 0.75%
Cryptos
Les sujets
Cryptospedia
Nouvelles
Cryptosopique
Vidéos
Top Cryptospedia

Choisir la langue

Choisir la langue

Sélectionnez la devise

Cryptos
Les sujets
Cryptospedia
Nouvelles
Cryptosopique
Vidéos

Comment mettre à niveau un contrat intelligent à l'aide du modèle de proxy UUPS ?

The UUPS proxy pattern enables secure, gas-efficient smart contract upgrades by separating logic from storage, allowing seamless updates while preserving contract addresses.

Nov 09, 2025 at 01:19 am

Comprendre le modèle de proxy UUPS dans le développement de contrats intelligents

Le modèle UUPS (Universal Upgradeable Proxy Standard) est devenu la pierre angulaire de l'architecture de contrat intelligent basée sur Ethereum, en particulier dans l'espace de la finance décentralisée (DeFi). Cette conception permet aux développeurs de mettre à niveau la logique du contrat sans modifier l'adresse du contrat, préservant ainsi les interactions des utilisateurs et les intégrations entre les plates-formes. Contrairement aux contrats traditionnels qui sont immuables une fois déployés, les contrats évolutifs utilisant UUPS séparent la couche de stockage de la couche logique.

1. Le contrat proxy contient les variables d'état et transmet les appels de fonction à un contrat de mise en œuvre.

  1. Le contrat de mise en œuvre contient la logique métier réelle et peut être remplacé par une version plus récente.
  2. Un mécanisme d'évolutivité minimale est intégré directement dans le contrat de mise en œuvre, réduisant ainsi les frais généraux.
  3. Seuls les rôles d'administrateur ou de gouvernance désignés peuvent déclencher des mises à niveau, garantissant ainsi la sécurité et le contrôle.
  4. La norme UUPS réduit les coûts de gaz lors du déploiement par rapport à d'autres modèles de proxy tels que les proxys transparents.

Étapes pour mettre à niveau un contrat à l'aide d'UUPS

La mise à niveau d'un contrat intelligent via le modèle UUPS implique une planification et une exécution minutieuses pour maintenir l'intégrité du système. Le processus dépend de l'interaction entre le proxy, la mise en œuvre actuelle et le nouveau contrat de mise en œuvre.

1. Développer la nouvelle version du contrat de mise en œuvre, en s'assurant qu'il hérite de la même structure de stockage de base.

  1. Compilez et déployez le nouveau contrat d'implémentation sur la blockchain, en obtenant son adresse.
  2. Appelez la fonction UpgradeTo(address) ou UpgradeToAndCall(address, bytes memory) sur le contrat proxy, en transmettant la nouvelle adresse d'implémentation.
  3. Assurez-vous que l'appelant dispose des privilèges administratifs requis ; sinon, la transaction sera annulée.
  4. Validez la mise à niveau en vérifiant l'adresse d'implémentation mise à jour via l'emplacement de stockage du proxy.

Considérations de sécurité dans les mises à niveau UUPS

La sécurité reste primordiale lors de la gestion des contrats évolutifs. Étant donné que le proxy délègue les appels à une logique mutable, toute faille dans le contrôle d'accès ou la validation logique peut conduire à des exploits irréversibles.

1. Limitez toujours la fonction de mise à niveau aux adresses de confiance ou aux portefeuilles multi-signatures.

  1. Utilisez l'interface UUPSUpgradeable d'OpenZeppelin, qui comprend des protections intégrées contre les mises à niveau non autorisées.
  2. Implémentez un délai ou un délai de gouvernance avant que les mises à niveau ne prennent effet pour permettre les audits des utilisateurs.
  3. Testez minutieusement la nouvelle implémentation dans un environnement de test qui reflète la production.
  4. Surveillez l'activité en chaîne après le déploiement pour détecter rapidement les comportements inattendus.

Défis courants et meilleures pratiques

Bien que le modèle UUPS offre de la flexibilité, il introduit une complexité qui doit être gérée avec discipline. Les développeurs doivent respecter des normes de codage strictes pour éviter les collisions de stockage et les risques de réentrée.

1. Suivez une hiérarchie d'héritage structurée pour éviter les conflits de disposition de stockage entre les versions.

  1. Ne supprimez ou ne réorganisez jamais les variables d'état existantes ; ajoutez-en de nouveaux uniquement à la fin.
  2. Utilisez des contrats ou des interfaces abstraits pour définir des dispositions de stockage de manière cohérente.
  3. Émettez des événements clairs lors des mises à niveau afin que les systèmes hors chaîne puissent suivre les modifications.
  4. Documentez chaque changement de logique et vérifiez la compatibilité avec les interfaces existantes et les services tiers.

Foire aux questions

Que se passe-t-il si le nouveau contrat de mise en œuvre présente un bug après la mise à niveau ? Si un bug critique existe dans la nouvelle implémentation, il peut compromettre toutes les interactions avec le proxy. Étant donné que le proxy délègue désormais à la logique défectueuse, une correction immédiate est requise. Cela implique généralement le déploiement d'une autre version du correctif et l'exécution d'une deuxième mise à niveau. Des mécanismes de pause d’urgence ou des disjoncteurs doivent faire partie de la conception pour limiter les dommages.

Quelqu'un peut-il appeler la fonction de mise à niveau dans une configuration UUPS ? L'accès à la fonction de mise à niveau doit être restreint via un contrôle d'accès basé sur les rôles, tel que les contrats Ownable ou AccessControl d'OpenZeppelin. Sans restrictions appropriées, des acteurs malveillants pourraient détourner le proxy et le diriger vers une logique malveillante arbitraire.

En quoi UUPS diffère-t-il du modèle Transparent Proxy ? Dans le modèle Transparent Proxy, la logique de mise à niveau réside dans le proxy lui-même, ce qui augmente sa taille et son coût en gaz. UUPS intègre cette logique dans le contrat de mise en œuvre, rendant les proxys plus légers et plus efficaces. Cependant, cela signifie que chaque implémentation doit inclure le code d'évolutivité, ce qui nécessite une gestion minutieuse lors de la compilation et du déploiement.

Est-il possible de désactiver définitivement les mises à niveau ? Oui. Après avoir finalisé une version contractuelle, les développeurs peuvent renoncer à la propriété ou appeler une fonction comme _disableInitializers() et verrouiller les mises à niveau. Une fois désactivé, aucune autre modification de la mise en œuvre ne peut survenir, ce qui rend le contrat immuable.

Clause de non-responsabilité:info@kdj.com

Les informations fournies ne constituent pas des conseils commerciaux. kdj.com n’assume aucune responsabilité pour les investissements effectués sur la base des informations fournies dans cet article. Les crypto-monnaies sont très volatiles et il est fortement recommandé d’investir avec prudence après une recherche approfondie!

Si vous pensez que le contenu utilisé sur ce site Web porte atteinte à vos droits d’auteur, veuillez nous contacter immédiatement (info@kdj.com) et nous le supprimerons dans les plus brefs délais.

Connaissances connexes

Qu’est-ce qu’une inversion du taux de financement ? Pourquoi cela signale souvent un changement de sentiment du marché

Qu’est-ce qu’une inversion du taux de financement ? Pourquoi cela signale souvent un changement de sentiment du marché

Jun 14,2026 at 03:57am

Modèles de volatilité du marché 1. Les fluctuations de prix Bitcoin dépassent souvent 10 % sur des fenêtres de 24 heures lors d'annonces macroécon...

Comment reconnaître les signaux de manipulation du marché sur les marchés à terme des cryptomonnaies

Comment reconnaître les signaux de manipulation du marché sur les marchés à terme des cryptomonnaies

Jun 12,2026 at 05:26pm

Bitcoin Réduire de moitié les mécanismes 1. Le protocole de Bitcoin applique un calendrier d'émission fixe dans lequel les récompenses de bloc son...

Qu’est-ce que le piégeage à effet de levier ? Pourquoi les commerçants de détail se font souvent prendre

Qu’est-ce que le piégeage à effet de levier ? Pourquoi les commerçants de détail se font souvent prendre

Jun 12,2026 at 11:53pm

Modèles de volatilité du marché 1. Les fluctuations de prix Bitcoin dépassent souvent 5 % sur une fenêtre de 24 heures lors d'événements à forte l...

Qu'est-ce qu'une transaction en petits groupes ? Comment les traders à terme capturent les mouvements de prix importants

Qu'est-ce qu'une transaction en petits groupes ? Comment les traders à terme capturent les mouvements de prix importants

Jun 13,2026 at 05:19am

Comprendre les mécanismes de rupture dans les contrats à terme cryptographiques 1. Une cassure se produit lorsque le prix de Bitcoin ou de l'altco...

Comment échanger des contrats à terme sur crypto lors d'annonces économiques majeures

Comment échanger des contrats à terme sur crypto lors d'annonces économiques majeures

Jun 12,2026 at 10:50pm

Modèles de volatilité du marché 1. Les fluctuations de prix Bitcoin dépassent souvent 5 % sur une seule fenêtre de 24 heures lors d'événements à f...

Qu’est-ce que le solde de marge ? Comprendre le cœur du contrôle des risques à terme

Qu’est-ce que le solde de marge ? Comprendre le cœur du contrôle des risques à terme

Jun 12,2026 at 03:19pm

Modèles de volatilité du marché 1. Les fluctuations de prix de Bitcoin sont souvent en corrélation avec des indicateurs macroéconomiques tels que les ...

Qu’est-ce qu’une inversion du taux de financement ? Pourquoi cela signale souvent un changement de sentiment du marché

Qu’est-ce qu’une inversion du taux de financement ? Pourquoi cela signale souvent un changement de sentiment du marché

Jun 14,2026 at 03:57am

Modèles de volatilité du marché 1. Les fluctuations de prix Bitcoin dépassent souvent 10 % sur des fenêtres de 24 heures lors d'annonces macroécon...

Comment reconnaître les signaux de manipulation du marché sur les marchés à terme des cryptomonnaies

Comment reconnaître les signaux de manipulation du marché sur les marchés à terme des cryptomonnaies

Jun 12,2026 at 05:26pm

Bitcoin Réduire de moitié les mécanismes 1. Le protocole de Bitcoin applique un calendrier d'émission fixe dans lequel les récompenses de bloc son...

Qu’est-ce que le piégeage à effet de levier ? Pourquoi les commerçants de détail se font souvent prendre

Qu’est-ce que le piégeage à effet de levier ? Pourquoi les commerçants de détail se font souvent prendre

Jun 12,2026 at 11:53pm

Modèles de volatilité du marché 1. Les fluctuations de prix Bitcoin dépassent souvent 5 % sur une fenêtre de 24 heures lors d'événements à forte l...

Qu'est-ce qu'une transaction en petits groupes ? Comment les traders à terme capturent les mouvements de prix importants

Qu'est-ce qu'une transaction en petits groupes ? Comment les traders à terme capturent les mouvements de prix importants

Jun 13,2026 at 05:19am

Comprendre les mécanismes de rupture dans les contrats à terme cryptographiques 1. Une cassure se produit lorsque le prix de Bitcoin ou de l'altco...

Comment échanger des contrats à terme sur crypto lors d'annonces économiques majeures

Comment échanger des contrats à terme sur crypto lors d'annonces économiques majeures

Jun 12,2026 at 10:50pm

Modèles de volatilité du marché 1. Les fluctuations de prix Bitcoin dépassent souvent 5 % sur une seule fenêtre de 24 heures lors d'événements à f...

Qu’est-ce que le solde de marge ? Comprendre le cœur du contrôle des risques à terme

Qu’est-ce que le solde de marge ? Comprendre le cœur du contrôle des risques à terme

Jun 12,2026 at 03:19pm

Modèles de volatilité du marché 1. Les fluctuations de prix de Bitcoin sont souvent en corrélation avec des indicateurs macroéconomiques tels que les ...

Voir tous les articles

User not found or password invalid

Your input is correct