본문 바로가기
반응형

전체 글560

Go Lang 설치하기 개발환경구성 샘플 테스트. 리눅스 CentOS7 구글에서 밀고 있는 간결한 Go 언어를 공부하려고요. 사실은 블록체인을 공부하고 싶은데요. 나만의 블록체인을 만들고 싶어서 찾던 중에 이더리움이 자료가 많아서 쉽게 접근할 수 있을 거 같아서 결정하게 되었어요. 이더리움 개발 언어가 다양하고 (Java , Python , JavaScript , Go , Rust , .NET , Delphi , Dart) 자바로도 가능해서 시작하기에 거부감이 없을 거 같아요.ㅋ 가만히 생각하다가 이더리움도 처음 시작하는 거라 이왕이면 앞으로도 다양한 분야에서 활용될 기대가 되는 Go언어도 같이 처음 시작하는 의미로 이더리움과 함께 공부하기로 했어요. 설치부터 해볼게요. 우선 Go 홈페이지에 접속해서 최신 버전을 확인합니다. https://go.dev/learn/ 현재 1... 2022. 9. 30.
VirtualBox 윈도우 10 설치 . Win10 ISO 파일 지난번에 Microsoft에서 제공하는 가상머신 파일로 윈도우10을 사용해봤는데요. 생각보다 좀 느린 거 같아서 ISO 파일을 이용해서 직접 설치합니다. https://www.microsoft.com/ko-kr/software-download/windows10 Windows 10 다운로드 Windows 10용 ISO 파일을 다운로드한 경우, 해당 파일은 선택한 위치에 로컬로 저장됩니다.컴퓨터에 타사 DVD 굽기 프로그램이 설치되어 있으며 해당 프로그램을 사용하여 설치 DVD를 만들려는 경우, www.microsoft.com ● Microsoft 다운로드 접속 지금 도구 다운로드 클릭하세요. ● 도구 설치 MediaCreationTool21H2.exe 실행하세요. ● 미디어 선택 ISO 파일이 있는 다른 .. 2022. 9. 29.
Pro*C . 한줄 단건만 조회하는 select 예제 테이블을 조회가 데이타는 2가지 경우입니다. 한줄의 레코드로 한건만 조회하는 경우와 여러줄의 레코드로 여러건을 조회하는 경우죠. Pro*C에서 한건만 조회하는 경우는 단순히 SELECT문으로만 처리하면 되고 여러건을 조회하는 경우에는 SELECT을 CURSOR와 FETCH를 조합해서 처리해야 됩니다. 이번에는 단건 처리만 간단하게 볼게요. int main() { EXEC SQL BEGIN DECLARE SECTION; char v_name[10+1]; char v_code[5+1]; EXEC SQL END DECLARE SECTION; EXEC SQL AT :con_name SELECT dat_name,dat_code INTO :v_name,:v_code FROM T_DATA where rownum = .. 2022. 9. 29.
Pro*C 컴파일 과정과 Makefile 만들기 Pro*C 프로그램 파일 확장자는 pc 입니다. pc 파일을 컴파일 하는 과정은 오라클에서 제공하는 PreCompiler를 통해 c 파일로 만듭니다. c 파일을 다시 c 컴파일러인 gcc를 통해 오브젝트 파일 (.o)를 만들고 링크를 통해 실행파일로 되는거에요. sample.pc → sample.c → sample.o → sample PreCompiler를 사용하기 위해 우선 ORALCE이 설치된 경로를 설정해 줘야 됩니다. 오라클 설치 경로가 /usr/oracleClient/app/oracle 라고 가정할게요. vi .bash_profile export ORACLE_BASE=/usr/oracleClient/app/oracle export ORACLE_HOME=$ORACLE_BASE/product/12... 2022. 9. 28.
Virtulbox 윈도우10 설치하기 . microsoft 제공 무료 가상머신 파일 VirtualBox에 개발용으로 윈도우10을 설치하려고 찾던 중에 마이크로소프트에서 가상머신 파일 제공한다고 것을 알게 되었네요. 대박입니다.^^ 윈도우10 ISO 파일을 다운로드해서 처음부터 윈도우10을 설치하면 한두 시간은 그냥 가는데 가상 머신 파일이라면 이 시간을 아낄 수 있겠죠. 단 90일만 사용할 수 있네요.^^;; 90일.. 3개월이면 배우기는 충분한 시간인 거 같네요. 그치만 처음 설치하고 스냅샷을 찍어 놓으시면 언제라도 처음으로 돌아갈 수 있을 거예요.ㅋ 그래도 90일 제한 때문에 좀 망설이다가 일단 설치해보고 나중에 계속 쓸지 생각해 보려고요.ㅋ ● Virtual Machines 사이트 접속 https://developer.microsoft.com/en-us/microsoft-edge/.. 2022. 9. 27.
Pro*C 에러 처리 . SQLCA ■ SQLCA 에러 처리 오라클에는 SQL 수행시 에러가 발생하면 SQLCA라는 구조체 필드에 매번 오류 상태를 갱신해 줍니다. 항상 마지막 SQL 처리에 대한 상태를 기억하고 있고 SQLCA 구조체를 사용하기 위해 Pro*C 프로그램에 sqlca 해더를 포함시켜야 됩니다. #include 또는 EXEC SQL INCLUDE SQLCA ★ sqlca 구조체 struct sqlca { char sqlcaid[8]; /* "SQLCA" 문자 스트링 , SQL 통신 영역 식별자*/ long sqlabc; /* slqca구조체의 바이트 길이 */ long sqlcode; /* 에러코드 */ struct { unsigned short sqlerrml; /* 에러 메시지 길이 , \n 포함된 길이 */ char s.. 2022. 9. 27.
Pro*C 에러 처리 . WHENEVER Pro*C에서 에러 처리하는 방법은 3가지입니다. ① WHENEVER문을 이용하는 방법 (묵시적 에러처리) ② sqlca를 이용하는 방법 (명시적 에러처리) ③ oraca를 이용하는 방법 (자세한 에러정보) 보통 WHENEVER와 sqlca 2가지를 사용하는데 프로그램 만드는 개발자의 취향에 따라 sqlca 사용하는 경우도 있고 WHENEVER 사용하는 경우도 있는 거 같아요. oraca는 에러 발생시에 더 상세한 에러 내용을 알고 싶을 때 사용하며 추가적인 작업이 필요하고 WHENEVER와 sqlca 두가지로도 에러처리에 충분하고 DB 쿼리문 에러가 몇 가지로 뻔해서 그런지 거의 사용하지 않는거 같아요. ㅋ 사용하면 더 좋겠죠. 묵시적 에러 처리(WHENEVER)는 SQL 오류에 대해 각각 개별적으로 .. 2022. 9. 26.
오라클 Pro*C 데이타베이스 DB 접속과 해제하기 SQL 쿼리문을 날리기 전에 당연히 DB에 접속을 해야겠죠.ㅋ Pro*C에서의 Oracle 접속과 해제에 대해서 간단히 알아볼게요. 접속을 위해선 오라클 계정과 계정의 비밀번호를 알고 있어야 될 거예요. 또 오라클이 설치된 서버가 아닌 다른 서버 장비에 설치된 오라클에 접속하기 위해 TNS을 이용한 원격 접속을 위해 TNSNAME도 알아야 됩니다. TNS정보는 오라클의 설치된 ORACLE_HOME 경로의 $ORACLE_HOME/network/admin 디렉터리 안에 TNSNAMES.ORA 파일 안에 기록되어 있습니다. 오라클을 관리하는 DBA가 잘 설정해 둔 거를 가져와서 사용만 하면 됩니다. ★ TNSNAMES.ORA 샘플 REMOTE_DB1 = ( DESCRIPTION = ( ADDRESS = ( P.. 2022. 9. 26.
Pro*C . 오라클 DB 데이터를 C / C++ 프로그램으로 제어 오라클은 C/C++ 프로그램 안에서 쿼리문을 직접 실행해서 테이블 데이터를 조작할 수 있게 PreCompiler를 제공하고 있습니다. C 소스 프로그램 안에 SQL 쿼리문을 삽입했다고 embedded SQL programming 이라고도 합니다. 보통 Pro*C라고 얘기하는데요. Pro*C의 소스 파일 확장자는 pc입니다. source.pc를 오라클에서 제공하는 PreCompiler를 이용합니다. ● C 프로그램 실행 과장을 보면 C 소스 코딩 source.c ▶ gcc 컴파일 ▶ 오브젝트 파일 생성 source.o ▶ 링크 ▶ 실행파일 생성 source ▶ 실행 ● PC 프로그램 실행 과정 PC 소스 코딩 source.pc ▶ PreCompiler ▶ source.c 생성 ▶ gcc 컴파일 ▶ 오브젝트.. 2022. 9. 25.
이더리움 solidity 스마트 계약 truffle 이용해서 테스트 하기 . console test solidity로 이더리움 스마트 계약을 만들었다면 생각대로 처리가 잘 되는지 검증을 위해 테스트를 해야 겠죠. 상태변수에는 값이 제대로 들어가는지 함수 결과가 맞는지 지갑 주소는 무엇인지 parameter 인자값을 임의로 변경해서 테스트하기 등... truffle에 내장된 test 기능을 이용해서 쉽게 테스트 해볼수 있습니다. ● truffle console 접속 truffle console --network [네트워크 이름] 사설 테스트넷에 접속해서 이더리움 블록체인에서 테스트를 진행합니다. C:\pjdapp>truffle console --network localnw truffle(localnw)> ▶ truffle(네트워크 이름)이 나오면 정상 접속된거에요. ♣ truffle-config.js 파.. 2022. 9. 25.
이더리움 DApp 개발 . Ganache + MetaMask 연동 가나슈와 메타마스크 지갑 연동을 위해서 네트워크 설정을 맞춥니다. 로컬 이더리움 네트워크인 가나슈를 기준으로 메타마스크를 지정하겠습니다. ■ Ganache와 Metamask 연동 ● Metamask 로컬 네트워크 추가 metamask 로그인하시면 상단에 이더리움 메인넷이 있는 둥근 박스가 보입니다. 클릭하시면 네크워크 목록이 표시되는데요. Ganache 로컬 이더리움과 연결하기 위해 아래 네트워크 추가 클릭하세요. ● Metamask 홈페이지가 오픈되네요. ▩ 네트워크 이름 : dapp_local . 다른 이더리움 네트워크와 구분되는 이름으로 지정해주세요. ▩ 새 RPC URL : HTTP://127.0.0.1:7545 . Ganache RPC SERVER 정보 그대로 넣어주세요. ▩ 체인 ID : 13.. 2022. 9. 24.
이더리움 DApp 개발 . Truffle + Ganache 연동 . smart contract 배포 이전까지 DApp 개발을 위한 필요한 프로그램 설치였다면 이제 이 프로그램들을 연계해서 이더리움 블록체인을 체험해 보겠습니다. Truffle - solidity 개발 환경 Ganache - 이더리움 블록체인 로컬 네트워크 환경 MetaMask - 이더리움 지갑(계정) Truffle로 스마트 계약을 만들어 Ganache 블록체인에 배포해서 Metamask 지갑에 ether가 송금되는지 확인합니다. 하나씩 해보겠습니다. ■ Truffle과 Ganache 연동 트러플과 가나슈 연동을 위해 네트워크 설정을 맞춥니다. ganache를 실행하면 아래처럼 Network ID와 RPC Server 정보가 설정되어 있어요. 가나슈를 기준으로 트러플을 설정하겠습니다. ● 우선 이더리움 사설 네트워크의 기본 NETWORK .. 2022. 9. 24.
이더리움 DApp 개발을 위한 Truffle(트러플) 설치하기 . solidity 컴파일 Truffle는 이더리움 스마트 계약(Smart Contract)을 만드는 개발 언어인 solidity를 컴파일하고 스마트 계약을 테스트를 할 수 있으며 배포까지 할수 있는 개발 환경입니다. http://trufflesuite.com/ TRUFFLE에 대해 아래와 같이 설명되어 있네요. 개발자로서의 삶을 더 쉽게 만드는 것을 목표로 하는 이더리움 가상 머신(EVM)을 사용하는 블록체인을 위한 세계적 수준의 개발 환경, 테스트 프레임워크 및 자산 파이프라인. 트러플은 node.js 플랫폼에서 npm 명령어로 설치할 수 있습니다. 트러플 홈페이지에 설치 명령어가 있네요. ngm install truffle -g npm은 node.js를 설치하면 자동으로 설치되는 패키지 관리 툴입니다. ♣ truffle 폴더.. 2022. 9. 23.
이더리움 DApp 개발을 위한 Node.js 설치하기 Node.js®는 Chrome V8 JavaScript 엔진으로 빌드된 JavaScript 런타임입니다. 자바스크립트(js)로 Non-blocking I/O와 싱글 스레드 개발이 가능한 서버 사이드 언어입니다. 자바스크립트(js)는 html과 함께 사용되는 웹 클라이언트 프론트 사이드 언어로만 알고 있었네요.^^;; 그동안 웹브라우저에만 있던 자바스크립트 엔진을 node.js에서 서버 개발에 활용하게 가져온 거 같아요. 그리고 런타임이란 프로그램 실행 환경을 말합니다. 여기서 node.js에서 강조하는 논블로킹과 싱글 스레드에 대해 아주 간단히 알아볼게요. 블로킹(blocking)은 간단하게 설명한다면 먼저 시작한 작업이 끝나야 다음 작업을 시작할 수 있는 거예요. 논블로킹(Non-blocking)은 먼.. 2022. 9. 23.
이더리움 로컬 개발 플랫폼 Ganache 설치하기 가나슈는 크림을 섞어 만든 초콜릿이란 뜻이며 설치하면 아이콘 모양도 크림 바른 초콜릿입니다. ■ Ganache . 가나슈 로컬 PC내에서 이더리움 블록체인 가상 네트워크를 생성해서 스마트 계약 트랜젝션을 송신할수 있고 MetaMask 지갑으로 송금도 할수 있는 저같은 왕초보에게는 안성맞춤인 이더리움 개발 툴입니다. 아시겠지만 메인넷에 스마트계약을 배포하거나 트랜젝션을 발생하면 삭제 불가능합니다. ^^;; 가나슈는 내PC안에서 모든 걸 하기때문에 실수해도 전혀 부담없이 편하게 개발할수 있어요. Ganache와 MetaMask 연동으로 이더리움 블록체인 개발을 할수 있어요. ● ganache 접속하기 https://trufflesuite.com/ganache/ ● Ganache 다운로드 하단에 DOWNLOA.. 2022. 9. 22.
이더리움 지갑 metamask 가입 설치하기 DApp 개발에 꿈꾸며 이더리움 지갑을 만들려고 찾다 보니 대부분 메타마스크를 사용하는거 같아 저도 메타마스크를 이용하려고 설치 진행합니다. ● 크롬에서 metamask를 검색하세요. https://metamask.io 클릭하세요. ● Download now 클릭하세요. ● Chrome 선택 밑에 《Install MetaMask for Chrome》 클릭하세요. ● chrome 웹 스토어 오른쪽 《Chrome에 추가》 클릭하세요. ● 확장 프로그램 크롬 브라우저 확장 프로그램 추가합니다. ● 동기화 MetaMask를 크롬 로그인 아이디와 동기화해서 다른 컴퓨터에서도 사용하려면 《동기화 사용...》 클릭하세요. 이럴 필요까지는 없을 거 같아 오른쪽 위 X 클릭해서 빠져나왔어요. 간단하게 설치가 끝나고 환영.. 2022. 9. 22.
solidity 0.5.16 프로그램 기초 배우기 . 스마트 계약(Smart Contract) 스마트 계약(Smart Contract)이란 이더리움 블록체인에서 동작하는 응용 프로그램입니다. 쓰지 않는 중고 물품을 공유하는 응용 프로그램을 만들어 블록체인에 배포하면 블록체인 참가자들이 다양한 클라이언트나 브라우저를 이용해서 중고 물품 리스트를 확인하거나 등록해서 공유할 수 있습니다. 이더리움 스마트 계약 개발에 사용되는 프로그래밍 언어로는 solidity , serpent , LLL 등이 있는데요. 아시겠지만 많이 사용되는 solidity 대세입니다. Solidity는 코딩해서 컴파일 과정을 거쳐 바이트코드를 만들어 배포하는 정적 언어로써 대규모의 프로그래밍도 가능하고 안정적입니다. 객제지향 언어이며 Class가 있는 C++ , Java와 매우 흡사합니다. solidity만의 고유의 문법이 있어 .. 2022. 9. 21.
이더리움 geth 멀티 노드 테스트하기 . private test network 블록체인에 참가하는 모든 참가자(노드)는 항상 동일한 블록 정보를 보유하고 열람할 수 있고 공유됩니다. 한 곳에서 발생한 액션이 같은 블록체인 네트워크에 있는 모든 참가자들에게 전송해서 공유되는지 그리고 내가 이더리움 네트워크에 대해 이해한 게 맞는지 확인을 위해 멀티 노드를 구성해서 테스트해봤습니다. ● 채굴하기 TestNet_1 노드에서 채굴을 하면 TestNet_2와 TestNet_3에 블록 생성 알림이 가는지 노드간에 자동으로 통신이 되는지 확인해 봅니다. ◆ TestNet_1 [tmach@localhost shell]$ geth attach rpc:http://localhost:3331 Welcome to the Geth JavaScript console! instance: Geth/v1.10... 2022. 9. 21.
이더리움 geth 멀티 노드 만들기 . private test network geth 클라이언트를 여러대 만들어서 테스트넷에서도 실제로 메인넷처럼 노드들이 각자 채굴하고 서로 송금하는 트랜젝션을 발생시켜 보려고요. 동일한 이더리움 네트워크로 연결하기 위해서는 genesis.json과 networkid를 같은 걸로 지정하면 됩니다. 노드마다 다른 컴퓨터로 한다면 나머지는 다른 설정들도 동일하게 지정해도 되겠죠. 그치만 여건이 안되어 리눅스 서버 한대에 3개의 geth 클라이언트를 구성합니다. ★ 다르게 해야 될 설정값 ① 데이터 디렉터리 ② --port 이더리움 클라이언트 listen 포트 ③ --http.port HTTP-RPC server listen 포트 . http rpc 사용시 ④ --ws.port WS-RPC server listen 포트 . ws(WebSocket) r.. 2022. 9. 21.
이더리움 geth JSON-RPC를 이용한 HTTP 웹으로 사용하기 리눅스에서 go-ethereum 클라이언트 설치 후 계속 Geth 콘솔을 통해 테스트넷 구성과 각종 명령어로 작업을 했었네요. 웹에서 geth를 접속해서 각종 명령어 작업을 할수 있다는걸 알게 되어네요. go-ethereum 클라이언트가 설치하면 JSON-RPC 기능도 같이 설치된다고 합니다. RPC란 remote procedure call, 리모트 프로시저 콜 원격의 다른 PC나 서버의 명령어나 기능(함수) 등을 마치 내 PC 로컬에서 실행하는거 처럼 처리해주는 프로세스간의 통신 기술입니다. Geth에 HTTP로 RPC기능을 구현한 HTTP-RPC 서버가 내장되어 있어 geth에 console로 접속하지 않아도 이용할수 있을거 같네요.ㅋ ● HTTP-RPC 모드로 geth 기동 명령어 기존의 테스트넷 .. 2022. 9. 21.
이더리움 geth 거래 송금 수수료 계산하기 블록체인에서 채굴(마이닝)은 고성능 컴퓨터에 100만원 이상의 그래픽 카드로 개인이 집에서 24시간 채굴해도 우리돈으로 만원정도 이렇게 한달에 20~30만원정도의 보상받는다고 하네요. 컴퓨터에 열도 많이 나고 펜소리도 시끄럽고 전기세도 많이 나오면서 가정집에서 하기가 만만치 않습니다. 암튼 참여자들이 계속 채굴해야 블록체인이 유지되기 때문에 이런 채굴에 대한 보상으로 채굴자에게 보너스로 수수료를 지불합니다. 수수료는 채굴에 요구되는 자원들과 문제 풀기 복잡성 그리고 현재 측정되어 있는 수수료 가격을 반영해서 수수료 가격이 결정됩니다. 수수료는 송금과 계약이 실행될 때 발생하며 Gas(가스)라고 합니다. Gas Price(수수료 가격)은 wei 단위이며 wei/Gas로 표현됩니다. ■ Gas가 어떻게 표현.. 2022. 9. 20.
이더리움 geth 테스트넷 Ether 송금하기 블록체인에서 송금은 주소에서 주소로 가상화폐를 보내는것입니다. 이더리움의 송금 단위는 wei입니다. 1 ether = 10^18 wei ♣ 채굴하기 > miner.start() null > miner.stop() null > eth.getBalance(eth.accounts[0]) 35000000000000000000 > > eth.blockNumber 7 ▶ 송금 테스트를 위해 미리 채굴해서 7개 블록과 35ether를 보상받았습니다. ♣ wei 단위를 ether 단위로 변환하기 > web3.fromWei(eth.getBalance(eth.accounts[0])) 35 ▶ wei로는 보기 불편해서 ether단위로 변환했지만 블록체인 전송 단위는 wei입니다. > web3.fromWei(120000000.. 2022. 9. 20.
이더리움 geth 채굴(마이닝)하기 . Ether 가상화폐 단위 채굴에 앞서 현재 상태와 기본적으로 알아야 될 것들을 체크할게요. ♣ geth console에 접속합니다. eth.accounts 명령어로 테스트넷에 생성된 계정을 모두 볼수 있습니다. 계정 주소가 배열로 표시되네요. > eth.accounts ["0x117309097e7afac115949c9384addca22d65451c", "0x8502af7eb47e8dcadc4f67923fdd7928a806f860", "0xc88d7a5c2638bf695b2a6b5c8bee93695975ab92"] > ♣ 채굴에서 우승자가 되면 보상받는데요. 보상 받는 계정을 Etherbase라고 합니다. eth.coinbase 명령어로 Etherbase가 누구인지 확인할수 있습니다. > eth.coinbase "0x1173090.. 2022. 9. 20.
이더리움 Geth 테스트넷 계정(지갑) 생성하기 지난번에 테스트넷 기동까지 해봤어요. 사설 테스트넷이지만 이제 이더리움 블록체인에 참여해 볼 거예요. 블록체인은 내컴퓨터에 또는 특정 서버에 계정 정보들을 모아 중앙관리하는 게 아니고 해당 블록체인에 참여하는 모든 노드의 블록들과 P2P 네트워크상에 존재하는 데이터이기 때문에 블록 또는 계정을 찾기 위해 변조할 수 없는 유일값이 있어야 됩니다. 이 유일값은 암호화적 해시함수(SHA256)를 통해 얻은 해시(checksum) 값을 사용합니다. 블록체인에 참여하는 간단 절차로는 신규 계정 생성해서 주소(해시)를 할당받고 Ether를 채굴해서 송금(거래)도 시켜봅니다. ■ 계정(지갑) 생성 이더리움의 계정은 EOA와 Contract 두가지가 있습니다. EOA는 Externally Owned Account . .. 2022. 9. 20.
반응형