$ sudo iptables -A PREROUTING -t nat -i eth0 -p tcp --dport 80 -j REDIRECT --to-port 9000

위의 명령어로 redirect를 할 수는 있지만 좀 더 안정적으로 forward하는 방법은 웹서버(nginx 등)을 이용하는 것이다.

Terminal multiplexer 라고 nohup과 같은 기능을 제공함. 즉, 명령어 실행 후 터미널을 닫아도 계속 실행되게 할 수 있음.

AWS EC2 돌릴 때와 같은 상황에서 유용함.

1. 인스톨 on Ubuntu.

$ sudo apt-get install tmux

2. tmux 실행

$tmux

3. tmux를 실행하면 터미널 하단에 초록색 띠같은게 생김.  tmux터미널이라고 부르겠음.

4. 거기서 명령어를 실행. (ex npm start)

5. 명령어가 실행됨.

6. ctrl b + d를 치면 tmux 터미널에서 빠져나옴.

7. command 는 background에서 계속 실행되고 있음. 터미널을 닫아도 마찬가지임. 

8. 다시 터미널에 접속한 후 tmux에서 실행되고 있는 작업을 확인하기 위해 아래의 명령어를 침.

$tmux ls

9. 그럼 tmux 로 인해 background에서 작업되고 있던 놈들이 맨왼쪽 작업번호화 함께 나옴.

10. 아래의 명령어를 치면 해당 작업번호의 tmux터미널로 이동. 

$tmux attach -t [작업번호]

11. ctrl+c를 통해 작업을 멈추고

12. ctrl+b+d를 통해 tmux 터미널을 벋어나면 background 작업을 멈출 수 있음.

13. 또 쓰다보면 세션에 이름을 붙이고 싶을 때가 있음.

14. 그럴땐

$tmux new-session -t [name]

[name] 부분에 원하는 세션 이름을 쓰면 됨.

15. 또 세션을 지우고 싶을 때도 있음.

그럴 땐

$tmux kill-session -t [session-name]

을 사용하면 됨.

아마존 AWC EC2 를 사용하기 위해서는 ssh 를 통해 접속해야 한다.

아마존 EC2에 NODEJS서버를 만들기위해 접속하는 방법.

1. key pair 가 있는 폴더에서 터미널 오픈

2. key pair 가 저장되어 있는 파일이름을 nodeeos.pem 이라고 한다면

3. 다음의 명령어로 ssh 접속.

$ sudo ssh -i nodeeos.pem ubuntu@[Public DNS]

*참고로 Public DNS 부분 입력 시 []를 생략해야한다.

리눅스에서 현재 열려있는 포트를 확인하기 위한 명령어는 아래와 같다.

$ sudo lsof -i -P -n | grep LISTEN

혹은

$ sudo netstat -tulpn | grep LISTEN

끝.

EOS 블록체인에서는 기존의 블록체인과는 다르게 계정을 만드는 게 좀 까다롭다.  비트코인이나 이더리움 블록체인에서는 간단하게 랜돔한 프라이빗키->퍼블릭키를 생성해 계정으로 사용할 수 있다. 하지만 EOS에서는 퍼블릭키, 프라이빗키와 더불어 account라는 것이 추가되었다. Account는 human-readable characters로서 정확하게 12자리의 알파벳으로 만들 수 있다. 12자 보다 짧아서도 안되고 길어서도 안된다. (물론 12자보다 짧은 account를 얻는 방법이 있긴 하지만 여기서는  언급하지 않겠다.)  그래서 EOS를 전송할 때는 퍼블릭키 대신 어카운트를 사용해 보낸다. 이메일과 비슷한 방식으로 보내기 때문에 외우기도 쉬워 EOS의 장점으로 꼽힌다. 다만, 이 어카운트를 만들 때 약간의 금전(EOS)가 필요하다는 점과  새 계정을 만들 때는 반드시 기존 계정을 이용해서 만들어야 한다는 점은 좀 불편할 수 있다.

위의 내용을 기본으로 하여 이번 포스팅에서는 기존 account가 있는 상태에서 새 account를 만드는 방법을 설명해 보겠다.

