-
bitcoin $87959.907984 USD
1.34% -
ethereum $2920.497338 USD
3.04% -
tether $0.999775 USD
0.00% -
xrp $2.237324 USD
8.12% -
bnb $860.243768 USD
0.90% -
solana $138.089498 USD
5.43% -
usd-coin $0.999807 USD
0.01% -
tron $0.272801 USD
-1.53% -
dogecoin $0.150904 USD
2.96% -
cardano $0.421635 USD
1.97% -
hyperliquid $32.152445 USD
2.23% -
bitcoin-cash $533.301069 USD
-1.94% -
chainlink $12.953417 USD
2.68% -
unus-sed-leo $9.535951 USD
0.73% -
zcash $521.483386 USD
-2.87%
最小限のプロキシ契約(EIP-1167)とは何ですか?
A minimal proxy contract efficiently forwards calls to an implementation contract using delegatecall, enabling cost-effective deployments and shared logic across multiple instances.
2025/07/15 05:00
最小のプロキシ契約を理解する
最小限のプロキシ契約は、最小限のオーバーヘッドを維持しながら、すべてのコールを別の契約に転送するように設計された軽量のスマート契約です。特に共有ロジックとの契約の複数のインスタンスを展開する場合、イーサリアムベースのシステムで重要な役割を果たします。この概念は、最小限のバイトコードを使用して既存の契約のクローンを作成するための標準の概要を説明するEIP-1167を通じて形式化されました。
このメカニズムの背後にある核となるアイデアは、コードの再利用です。毎回同一のロジックで新しい契約を展開する代わりに、開発者はすべての機能呼び出しを既存の実装契約に委任するプロキシを展開できます。これにより、展開コストが大幅に削減され、アップグレードが簡素化されます。
重要な概念:最小限のプロキシ契約には、実行をターゲット契約にリダイレクトするために必要なコードのみが含まれます。
EIP-1167はどのように機能しますか?
EIP-1167は、その機能を実現するために、 DelegateCall OpCodeを堅牢性で活用します。 DeLegateCallでは、1つの契約が別の契約からコードを実行することができます。最小限のプロキシの場合、これはプロキシが発信者のコンテキストを変更することなく、すべての着信コールを実装契約に転送することを意味します。
これがどのように機能しますか:
- プロキシ契約には、実装契約のアドレスを保持する単一のストレージスロットが含まれています。
- ユーザーがプロキシと対話すると、フォールバック関数がトリガーされます。
- このフォールバック関数は、DeLegateCallを使用して、コールを保存された実装アドレスに転送します。
その単純さのため、プロキシ契約では展開にはほとんどガスが必要です。多くの場合、50,000ガス未満のガスです。この効率により、多くの同様の契約を迅速かつ安価に展開する必要があるシナリオに最適です。
最小のプロキシ契約の構造
通常、最小限のプロキシ契約は、EIP-1167で定義された厳密な構造に従います。これに含まれるものは次のとおりです。
- 実装契約を指す一定のアドレス変数。
- その実装アドレスに対してDeLegateCallを実行するフォールバック関数。
- 実装アドレスを超えたコンストラクターまたは状態変数はありません。
この設計により、プロキシはロジック自体を保存せず、単に実装契約の導管として機能することが保証されます。以下は、Solidityで書かれたこのような契約の単純化されたバージョンです。
pragma solidity ^0.8.0;契約minimalproxy {address private immutable implementation; constructor(address _implementation) { implementation = _implementation; } fallback() external payable { address impl = implementation; assembly { let ptr := mload(0x40) calldatacopy(ptr, 0, calldatasize()) let result := delegatecall(gas(), impl, ptr, calldatasize(), 0, 0) let size := returndatasize() returndatacopy(ptr, 0, size) switch result case 0 { revert(ptr, size) } default { return(ptr, size) } } }}
重要な注意:フォールバック関数でのインラインアセンブリの使用は、プロキシを最小限で効率的に保つために不可欠です。
最小限のプロキシ契約のユースケース
最小限のプロキシ契約は、効率と柔軟性のために、さまざまな分散型アプリケーションとプロトコルで広く使用されています。最も一般的なユースケースには次のものがあります。
- トークン工場:単一の実装契約から複数のERC-20またはERC-721トークンの作成。
- アップグレード可能な契約:透明なプロキシやUUPSなどのアップグレード可能性パターンの基本層として機能します。
- ガス効率の良い展開:数百または数千の契約を即位させるときの展開コストを削減します。
- 契約テンプレート:複数の展開にわたって予測可能な動作のための標準化されたテンプレートを提供します。
これらのユースケースのそれぞれは、展開フットプリントの削減と、複数のプロキシ全体で一貫したロジックを維持する能力の恩恵を受けます。
最小プロキシと他のプロキシパターンの違い
透明なプロキシ、UUP(ユニバーサルアップグレード可能なプロキシ標準)、ビーコンプロキシなど、イーサリアムにはいくつかのプロキシパターンがあります。それぞれには、複雑さ、アップグレード可能性、ガスコストの観点から独自のトレードオフがあります。
最小限のプロキシと他のプロキシタイプの重要な違いは、機能と拡張性にあります。
- 最小限のプロキシは、追加のインフラストラクチャとペアリングされない限り、アップグレードをサポートしません。
- 透明なプロキシには、管理ロジックとプロキシレジストリ、ガスの使用量の増加、複雑さが含まれます。
- UUPSプロキシは、実装契約を介して自己完結型のアップグレードを可能にします。
最小限のプロキシは、展開後、またはアップグレードが外部で処理される場合、実装が静的なままになるシナリオに最適です。
セキュリティ上の考慮事項とベストプラクティス
最小限のプロキシ契約は簡単ですが、リスクがないわけではありません。開発者は、安全な使用法を確保するためにベストプラクティスに従う必要があります。
- 実装の不変性を確保する:展開したら、明示的に意図して保護されていない限り、実装アドレスは変更されないはずです。
- ストレージの競合を避けてください:プロキシと実装はストレージのコンテキストを共有するため、後でプロキシを拡張する場合は慎重な計画が必要です。
- Bytecodeの検証:悪意のある変更を防ぐために、プロキシ契約と実装契約の両方のバイトコードを常に確認してください。
- 徹底的にテスト: HardhatやFoundryなどのツールを使用して、メインネットの展開前にインタラクションとテストエッジケースをシミュレートします。
重要なヒント:プロキシ契約が実装からセキュリティを継承していると仮定しないでください。それは別々に監査する必要があります。
よくある質問
Q:最小限のプロキシ契約をアップグレードできますか?最小限のプロキシ自体にはアップグレードロジックは含まれていませんが、UUPSなどの他の標準と組み合わせるか、外部コントローラーを使用して実装アドレスを管理することにより、アップグレード可能なシステムを作成できます。
Q:完全な契約と比較して、最小限のプロキシを展開するのはどれくらい安いですか?最小限のプロキシを展開すると、通常は約20,000〜50,000ガスのコストがかかりますが、完全な契約を展開すると、複雑さに応じて200万ガスを超える場合があります。
Q:展開されたプロキシから実装アドレスを取得する方法はありますか?はい、実装アドレスは通常、特定のストレージスロットに保存されます(多くの場合、スロット0)。 eth_getStorageAtなどのツールを使用して、または契約作成コードを検査することで読み取ることができます。
Q:最小限のプロキシは、すべての堅牢性バージョンと互換性がありますか?彼らは、0.5.0以上の堅牢性でうまく機能します。ただし、最適な互換性とガスの節約には、堅牢性0.8.x以降を使用することをお勧めします。
免責事項:info@kdj.com
提供される情報は取引に関するアドバイスではありません。 kdj.com は、この記事で提供される情報に基づいて行われた投資に対して一切の責任を負いません。暗号通貨は変動性が高いため、十分な調査を行った上で慎重に投資することを強くお勧めします。
このウェブサイトで使用されているコンテンツが著作権を侵害していると思われる場合は、直ちに当社 (info@kdj.com) までご連絡ください。速やかに削除させていただきます。
- Wintermute が警鐘を鳴らす:AI の流動性枯渇が仮想通貨情勢の進化の中でビットコインを揺るがす
- 2026-02-10 22:10:01
- サム・バンクマン・フリードの刑務所ショッカー:FTX「決して破産しない」と主張、進行中の佐賀で弁護士を標的に
- 2026-02-10 21:50:02
- オリンピック 50 ペンス コインの熱狂: 珍しい掘り出し物を求めるイギリスのコレクター
- 2026-02-10 22:10:01
- 精査中のCEX台帳:2000BTCの不具合と信頼の基本的な問題
- 2026-02-10 21:50:02
- 機関投資家の買いが堅調な中、ビットコイン価格は横ばい:統合が進む市場
- 2026-02-10 22:05:01
- エスプレッソがバイナンスを加熱: 市場前取引がレイヤー2の新時代を告げる
- 2026-02-10 22:05:01
関連知識
デイトレード暗号通貨のレバレッジを安全に最大化するにはどうすればよいですか?
2026-02-08 01:19:53
暗号デリバティブにおけるレバレッジの仕組みを理解する1. レバレッジにより、トレーダーは必要な資金の一部でより大きなポジションをコントロールできるようになり、潜在的な利益と損失の両方が倍増します。 2. ほとんどの暗号通貨取引所は、資産ペアとアカウント検証レベルに応じて、2 倍から 125 倍までの...
スキャルピング用の「ワンクリック」取引インターフェイスを設定するにはどうすればよいですか?
2026-02-09 22:59:56
コアアーキテクチャ要件1. 50 ミリ秒未満の間隔でリアルタイムの買値更新を受信するには、取引所の注文帳フィードとの低遅延 WebSocket 接続を直接確立する必要があります。 2. インターフェイスは、ルーティング遅延を引き起こす外部バックエンド プロキシへの依存を避けるために、WebAssem...
メジャーアップグレードの前後でイーサリアム先物を取引するにはどうすればよいですか?
2026-02-08 09:40:26
イーサリアム先物の仕組みを理解する1. イーサリアム先物契約は、CME やバイナンス先物などの規制された取引所で、あらかじめ決められた価格と日付で ETH を売買するための標準化された契約です。 2. レバレッジは重要な役割を果たします。トレーダーは最小限の資金で大きなポジションを管理でき、変動期間...
大規模契約取引用の流動性の高いペアを見つけるにはどうすればよいですか?
2026-02-08 18:20:09
大規模契約取引向けの流動性の高いペアを見つける大規模な契約注文を実行するトレーダーは、スリッページや価格への影響を避けるために流動性を優先する必要があります。流動性の低い環境では、特に資金調達率とベーシスの乖離によりボラティリティが増大する無期限先物やインバース契約において、実行リスクが増幅されます...
清算を防ぐために「マーク価格」と「最終価格」を使用する方法は?
2026-02-07 17:39:59
マーク価格の仕組みを理解する1. マーク価格は、複数のスポット為替指数と資金調達率の調整から導出される複合価値であり、永久契約の公正な市場価値を反映するように設計されています。 2. Binance、Coinbase、Kraken、Bybit などの主要なスポット市場からのリアルタイム データを組み...
レバレッジ取引における「自己資本利益率(ROE)」の計算方法は?
2026-02-08 04:39:45
レバレッジ取引における自己資本利益率を理解する1. レバレッジ取引における自己資本利益率 (ROE) は、ポジションの合計サイズではなく、トレーダーの自己資金と比較して生み出される収益性を測定します。これは、トレーダーが取引所やブローカーから資金を借りる際に、自分の株式をどれだけ効率的に利用するかを...
デイトレード暗号通貨のレバレッジを安全に最大化するにはどうすればよいですか?
2026-02-08 01:19:53
暗号デリバティブにおけるレバレッジの仕組みを理解する1. レバレッジにより、トレーダーは必要な資金の一部でより大きなポジションをコントロールできるようになり、潜在的な利益と損失の両方が倍増します。 2. ほとんどの暗号通貨取引所は、資産ペアとアカウント検証レベルに応じて、2 倍から 125 倍までの...
スキャルピング用の「ワンクリック」取引インターフェイスを設定するにはどうすればよいですか?
2026-02-09 22:59:56
コアアーキテクチャ要件1. 50 ミリ秒未満の間隔でリアルタイムの買値更新を受信するには、取引所の注文帳フィードとの低遅延 WebSocket 接続を直接確立する必要があります。 2. インターフェイスは、ルーティング遅延を引き起こす外部バックエンド プロキシへの依存を避けるために、WebAssem...
メジャーアップグレードの前後でイーサリアム先物を取引するにはどうすればよいですか?
2026-02-08 09:40:26
イーサリアム先物の仕組みを理解する1. イーサリアム先物契約は、CME やバイナンス先物などの規制された取引所で、あらかじめ決められた価格と日付で ETH を売買するための標準化された契約です。 2. レバレッジは重要な役割を果たします。トレーダーは最小限の資金で大きなポジションを管理でき、変動期間...
大規模契約取引用の流動性の高いペアを見つけるにはどうすればよいですか?
2026-02-08 18:20:09
大規模契約取引向けの流動性の高いペアを見つける大規模な契約注文を実行するトレーダーは、スリッページや価格への影響を避けるために流動性を優先する必要があります。流動性の低い環境では、特に資金調達率とベーシスの乖離によりボラティリティが増大する無期限先物やインバース契約において、実行リスクが増幅されます...
清算を防ぐために「マーク価格」と「最終価格」を使用する方法は?
2026-02-07 17:39:59
マーク価格の仕組みを理解する1. マーク価格は、複数のスポット為替指数と資金調達率の調整から導出される複合価値であり、永久契約の公正な市場価値を反映するように設計されています。 2. Binance、Coinbase、Kraken、Bybit などの主要なスポット市場からのリアルタイム データを組み...
レバレッジ取引における「自己資本利益率(ROE)」の計算方法は?
2026-02-08 04:39:45
レバレッジ取引における自己資本利益率を理解する1. レバレッジ取引における自己資本利益率 (ROE) は、ポジションの合計サイズではなく、トレーダーの自己資金と比較して生み出される収益性を測定します。これは、トレーダーが取引所やブローカーから資金を借りる際に、自分の株式をどれだけ効率的に利用するかを...
すべての記事を見る














