-
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%
프록시 패턴을 사용하여 스마트 계약을 업그레이드하는 방법은 무엇입니까?
The Ethereum proxy pattern separates logic and storage, enabling upgrades via delegatecall while preserving state—provided storage layout remains consistent across versions.
2026/01/23 03:40
Ethereum의 프록시 패턴 이해
1. 프록시 패턴은 프록시와 구현이라는 두 가지 개별 계약을 배포하여 스토리지에서 계약 논리를 분리합니다.
2. 사용자는 위임자 호출을 사용하여 모든 호출을 현재 구현 계약으로 전달하는 프록시와 독점적으로 상호 작용합니다.
3. 데이터 손상이나 정렬 오류를 방지하려면 구현 업그레이드 전반에 걸쳐 스토리지 레이아웃을 일관되게 유지해야 합니다.
4. 프록시는 구현 주소에 대한 단일 스토리지 슬롯을 유지하므로 사용자 상태에 영향을 주지 않고 업데이트할 수 있습니다.
5. 이 아키텍처는 온체인 잔액, 허용량 및 과거 상호 작용을 유지하면서 이전 버전과 호환되는 변경을 가능하게 합니다.
투명 프록시의 주요 구성 요소
1. 프록시 계약에는 위임자 호출을 통해 외부 호출을 지정된 구현으로 라우팅하는 폴백 기능이 포함되어 있습니다.
2. 업그레이드 권한을 제한하기 위해 관리자 역할이 적용됩니다. 승인된 주소만 구현 포인터를 변경할 수 있습니다.
3. 수정자는 업그레이드 로직을 실행하기 전에 호출자가 관리자인지 확인하여 무단 재구성을 방지합니다.
4. 구현 계약은 스토리지 구조를 정의하는 기본 계약에서 상속되어 프록시 레이아웃과의 정렬을 보장해야 합니다.
5. 기능 선택기는 여러 버전에서 유지됩니다. 새로운 함수는 의도적으로 동작을 재정의하지 않는 한 기존 함수와의 충돌을 피해야 합니다.
배포 및 업그레이드 단계
1. 핵심 비즈니스 로직과 필수 상태 변수가 포함된 초기 구현 계약을 배포합니다.
2. 첫 번째 구현 주소로 스토리지를 초기화하고 관리자 주소를 설정하여 프록시 계약을 배포합니다.
3. 테스트 함수를 호출하고 반환 값이 예상 출력과 일치하는지 확인하여 프록시가 호출을 올바르게 위임하는지 확인합니다.
4. 업그레이드할 때 논리는 수정되었지만 스토리지 레이아웃은 동일한 새 구현 계약을 컴파일하고 배포합니다.
5. 관리자만 이 트랜잭션을 트리거하도록 보장하면서 새 구현 주소를 사용하여 프록시의 UpgradeTo 함수를 호출합니다.
보안 고려 사항 및 함정
1. 구현 간 스토리지 레이아웃 정렬이 누락되거나 올바르지 않으면 데이터가 자동으로 손상됩니다. 변수가 잘못된 슬롯에서 읽을 수 있습니다.
2. 관리자 역할을 보호하지 못하면 전체 시스템이 악의적인 업그레이드에 노출됩니다. 다중 서명 지갑이나 시간 잠금을 고려해야 합니다.
3. 생성자는 대리자 호출 컨텍스트에서 실행되지 않으므로 배포 후 초기화 함수를 별도로 호출해야 합니다.
4. 구현 코드에 포함된 외부 라이브러리 종속성 역시 일관되게 업그레이드해야 합니다. 해당 바이트코드는 논리 계약의 일부이기 때문입니다.
5. 중요한 전환 중에 업그레이드 논리가 재귀적인 대리자 호출을 적절하게 보호하지 않으면 재진입 위험이 증가합니다.
자주 묻는 질문
Q: 배포 후 관리자 주소를 변경할 수 있나요? 예, 대부분의 프록시 구현에는 현재 관리자가 호출을 시작하는 경우 관리자 주소를 업데이트할 수 있는 ChangeAdmin 기능이 포함되어 있습니다.
Q: 업그레이드된 구현을 초기화하는 것을 잊어버리면 어떻게 되나요? 계약 상태는 초기화되지 않은 상태로 유지되므로 잠재적으로 중요한 변수가 0 또는 빈 주소와 같은 기본값에 남겨져 예상치 못한 동작이 발생할 수 있습니다.
Q: 이전 구현 버전으로 다운그레이드할 수 있나요? 예, 이전 구현 계약이 여전히 온체인에 존재하고 호환 가능한 스토리지 레이아웃을 유지하는 한 다운그레이드는 기술적으로 지원됩니다.
Q: 대리자 호출 중에 발생한 이벤트가 프록시 주소 또는 구현 주소 아래에 표시됩니까? 이벤트를 내보낼 때 EVM이 대상을 호출한 대리자가 아닌 호출 컨텍스트를 기록하기 때문에 이벤트는 프록시 주소 아래에서 내보냅니다.
부인 성명:info@kdj.com
제공된 정보는 거래 조언이 아닙니다. kdj.com은 이 기사에 제공된 정보를 기반으로 이루어진 투자에 대해 어떠한 책임도 지지 않습니다. 암호화폐는 변동성이 매우 높으므로 철저한 조사 후 신중하게 투자하는 것이 좋습니다!
본 웹사이트에 사용된 내용이 귀하의 저작권을 침해한다고 판단되는 경우, 즉시 당사(info@kdj.com)로 연락주시면 즉시 삭제하도록 하겠습니다.
- 트럼프의 연준의장 지명: 케빈 워시(Kevin Warsh) 등장, 월스트리트 워치
- 2026-01-30 22:10:06
- 시장 변화와 새로운 암호화폐에 불이 붙으면서 비트코인의 디지털 골드 드림이 테스트되었습니다.
- 2026-01-30 22:10:06
- 바이낸스가 두 배로 성장: SAFU 펀드가 완전히 비트코인으로 전환되어 깊은 확신을 나타냄
- 2026-01-30 22:05:01
- Chevron의 4분기 결과에 따르면 수익 부족에도 불구하고 EPS가 앞섰고 향후 성장에 주목
- 2026-01-30 22:05:01
- 2026년 비트코인의 메가 행보: 새로운 시대를 향한 변동성 탐색
- 2026-01-30 22:00:01
- Cardano(ADA) 가격 전망: 2026년 잠재적 하락장 탐색
- 2026-01-30 22:00:01
관련 지식
LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?
2026-01-18 13:19:39
LayerZero 아키텍처 이해 1. LayerZero는 신뢰할 수 있는 중개자나 래핑된 자산에 의존하지 않고 블록체인 간의 통신을 가능하게 하는 경량의 무허가 상호 운용성 프로토콜로 작동합니다. 2. 각 체인에 배포된 Ultra Light Node(ULN)를 활용하여...
안전한 서명 검증을 위해 EIP-712를 구현하는 방법은 무엇입니까?
2026-01-20 22:20:26
EIP-712 개요 및 핵심 목적 1. EIP-712는 이더리움 애플리케이션에서 형식화된 구조화된 데이터 해싱 및 서명에 대한 표준을 정의합니다. 2. 서명 요청 시 원시 16진수 문자열 대신 사람이 읽을 수 있는 도메인 및 메시지 필드를 지갑에 표시할 수 있습니다. ...
새로운 계약과 상호 작용하여 에어드랍 자격을 얻는 방법은 무엇입니까?
2026-01-24 21:00:23
계약 상호 작용 요구 사항 이해 1. 대부분의 에어드롭 캠페인은 Ethereum, Arbitrum 또는 Base와 같은 지원되는 블록체인에 배포된 스마트 계약과의 직접적인 상호 작용을 요구합니다. 2. 상호 작용에는 일반적으로 dApp 인터페이스에 연결된 지갑을 사용하...
보안 경고에 대한 스마트 계약을 모니터링하는 방법은 무엇입니까?
2026-01-21 07:59:57
온체인 모니터링 도구 1. Etherscan 및 Blockscout와 같은 블록체인 탐색기를 사용하면 계약 바이트 코드, 트랜잭션 로그 및 내부 호출을 실시간으로 검사할 수 있습니다. 2. 온체인 데이터를 신뢰하기 전에 계약 확인 상태를 확인해야 합니다. 확인되지 않은...
자동 결제 계약을 설정하고 자금을 조달하는 방법은 무엇입니까?
2026-01-26 08:59:35
스마트 계약 배포 이해 1. 개발자는 가스 효율성 및 보안 요구 사항을 기반으로 Ethereum, Polygon 또는 Arbitrum과 같은 호환 가능한 블록체인 플랫폼을 선택해야 합니다. 2. Solidity는 특히 반복 또는 조건부 이체를 위한 결제 자동화 로직 작...
OpenZeppelin 계약을 사용하여 안전한 dApp을 구축하는 방법은 무엇입니까?
2026-01-18 11:19:49
OpenZeppelin 계약 기본 사항 이해 1. OpenZeppelin Contracts는 Ethereum 및 EVM 호환 블록체인용으로 구축된 재사용 가능한 커뮤니티 감사 스마트 계약 구성 요소 라이브러리입니다. 2. 라이브러리의 각 계약은 검사-효과-상호작용 패턴...
LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?
2026-01-18 13:19:39
LayerZero 아키텍처 이해 1. LayerZero는 신뢰할 수 있는 중개자나 래핑된 자산에 의존하지 않고 블록체인 간의 통신을 가능하게 하는 경량의 무허가 상호 운용성 프로토콜로 작동합니다. 2. 각 체인에 배포된 Ultra Light Node(ULN)를 활용하여...
안전한 서명 검증을 위해 EIP-712를 구현하는 방법은 무엇입니까?
2026-01-20 22:20:26
EIP-712 개요 및 핵심 목적 1. EIP-712는 이더리움 애플리케이션에서 형식화된 구조화된 데이터 해싱 및 서명에 대한 표준을 정의합니다. 2. 서명 요청 시 원시 16진수 문자열 대신 사람이 읽을 수 있는 도메인 및 메시지 필드를 지갑에 표시할 수 있습니다. ...
새로운 계약과 상호 작용하여 에어드랍 자격을 얻는 방법은 무엇입니까?
2026-01-24 21:00:23
계약 상호 작용 요구 사항 이해 1. 대부분의 에어드롭 캠페인은 Ethereum, Arbitrum 또는 Base와 같은 지원되는 블록체인에 배포된 스마트 계약과의 직접적인 상호 작용을 요구합니다. 2. 상호 작용에는 일반적으로 dApp 인터페이스에 연결된 지갑을 사용하...
보안 경고에 대한 스마트 계약을 모니터링하는 방법은 무엇입니까?
2026-01-21 07:59:57
온체인 모니터링 도구 1. Etherscan 및 Blockscout와 같은 블록체인 탐색기를 사용하면 계약 바이트 코드, 트랜잭션 로그 및 내부 호출을 실시간으로 검사할 수 있습니다. 2. 온체인 데이터를 신뢰하기 전에 계약 확인 상태를 확인해야 합니다. 확인되지 않은...
자동 결제 계약을 설정하고 자금을 조달하는 방법은 무엇입니까?
2026-01-26 08:59:35
스마트 계약 배포 이해 1. 개발자는 가스 효율성 및 보안 요구 사항을 기반으로 Ethereum, Polygon 또는 Arbitrum과 같은 호환 가능한 블록체인 플랫폼을 선택해야 합니다. 2. Solidity는 특히 반복 또는 조건부 이체를 위한 결제 자동화 로직 작...
OpenZeppelin 계약을 사용하여 안전한 dApp을 구축하는 방법은 무엇입니까?
2026-01-18 11:19:49
OpenZeppelin 계약 기본 사항 이해 1. OpenZeppelin Contracts는 Ethereum 및 EVM 호환 블록체인용으로 구축된 재사용 가능한 커뮤니티 감사 스마트 계약 구성 요소 라이브러리입니다. 2. 라이브러리의 각 계약은 검사-효과-상호작용 패턴...
모든 기사 보기














