이 글은 HOPR의 기본에 대해 알아보는 시리즈의 여섯번째 에피소드입니다. 이전 에피소드에 대한 링크는 글의 끝에 찾아보실 수 있습니다.
인센티브형 믹스넷을 구축하는 일의 중심에는 모순이 있습니다: 인센티브만 챙기고 작업을 수행하지 않을 수 있는데, 노드가 데이터를 릴레이하는 작업을 제대로 수행하는지 어떻게 확실히 할 수 있을까요?
HOPR의 솔루션은 바로 릴레이 증명이며, 이 에피소드에서 이 작업이 어떻게 수행되는지 알아볼 것입니다.
무신뢰 프라이버시
규칙을 따르는 것이 옳다는 이유만으로 사람들이 그 규칙을 온전히 따를 것을 기대할 수는 없습니다. 이에 따라 규칙을 따르는 일이 합리적이며 유익한 일로 만들어야 합니다. 이것은 많은 암호화 시스템의 초석이며, 시스템을 무신뢰로 만드는 것입니다(시스템을 만든 그 누구도 신뢰하지 않아도 되기 때문에 오히려 시스템이 신뢰 가능하다는, 조금은 헷갈릴 수 있는 개념입니다). 기본적으로 시스템이 원하는 여러분의 행동 방식이 바로 여러분의 가장 이기적인 행동 방식일 때, 우리는 친절하게 대해주는 그 누구에게도 기대지 않아도 됩니다.
HOPR의 경우 우리는 모두가 공정하게 보상을 확실하게 받을 방법이 필요한데, 이는 단지 그들이 데이터를 릴레이한 다음의 경우에만 해당합니다. 이 메커니즘은 공개적으로 모두를 추적하고 확인하지 않아도 모두가 정직함을 보장해야 하며, 그렇지 않은 경우 믹스넷을 설계하는데 들어간 모든 프라이버시 작업이 무용지물이 됩니다.
노드를 정직하게 유지
지난 에피소드에서 우리는 사용자가 네트워크를 통해 전체 경로에 대한 결제를 미리 로드하고 노드 러너가 자신의 몫을 챙기고 나머지를 체인을 통해 전달하는 다소 순진한 결제 방식에 대한 접근을 살펴봤습니다.
이것의 문제는 바로 보장된 것이 없다는 점입니다. 돈만 챙기고 데이터는 전달하지 않는 경우가 발생할 수 있지 않을까요? HOPR 네트워크의 익명성은 노드들로 하여금 그들의 릴레이 작업을 수행하지 않고 시스템으로부터 돈을 훔칠 수 있게 만들 가능성이 있습니다. 기억해야 할 점은 오직 발신자만이 데이터 패킷이 통과해야 하는 전체 경로를 알 뿐이며, 여기에 믹싱이 더해진다는 것은 데이터 경로가 어느 지점에서 실패했는지 추적할 길이 없다는 뜻입니다.
따라서 우리는 노드가 그들의 릴레이잉 작업을 수행 완료한 경우에만 지불을 받는 방법을 찾아야 합니다. 이것은 직관적인 솔루션입니다. 결국 사람들은 일을 한 후에 돈을 받지, 일을 하기 전 돈을 받지 않습니다. 하지만 여기서는 어떻게 그것을 달성할 수 있을까요?
단순한 접근의 한 예로는 체인 내 각 노드가 직전 노드에게 돈을 지불하게 만드는 방법이 있습니다. 따라서 만약 Dmytro가 Chāo로부터 데이터를 수신한다면, 그가 Chāo의 임금을 보상으로 보내는 방식입니다. 그런데 이렇게 하면 결국 같은 문제를 다시 마주하게 됩니다. Dmytro가 왜 굳이 그래야 할까요? 굳이 그렇게 하지 않고 돈을 전송하지 않는 경우 어떡할까요? 다시 말하지만 네트워크의 프라이버시로 인해 이것을 적발해낼 방법이 없습니다.
(사실 이것은 과도하게 단순화해 말한 것입니다 - 결국, Chāo는 그가 Dmytro에게 데이터 일부를 전송했다는 것을 알고 그로부터 돈을 지급받지 못했다는 사실 또한 알 것입니다. 하지만 Chāo는 그것이 악의적이었다는 것을 증명할 수 없습니다. 네트워크에서는 항상 문제가 발생하고는 합니다! 또, Dmytro가 돈을 전달하지 않는다는 평판이 있더라도, 그는 단순히 네트워크에서 빠져나와 새로운 ID로 다시 시작할 수 있습니다. 다시 말해, 프라이버시는 양날의 검입니다.)
그렇다면 우리는 이 문제를 어떻게 해결해야 할까요?
릴레이 증명
HOPR가 찾은 혁신은 바로 체인 내 연속되는 노드 페어가 서로에게 금액 지불에 있어 의존하게 만드는 것입니다. Chāo는 Dmytro에게 데이터를 릴레이하기 전까지 금액을 청구할 수 없으며, Dmytro 또한 Chāo의 몫을 언락하기 전까지는 자신의 몫을 청구할 수 없습니다.
이것은 암호화 기술을 통해 이루어지지만, 사실 이해하기 간단합니다.
HOPR 네트워크를 통해 데이터가 전송될 때, 체인 내 각 노드에 대한 지불이 생성됩니다. 이것은 암호화 키로 인해 락업됩니다. 키 전체를 갖고 있는 경우 지불을 청구할 수 있습니다. 하지만 그 중 어느 한 부분이라도 빠지면 아무 소용이 없습니다.
이러한 키는 절반으로 나뉘어 여러분은 지불을 청구하기 위해 양쪽 모두를 확보해야만 합니다.
데이터가 체인을 따라 전송될 때, 연속되는 노드 페어는 서로가 가진 키의 반쪽을 스왑합니다. 열쇠를 앞쪽과 뒷쪽 두 쪽으로 나눈다고 가정하겠습니다. Chāo는 Betty가 가진 뒷쪽 키를 확보하기 위해 그가 가진 앞쪽 키를 스왑합니다. 그는 Dmytro가 가진 앞쪽 키를 자신이 가진 뒷쪽 키와 스왑합니다. 이렇게 한 뒤에 그는 지불을 청구할 수 있으며, 이렇게 작업이 진행된다면 데이터는 성공적으로 Betty에서 Chāo에게, 그리고 이어 Dmytro에게 전달되었을 것입니다.
이렇게 하면 모두가 규칙에 따라 작업을 수행하게 만듭니다. 만일 제가 당신으로부터 데이터를 받는 노드라면, 우리 중 그 누구도 키의 반쪽을 스왑하지 않고서는 지불을 청구할 수 없습니다. 책임을 회피하는 것에 대한 베네핏이 전혀 없으며, 돈을 훔칠만한 구멍도 없습니다. 이 경우 가장 이기적인 행동방식이 바로 협업이 되며, 이 말은 모두의 인센티브가 연대한다는 뜻입니다.
프라이버시 보존
간단하지만 강력한 이 혁신은 가능성으로 가득한 또 다른 세계를 열어줍니다. 릴레이 증명과 함께 우리는 드디어 무한히 확장할 수 있는 완전한 인센티브형 프라이빗 믹스넷을 구축할 수 있게 되었으며, 이는 우리가 신뢰할 수 있는 이타적인 사람을 찾을 필요가 없기 때문입니다.
아직 우리는 숲에서 빠져나온 것이 아닙니다. 만일 각 지불이 퍼블릭 블록체인에서 트랜잭션을 만들 경우, 우리는 네트워크에서 일어나는 모든 것에 대한 데이터베이스를 실수로 노출시킬 수 있는 위험성에 가까워집니다. HOPR는 확률적 지불을 이용해 HOPR의 지불 레이어를 메시징 레이어로부터 분리해 프라이버시를 보존합니다. 이것이 어떻게 작동하는지에 대해서는 다음 에피소드를 통해 설명하겠습니다.
*해당 포스팅은 투자 관련 정보 공유의 목적으로 포스팅된 글이며 투자 권유가 아닙니다. 그러므로 개인 투자의 책임은 모두 본인에게 있으니 참고하셔서 투자하시기 바랍니다.
가장 최근에 출시한 Diablerets를 이제 테스트해 볼 수 있습니다! 이 튜토리얼은 여러분이 어떻게 설치하고 노드를 실행하는지 알려주며 몇 가지 기본적인 명령을 시도해볼 수 있게 해줍니다. 질문이 있으시다면 주저하지 말고 당사의 텔레그램 그룹에 문의해 주세요.
면책 조항: 이것은 얼리 출시로, 참여자 자산의 안전을 장담할 수 없습니다. 현재 노드를 실행하는 것에 대한 보상이 없습니다. 그러므로 테스트를 위한 최소한의 자금만 넣으시기 바랍니다(최대 1xDAI와 10wxHOPR).
무엇을 배우게 될까요?
이 튜토리얼은 다음과 같은 것에 대해 안내합니다:
● 컴퓨터에 HOPRd를 설치하고 사용하는 방법
● xDai와 HOPR로 노드에 자금 넣기
● 노드에서 xDai 인출하고 다른 노드로 보내기
● 익명의 메시지를 전송 및 받으며 피어와 소통하기
● 커뮤니케이션 채널을 열고 자금을 넣고 닫기
● 티켓을 얻고 교환해 HOPR 토큰으로 바꾸기
● 두 개의 노드를 실행하고 그 노드를 이용한 커뮤니케이션
● 채널을 열고 퍼블릭 노드에 메시지 보내기
이전에 노드를 실행한 적이 있더라도 지난번과 다르게 많은 부분들이 상당히 변했을 가능성이 있으므로 다음의 지침을 따르기를 권장합니다.
설치
HOPR 네트워크를 이용하기 위해 여러분은 HOPR 노드를 설치해야 합니다. 이것은 디바이스에 직접 하거나 VPS를 이용해 할 수 있습니다.
여러분의 노드는 HOPR 프로토콜을 도입하는 node.js 프로세스의 형식을 채택합니다. 이것은 hoprd로도 알려져 있습니다.
중요: HOPR 노드는 현재 MacOS, Linux, 그리고 AVADO 박스에서 구동됩니다. Windows 지원은 추후 릴리스에 추가될 것입니다.
hoprd를 설치할 수 있는 방법은 여러가지가 있습니다. 바이너리 다운로드를 요구했던 이전의 릴리스와는 다르게 HOPR Diablerets에 관한 모든 설치는 당신의 터미널을 통해 일어납니다. 아래에 나오는 여러분의 터미널로의 모든 명령을 입력하고 난 후, 여러분은 각자의 HOPR 노드에 브라우저를 통해 액세스할 수 있습니다.
NPM
우선 여러분은 NVM을 설치해야 합니다. 이를 위해 다음의 단계를 따라주세요. NVM 설치 이후, 명령을 이용해 올바르게 설치되었는지 확인하기 바랍니다.
nvm ls
이제 여러분은 이 명령을 실행해 node.js v14를 설치할 수 있습니다:
nvm install v14
설치 후 이 명령을 실행해 v14를 디폴트로 만듭니다:
nvm use v14
중요: 지금은 오직 node.js v14만 사용하세요. 다른 버전은 현재 지원되지 않습니다. 만약 당신이 MacOS M1 유저라면, 반드시 다음 nvm 지침을 따라주십시오.
노드를 설치하기 위해 다음 명령을 입력합니다:
mkdir MY_NEW_HOPR_TEST_FOLDER cd MY_NEW_HOPR_TEST_FOLDER npm install @hoprnet/hoprd@1.72
인출 명령을 사용해 첫번째 노드(앨리스)에서 xDAI를 인출해 두번째 노드(밥)에 보내줍니다. 이 방법으로 HOPR를 인출할 수 없을 수도 있지만(이것은 우리가 알고 있는 버그로 해결중에 있습니다) 상관 없습니다. 다음 단계를 위해 오직 앨리스만 HOPR가 필요합니다.
두 노드 모두 자금이 지원되면 이제 여러분은 채널을 열고 닫으며 메시지를 전송할 수 있습니다.
1. 각 노드에 별칭을 설정하며 시작합니다. 별칭을 설정하면 다른 노드와 소통할 때마다 그들의 전체 HOPR 어드레스를 매번 기입하지 않아도 됩니다.
노드의 HOPR 어드레스를 찾기 위해, address 명령을 각 노드에서 사용해 각자의 xDai와 HOPR 어드레스를 알아봅니다.
앨리스의 명령어
alias [Bob’s HOPR address] Bob
밥의 명령어
alias [Alice’s HOPR address] Alice
2. 앨리스는 이제 다음과 같이 밥에게 메시지를 전송할 수 있습니다:
send ,Bob hello
쉼표 “,”를 잊지 않는 것이 매우 중요한데, 쉼표를 누락하면 메시지는 전송되지 않으며 당신에게 에러 메시지가 나타납니다.
밥의 노드는 ‘hello’라는 메시지를 받게 되지만 발신인의 ID에 대해서는 전혀 알 수 없습니다. HOPR는 완전한 익명성을 보장하기 때문에 이것은 기능이며 버그가 아닙니다!
그럼에도, 일반적으로 메시지를 주고 받을 때 누구와 소통하고 있는지 아는 것이 유용한 경우가 많습니다. 앨리스는 설정을 변경해 밥에게 그녀의 ID를 알릴 수 있습니다:
settings includeRecipient true
이것을 완료한 후 다시 앨리스에게서 밥에게 메시지를 보내면, 앨리스의 노드로부터 온 메시지라는 것을 식별한다는 것을 확인할 수 있습니다.
3. 이제, 앨리스의 노드를 이용해 밥과의 채널을 열고 해당 채널에 다음의 명령을 입력해 HOPR를 지원합니다:
open Bob 0.01
채널에 자금을 지원하는데 필요한 최소량은 0.1 HOPR입니다. 이것은 기본적으로 하나의 티켓에 대한 지불입니다. 그러나, 일반적으로 우리는 한 채널에 충분한 HOPR를 지원해 몇 개의 티켓을 다룰 수 있도록 권장합니다.
채널을 여는 것은 블록체인에서 스마트 컨트랙트와 상호작용을 필요로 하기 때문에, 채널이 열리기까지 잠시 기다려야 합니다. 이 작업이 성공적으로 이뤄지면 여러분은 ‘Successfully opened channel’이라는 메시지를 보게 됩니다.
4. 이제 두 노드에 명령 채널을 입력해 이 채널이 존재하고 열려 있는지 확인할 수 있습니다. 채널 명령은 현재 열려있는 모든 채널을 표시합니다.
예:
Channel: 0xa0b92e6d400f556c2139661e799ccc867da28ce079c382388086882806e34dd8 CounterParty: Z35Qj Status: OPEN Total Balance: 0.01 HOPR My Balance: 0.01 HOPR
이 뜻은 앨리스가 노드 Z35Qj로 채널을 오픈했다는 말입니다. 이 채널은 현재 열려있으며 채널 내 잔액은 0.01 HOPR입니다. 앨리스가 이 채널에 자금을 지원한 것이기 때문에 앨리스의 잔액은 동일합니다.
밥쪽에서 당신은 비슷한 메시지가 표시되는 것을 볼 수 있습니다. 그러나 이쪽에서 밥의 잔액은 0일 것이며, 그 이유는 밥이 이 채널에 자금을 지원하지 않았기 때문입니다.
앨리스는 이제 밥을 릴레이 노드로 사용해 앨리스 스스로에게 메시지를 전송할 수 있습니다. 이것으로 밥은 티켓을 받을 수 있으며 이 티켓은 HOPR 토큰으로 바꿀 수 있습니다.
5. 우선, 밥이 가지고 있는 티켓이 있는지 밥의 노드에서 확인합니다. 다음과 같은 것을 보게 됩니다:
6. 앨리스의 노드에서 다음의 명령어를 입력해 밥의 노드를 통해 스스로에게 메시지를 보냅니다(앨리스는 디폴트 별칭 “me”로 나타나며 항상 당신의 고유 노드를 알립니다):
send Bob,me what’s up
이제 티켓 명령을 다시 이용하면 상환되지 않은 티켓의 수가 0에서 1로 바뀌었음을 확인할 수 있습니다.
7. 이제 여러분은 밥의 노드를 이용해 밥이 받은 티켓을 상환하거나 계속해 릴레이어로 활동하고 더 많은 티켓을 받아 나중에 한꺼번에 상환할 수 있습니다. 여러분은 이 작업을 앨리스가 더 이상 메시지를 위해 지불할 수 있는 HOPR가 남지 않을 때까지 반복해서 할 수 있습니다. 상환하기로 결정하면, 밥의 노드에서 redeemTickets 명령을 이용해 진행하면 됩니다.
7. 이 채널에서 밥이 얼마의 잔액을 갖고 있었는지 기억하시나요? 0입니다.
티켓을 상환한 후 채널 명령을 다시 입력하면 여러분은 채널 내 밥의 잔액이 늘어났음을 볼 수 있습니다.
8. 이제 앨리스에게 작별을 고하고 채널을 닫을 시간입니다. 채널을 닫기 위해 밥의 노드를 이용하고 다음을 입력합니다:
close Alice
몇분을 기다린 후 같은 기능을 다시 호출하면 채널이 완전히 닫힙니다.
이 쿨오프 기간 동안 밥의 노드가 받은 모든 티켓을 상환했는지 확인하기 바랍니다. 채널이 닫힌 후 이 작업은 더 이상 실행할 수 없습니다.
계속해서 즐기고 싶으신가요?
ID를 이용하는 것은 새로운 기능을 이용해보고 단일 디바이스에서 테스트를 실행해보는 좋은 방법입니다. 그러나 여러분은 다른 유저들에게도 메시지를 전송할 수 있습니다! peers 명령을 이용해 여러분은 채널을 열고 소통할 수 있는 공개적으로 열린 피어들에 대한 리스트를 찾을 수 있습니다.
그 중 하나의 피어를 고르고(가급적 quality 1의 피어) ping을 이용해 그들이 온라인인지 확인합니다 [피어의 HOPR 어드레스]
해당 피어가 온라인인것을 확인한 후 여러분은 앨리스와 밥이 했던 것과 마찬가지로 작업을 진행하면 됩니다.
참여해주셔서 감사합니다. 우리는 여러분이 HOPR 프로토콜에 대해 더 많이 배웠으며 즐거운 경험을 했기를 바랍니다. 이제 여러분은 HOPRd의 자랑스러운 유저라고 말할 수 있습니다.
*해당 포스팅은 투자 관련 정보 공유의 목적으로 포스팅된 글이며 투자 권유가 아닙니다. 그러므로 개인 투자의 책임은 모두 본인에게 있으니 참고하셔서 투자하시기 바랍니다.
이 글은 HOPR의 기본에 대해 알아보는 일련의 시리즈의 첫 에피소드입니다. 매주 새 업데이트를 받아보기 위해 우리와 함께하세요.
오늘날 인터넷의 현실
이번주 당신이 인터넷을 이용해 한 모든 일의 리스트를 언제 했는지와 함께 떠올려 보십시오. 메시지와 전화를 주고받은 모든 사람을 떠올려 보세요. 모든 소셜 미디어 인터랙션, 암호화폐 거래소 방문, 테이크아웃 주문, 의사와의 진료 예약, 데이팅 앱 매치도 떠올려 보세요. 말 그대로 당신이 방문한 모든 웹사이트를 생각해 보십시오(네 전부요!). 이제, 당신이 휴대폰을 지니고 다닌 모든 곳을 떠올려 보세요. GPS와 타임스탬프를 통해 쉽게 추적할 수 있을 것입니다.
당신의 이웃, 직장 상사, 은행, 보험사, 혹은 인터넷 상의 모두가 그 리스트를 본다고 생각하면 어떻습니까? 괜찮으시겠어요? 자 이번엔 그 리스트를 1주일이 아닌 지난 일년, 또 지난 10년간의 리스트로 생각해 보겠습니다.
이번엔 당신이 평생 인터넷에서 한 일들로 확장해 보시고 그 정보가 구매(또는 해킹)할 의사가 있는 누군가를 위해 영구 저장된다고 생각해 보세요.
이것이 오늘날 인터넷 이용의 현주소입니다. 우리가 전송하는 데이터는 주로 암호화되지만, 당신이 무엇을 누구에게 언제 전송하는지에 대한 데이터인 메타데이터는 해킹 및 추적의 대상이 될 수 있습니다.
이 문제는 점점 심각해집니다. 우리는 매 분마다 수백만 기가바이트의 데이터를 만들어 내고 있으며, 이 대부분은 메타데이터를 통해 노출되고, 이 숫자는 점점 커질 뿐입니다.
인터넷이 이런 식이면 안됩니다. 유저들은 프라이버시를 보장받아야 합니다. 기업은 그들의 직원과 고객의 개인정보를 보호할 도구를 보장받아야 합니다. HOPR는 모두를 위해 프라이버시를 제공합니다.
HOPR는 무엇인가요?
HOPR는 사람, 기업, 그리고 디바이스가 완벽한 프라이버시를 가지고 인터넷에서 정보를 교환할 수 있게 합니다. HOPR 또는 HOPR 플랫폼 위에 구동되는 애플리케이션 및 서비스를 이용해 소통하고 거래하는 사람들은 그 누구도 자신이 어떤 데이터를 누구와 언제 그리고 얼마나 공유하는지, 수신인 또는 발신인이 누구인지 완벽하게 비공개로 할 수 있습니다.
가장 좋은 점은, HOPR가 완전히 분산형이라는 것입니다. HOPR는 투명하고 신뢰를 요구하지 않아 당신은 제 3자에 의존할 필요가 없으며, 당신의 데이터에 대한 통제력을 내줘야 하는 서비스에 갇힐 일이 없습니다.
HOPR는 유저들이 운영하며 유저들을 위해 존재합니다. 누구나 자신의 컴퓨터 또는 라우터에 플러그된 개별 디바이스를 통해 HOPR 노드를 릴레이하고 HOPR 네트워크 유지에 참여할 수 있습니다. 가장 좋은 점은 HOPR가 완전히 인센티브형이라는 것이며, 이 뜻은 노드를 돌리고 토큰을 스테이킹하는 모두가 그들의 노력에 대해 HOPR 토큰을 보상으로 받는다는 말입니다.
더 알아보려면 어떻게 하면 되나요?
물론 위에 언급된 것 말고도 HOPR에는 많은 것들이 있습니다. 앞으로 몇주 동안 우리는 HOPR의 작동 방식, 메타데이터 프라이버시 중요성의 이유, HOPR 토큰을 보유하는 것과 HOPR 노드를 돌려 돈을 벌 수 있는 방법 등 다양한 방면에 대한 짧은 블로그 포스트 시리즈를 게시할 예정입니다.
각 포스트는 기술적 경험 및 전문성과 상관없이 모두를 위해 맞춤형으로 작성될 것입니다. 이 시리즈를 전부 읽을 때 쯤이면 여러분은 데이터 프라이버시를 개선하는 미션에 동참하기 위해 HOPR와 함께 할 준비가 될 것입니다. 앞으로 출시될 에피소드를 놓치지 않기 위해 이 채널을 팔로우해 주세요. 우리의 친절한 커뮤니티와 HOPR 앰배서더들은 언제나 텔레그램과 디스코드에서 도울 준비가 되어 있으니 질문이 있으시다면 이쪽으로 문의해 주세요.
*해당 포스팅은 투자 관련 정보 공유의 목적으로 포스팅된 글이며 투자 권유가 아닙니다. 그러므로 개인 투자의 책임은 모두 본인에게 있으니 참고하셔서 투자하시기 바랍니다.