위에서 언급하였지만 새 account를 만들기 위해서 돈(EOS)가 든다. 이 부분에 대해 조금 더 설명하자면 비트코인이나 이더리움은 가상화폐를 전송할 때 수수료가 들지만 EOS는 전송 시 수수료는 들지 않지만 계정을 만들 때 돈이 든다. 왜냐하면 블록체인 내의 RAM을 구입해야 하기 때문이다. 간단히 비유하자면 전통적인 서버-클라이언트 구조에서 서버서를 빌릴 때 지불하는 금액으로 생각하면 되겠다. 메모리가 크고 빠른 서버를 구입하기 위해서는 더 많은 금액을 지불해야 하는 것 처럼 EOS 블록체인에서도 용량이 크고 빠른 dapp을 만들기 위해서는 좀 더 많은 EOS를 지불해 많은 컴퓨팅파워를 확보해야한다. 

두서 없이 말했다. 정리하자면 새 account를 만드는데 필요한 것은 아래와 같다.

1. 기존 EOS account

2. 기존 EOS account 내 EOS

기존 account 이름을 existing1234 이라 하고 새로 생성하려는 아이디를 creating1234(public key: EOSXXXX) 라고 하자. 다시 한번 명심해야 할 것은 EOS블록체인의 account 명은 반드시 12글자여야 한다는 점이다. 위 account명이 12자가 아니면 에러가 난다.

cleos를 이용해서 새 account를 만드는 명령어는 아래와 같다.

$ cleos system newaccount existing1234 creating1234 EOSXXX -stake-net "0.1 EOS" --stake-cpu "0.1 EOS" --buy-ram-kbytes 8

이렇게 하면 새로운 계정이 만들어진다. --stake-net "0.1 EOS"의 경우 account의 brandwidth를 0.1 EOS만큼 예치하여 사용 하겠다는 뜻이고 --stake-cpu는 계정의 cpu를 0.1 EOS를 예치하여 사용하겠다는 것이다.  

이상.

EOS 스마트계약은 C++로 작성되어 Web assembly 언어로 컴파일되어 실행된다. 여기서는 이 개발 툴(CDT)를 설치해 보겠다.

1) GIT HUB에서 clone 하기.

일단 임의 폴더에 clone 명령어를 통해 다운 받는다. 

$ git clone --recursive https://github.com/eosio/eosio.cdt --branch v1.2.1 --single-branch
cd eosio.cdt

2) 그리고 설치한다.

./build.sh


sudo ./install.sh


Chapter1-2: EOSIO/EOS image 다운 및 설치

전편에서 설명한 Docker를 설치하였다면 이제 docker 명령어를 이용하여 EOS Docker 이미지를 다운 받아 컴퓨터안에 EOS node를 생성할 차례이다. 이 단계가 정상적으로 끝난다면 지금 당신의 컴퓨터 내에 EOS 노드가 생성될 것이고 EOS Mainnet과 통신을 할 수 있게 된다.

1) 간단한 명령어로 Docker eosio 이미지 다운 받기

$ sudo docker pull eosio/eos

2) 그리고 임의의 공간에 contracts라는 폴더를 만든다. 그리고 pwd명령어를 이용해 경로 파악한 후 보관한다. 여기에 EOS관련 계약 등이 담길 것이다.

$ mkdir contracts

$ cd contracts

$ pwd

3) 노드 생성 시키기. CONTRACT_DIR에 위에서 파악한 contracts 폴더의 경로를 대체한다.

$ docker run --name eosio \
  --publish 7777:7777 \
  --publish 127.0.0.1:5555:5555 \
  --volume CONTRACTS_DIR:CONTRACTS_DIR \
  --detach \
  eosio/eos \
  /bin/bash -c \
  "keosd --http-server-address=0.0.0.0:5555 & exec nodeos -e -p eosio --plugin eosio::producer_plugin --plugin eosio::history_plugin --plugin eosio::chain_api_plugin --plugin eosio::history_plugin --plugin eosio::history_api_plugin --plugin eosio::http_plugin -d /mnt/dev/data --config-dir /mnt/dev/config --http-server-address=0.0.0.0:7777 --access-control-allow-origin=* --contracts-console --http-validate-host=false --filter-on='*'"

