-
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%
업그레이드 가능한 스마트 계약이란 무엇이며 어떻게 생성하나요?
Upgradable smart contracts enable post-deployment logic updates via proxy patterns—separating state from code—but introduce security risks like admin key compromise and storage misalignment.
2026/01/12 10:59
업그레이드 가능한 스마트 계약 이해
1. 업그레이드 가능한 스마트 계약은 온체인 주소를 변경하지 않고도 배포 후 논리를 수정할 수 있는 메커니즘으로 설계된 블록체인 기반 프로그램입니다.
2. 이 기능은 기존 스마트 계약의 근본적인 한계인 불변성을 해결합니다. 이는 배포 후 영구적인 취약성이나 오래된 기능으로 이어지는 경우가 많습니다.
3. 핵심 아이디어는 계약 상태에서 계약 논리를 분리하여 개발자가 동일한 저장소 위치를 새로운 구현 코드에 지정할 수 있도록 하는 것입니다.
4. 이더리움은 성숙한 도구와 분산형 금융 프로토콜의 광범위한 채택으로 인해 이러한 패턴에 대한 가장 일반적인 환경으로 남아 있습니다.
5. 업그레이드 경로로 인해 프록시 소유권 및 초기화 결함을 비롯한 추가 공격 표면이 발생하므로 보안 감사가 훨씬 더 복잡해집니다.
프록시 패턴 아키텍처
1. 투명 프록시 패턴은 호출자의 컨텍스트를 유지하면서 대리자 호출을 사용하여 호출을 구현 계약으로 전달하는 프록시 계약을 사용합니다.
2. 프록시는 영구 저장소를 유지하고 관리자 또는 다중 서명 지갑이 제어하는 변경 가능한 구현 주소에 실행을 위임합니다.
3. 전달하기 전에 기능 선택기를 확인합니다. 관리 기능은 무단 액세스를 방지하기 위해 사용자 측 기능 서명과 충돌해서는 안 됩니다.
4. 버전 간 스토리지 레이아웃 호환성이 중요합니다. 잘못 정렬되면 상태가 손상되고 이전 버전과의 호환성이 손상됩니다.
5. OpenZeppelin의 업그레이드 가능한 계약 라이브러리는 ERC-20 및 이 아키텍처용으로 구축된 거버넌스 모듈을 포함하여 표준화되고 감사된 템플릿을 제공합니다.
위험과 일반적인 함정
1. 잘못 초기화된 업그레이드 가능한 계약으로 인해 중요한 변수가 초기화되지 않은 상태로 남아 런타임 작업 중에 자동 오류가 발생할 수 있습니다.
2. 프록시 관리의 소유권 중앙화는 단일 실패 지점을 만듭니다. 손상된 관리 키는 로직을 악의적인 구현으로 리디렉션할 수 있습니다.
3. ReentrancyGuard 수정자와 같은 검사로 주의 깊게 보호하지 않으면 업그레이드 기능 자체에 재진입 벡터가 포함될 수 있습니다.
4. 개발자는 때때로 생성자 대신 초기화 수정자를 추가하는 것을 잊어버려서 업그레이드 전반에 걸쳐 설정 논리를 건너뛰게 됩니다.
5. 구현 계약에 하드코딩된 주소는 업그레이드 후 해당 주소가 변경될 때 구성성을 손상시켜 계약 간 호출 오류를 발생시킵니다.
배포 워크플로
1. 개발자는 OpenZeppelin의 초기화 가능을 상속받아 구현 계약을 작성하고 그 안에 모든 비즈니스 로직을 정의합니다.
2. 처음에는 첫 번째 구현 버전을 가리키고 검증된 지갑에 관리자 권한을 할당하는 별도의 프록시 계약이 배포됩니다.
3. 그런 다음 구현 계약이 별도로 배포되고 해당 주소가 서명된 트랜잭션을 통해 프록시의 업그레이드 기능으로 전달됩니다.
4. 모든 후속 상호 작용은 프록시 주소를 통해 발생하므로 기본 논리 변경에도 불구하고 사용자가 동일한 인터페이스를 유지합니다.
5. 각 업그레이드에는 프런트엔드나 오라클이 보유한 가정을 깨뜨리는 것을 방지하기 위해 일시 중지된 상태, 긴급 정지, 토큰 전송과 관련된 엣지 케이스를 포함한 전체 회귀 테스트가 필요합니다.
자주 묻는 질문
Q: 원래 업그레이드 가능하도록 설계되지 않은 계약을 업그레이드할 수 있습니까? A: 아니요. 표준 계약에 업그레이드 기능을 추가하는 것은 모든 상태를 수동으로 재배포하고 마이그레이션하지 않고는 불가능합니다. 이 프로세스는 위험이 따르며 프로덕션에서는 거의 실현 가능하지 않습니다.
Q: 업그레이드 가능한 계약과 상호 작용하는 데 더 많은 가스 비용이 발생합니까? 답: 그렇습니다. 모든 외부 호출은 프록시의 대리자 호출 전달 계층 및 선택기 디스패치 논리에서 오버헤드를 발생시키며 일반적으로 작업당 1,000~3,000개의 가스를 추가합니다.
Q: 테스트에 공개 프록시 관리 키를 사용해도 안전합니까? A: 테스트넷에서만 허용됩니다. 메인넷에서 공개 키 또는 노출된 관리자 키를 사용하면 기본 보안 위생을 위반하고 전체 프로토콜이 즉시 손상될 수 있습니다.
Q: 업그레이드로 인해 외부 계약의 ABI가 크게 변경되면 어떻게 됩니까? A: 해당 ABI를 사용하는 모든 dApp 또는 서비스는 호출 중에 자동으로 실패하거나 오류가 발생하므로 새 인터페이스와 일치하도록 업데이트될 때까지 자금이 동결되거나 통합이 중단될 수 있습니다.
부인 성명: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. 라이브러리의 각 계약은 검사-효과-상호작용 패턴...
모든 기사 보기