위 명령을 수행하면 로컬노드가 생성된다. 그러나 아직  Development용으로 실제 EOS Mainnet과 연결되지 않았다. 실제 Mainnet과 연결하려면 아래의 명령을 수행한다.

$ docker run --rm --name eosio -d -v ~/eosio-wallet: /root/eosio-wallet eosio/eos-dev/ bin/bash -c 'keosd'

그리고 cleos 단축키 만든다. 리눅스의 경우 "bashrc"파일에 아래의 문구를 삽입한다.


alias cleos='docker exec -it eosio /opt/eosio/bin/cleos --url http://127.0.0.1:7777 --wallet-url http://127.0.0.1:5555'

4) 실제 EOS Mainnet 과 연결되었는지 확인하기

$ cleos get info

위 명령을 수행하면 json파일 형식이 리턴 되는데 head_block_producer가 eosio로 되어 있으면 현재 메인넷과 연결이되지 않은 상태이고 eosio가 아닌 eoslaomaocom 등 이 나타난다면 정상적으로 EOS Mainnet과 연결된 것이다.

여기까지 정상적으로 끝냈다면 일단 컴퓨터에 EOS 노드가 만들어진 것이다. 다음에는 EOS 스마트 계약을 만들 수있는 CDT를 설치하도록 하자.

요새 이 쪽 바닥에서 핫하다는 EOS Blockchain 플랫폼을 맛보기 위한 작업에 착수하였다. 일단 관련 documentation과 인터넷 기사를 읽어보았다. 가장 눈에 띄는 사실은 블록체인 플랫폼인데 기존 centralized platform처럼 빠른 속도를 지향한다는 점이다. 예전 이더리움 플랫폼으로 무언가 만들어보려던 나는 너무 느린 속도에 상품성이 없을 거 같아서 중단한 적이 있다. 그런데 이더리움의 대항마로 혜성처럼 나타난 EOS는 그런 단점을 해결해 줄 수 있을 것 처럼 보인다.

지식이 거의 전무한 C++를 익혀야 된다는 사실이 좀 마음에 걸리지만 그냥 시작해 보기로 결심하였다.

Chapter 1-1 : Docker 설치하기

모든 개발작업이 그렇듯 EOS Dapp을 만드려면 개발 환경을 만들어주어야 하는데 그 첫번째는 Docker를 설치하는 작업이다. 혹시 모르는 독자들을 위해 Docker에 대해 설명이 잘되어 있는 블로그 페이지를 소개한다.

https://subicura.com/2017/01/19/docker-guide-for-beginners-1.html

참고로 나는 Ubuntu 18.04 를 사용하고 있다.

1) 패키지 업데이트와 시스템 업그레이드

$ sudo apt update

$ sudo apt upgrade

2) 필수 dependency 설치

$ sudo apt install apt-transport-https ca-certificates curl software-properties-common

3) Docker's GPG 키와 repository 추가

curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
sudo add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"

4) 여기까지 하면 Docker repository 모두 설치완료 되었다. 그리고 다시 apt 패키지 업데이트 및 최신버전 Docker CE(community Edition) 설치하면 끝...

sudo apt update
sudo apt install docker-ce

5) Docker 버전 체크

docker -v

현재 기준 Docker의 최신 버전은 18.06.1 이다.

여기까지 하면 개발환경 구성 첫번째 단계인 Docker설치가 끝난다.


1. 미국 밖에서 인터넷으로 미국 방송 실시간 보기

대부분 아시겠지만 미국 밖에서 미국방송을 실시간으로 보기는 어렵습니다. 대부분의 웹사이트에서 저작권 문제로 해외에서 들어오는 아이피를 차단하기 때문이죠. 영화나 미드같은 건 넷플릭스 등으로 시청하면 되는데 스포츠나 UFC는 실시간으로 보지 않으면 재미가 반감되죠. 그래서 제가 이번 포스트에서 어떻게 하면 미국 방송을 실시간으로 볼 수 있을지에 대해서 포스팅을 해보려 합니다. 미국 방송을 실시간으로 스트리밍해주는 회사는 여러개가 있는데 이번에는 sling (https://www.sling.com/)이라는 회사를 소개해 드리겠습니다. 위 미국이 아닌 지역에서 URL로 접속해 보시면 아래와 같은 화면을 볼 수 있을 겁니다.

SLING TV는 미국 내에서만 접속가능하니 접속할 수 없다고 나옵니다. 인터넷을 사용할 시 사용자의 주소가 있는데 이를 아이피 주소라고 합니다. 이 주소를 미국 주소로 변경할 필요가 있습니다. 

2. Sling접속하기 위한 준비물: VPN

위에도 언급한 바와 같이 미국 방송을 실시간으로 보기 위해서는 미국아이피주소로 해당 웹사이트를 접속해야합니다. 따라서, 사용자의 아이피주소를 미국아이피주소로 바꿔주는 VPN이 필요합니다. ExpressVPN을 사용하여 보여드리도록 하겠습니다. ExpressVPN에 대해 자세한 내용은 아래  제 블로그 링크(http://mingmingking.com/11)를 참고해 주세요.

일단 ExpressVPN을 설치해 주시면 아래와 같은 프로그램이 설치가 됩니다. 

전원 버튼과 접속 장소(SELECTED LOCATION)을 선택하고 동그란 전원버튼을 눌러줍니다. 그럼 아래와 같이 됩니다. 


그럼 이제 이 상태로 인터넷에 접속하면 웹사이트는 한국이 아닌 미국 할리우드에서 접속하는 것으로 인식하죠. 왜냐하면 아이피 주소가 한국아이피주소가 아닌 미국할리우드 아이피주소니까요. 그럼 이 상태에서 SLING TV에 접속해 볼까요? 

접속이 됩니다. ㅎㅎㅎ "WATCH 7 DAYS FREE를 클릭하셔서 회원가입을 하시고요.

가입 옵션을 선택하세요. $25짜리 Orange와 Blue옵션과 $40짜리 옵션 1개가 있습니다. $40짜리는 이름이 없네요. $40짜리는 채널 수가 더 많습니다. 각 종 FOX, NBC 등의 뉴스프로는 물론 AMC, ESPN 등등 거의 모든 채널이 있다고 보시면 됩니다. 

그럼 스트리밍 화질을 확인해 보실까요? 


속도도 괜찮고 화질도 볼만합니다. 

만약 일주일 보시고 맘에 안들어 취소하고 싶으시다면 취소가능합니다. 아래 빨간화살표가 가르키는 설정버튼을 누르시고 Manage Account로 들어가신 후 Cancel Subscription을 클릭하시면 일주일이 지나도 결제되지 않습니다. 

참 쉽죠잉? 참고로 내일 모래 방영되는 McGregor vs KHABIB도 VPN과 SLING TV를 통해 실시간으로 볼 수 있습니다. 근데 이건 따로 돈을 더 지불해야하네요. ㅜㅜ 

그럼 이렇게 미국 티비 실시간 보기 포스팅을 마치겠습니다. 잘안되거나 궁금한 부분 있으면 비댓으로 남겨주세요. 




A random element in a python list can easily extracted with a newly added module called "secrets".

Without secrets module, you may consider a code as show below.


import random

alist= [1,3,4,5,3,2,1]

n = random.randint(0, len(alist)-1))

print(alist[n])


There is no problem in acheiving the goal, but it does not seem pythonic.

In python 3.6, a module called "secrets" was added. It describes as below.


"The secrets module is used for generating cryptographically strong random numbers suitable for managing data such as passwords, account authentication, security tokens, and related secrets."


Using the secrets module you can shorten the codes 2/3 as below. 


import secrets


alist= [1,3,4,5,3,2,1]

print(secrets.choice(alist))


It looks much better, cleaner so pythonic.






+ Recent posts