추적 매수/매도 기법(Trailing buy/sell strategy)을 이용한 자동화된 바이낸스 자동매매 프로그램
이 프로젝트는 제 코드를 테스트 하기 위한 단순한 테스트 프로젝트 입니다.
최신 업데이트 정보는 README.md에 서 확인 가능합니다. 이 페이지는 한국어로 프로그램에 대한 설명만 적혀있습니다.
이 프로그램을 이용하여 돈을 벌 수 있을지 없을지는 절대 보장하지 않습니다.
리스크를 감당하실 수 있을 경우에만 사용하세요! 이 코드를 이용하여 직/간접적으로 생긴 손실이나 경제적인 어려움이 생길 경우 절대 책임지지 않습니다.
프로그램을 업데이트하기 전에, 구매 가격을 꼭 적어두시기 바랍니다. 환경설정이나 구매 가격 정보가 손실될 수 있습니다.
이 프로그램은 가격의 하락/상승 추세를 따라가며 추적 매수/추적 매도를 하는 기법을 기반으로 작성되었습니다.
- 이 프로그램은 여러개의 코인을 모니터링 가능합니다. 각 코인들은 1초마다 가격 확인 및 매수/매도 처리가 됩니다.
- 이 프로그램은 지속적인 데이터베이스로 MongoDB를 사용합니다. 하지만 라즈베리파이 32bit 지원을 위해 최신 버젼을 사용하지 않습니다. 사용된 MongoDB 버젼은 apcheamitru에서 제공된 3.2.20입니다
- 이 프로그램은 리눅스와 라즈베리파이 4 32비트에서만 테스트/작동 확인하였습니다. 다른 플랫폼은 테스트하지 않았습니다.
이 프로그램은 설정된 기간동안의 가장 낮은 가격을 모니터링합니다. 현재 값이 가장 낮은 가격에 도달했을 경우에, 프로그램은 매수를 위한 STOP-LOSS-LIMIT 주문을 넣습니다. 현재 가격이 계속 떨어질 경우, 프로그램은 이전 주문을 취소하고, 새로운 가격으로 STOP-LOSS-LIMIT 주문을 넣습니다.
- 이 프로그램은 매도를 위한 코인이 충분할 경우 (보통 $10정도) 매수 주문을 넣지않습니다.
예를 들어, 매수 환경설정이 다음과 같이 되었다고 가정해봅시다:
- 최대 매수 수량(Maximum purchase amount): $50
- 매수 시작 퍼센트(Trigger percentage): 1.005 (0.5%)
- 스탑 가격 퍼센트(Stop price percentage): 1.01 (1.0%)
- 리밋 가격 퍼센트(Limit price percentage): 1.011 (1.1%)
그리고 현재 마켓이 아래와 같다고 가정합니다:
- 현재 가격(Current price): $101
- 최저 가격(Lowest price): $100
- 매수 시작 가격(Trigger price): $100.5
이럴 경우 현재 가격($101)이 매수 시작 가격($100.5)보다 높기 때문에, 프로그램은 주문을 넣지 않습니다.
시간이 지나, 마켓이 다음과 같이 변했다고 가정합니다:
- 현재 가격(Current price): $100
- 최저 가격(Lowest price): $100
- 매수 시작 가격(Trigger price): $100.5
현재 가격 ($100)이 매수 시작 가격($100.5)보다 낮기 때문에, 프로그램은 매수 STOP-LOSS-LIMIT 주문을 넣습니다. 간단한 계산을 위해 커미션은 계산하지 않았습니다. 실 거래시, 주문 수량은 다를 수 있습니다. 매수 주문은 다음과 같이 넣어집니다:
- 스탑 가격(Stop price): $100 * 1.01 = $101
- 리밋 가격(Limit price): $100 * 1.011 = $101.1
- 수량(Quantity): 0.49
시간이 지나 마켓이 다음과 같이 변했다고 가정합니다:
- 현재 가격(Current price): $99
- 현재 리밋 가격(Current limit price): $99 * 1.011 = 100.089
- 주문 스탑 가격(Open order stop price): $101
주문 스탑 가격($101)이 현재 리밋 가격($100.089)보다 높기 때문에, 프로그램은 현재 주문을 취소하고 새로운 매수 STOP-LOSS-LIMIT 주문을 넣습니다:
- 스탑 가격(Stop price): $99 * 1.01 = $99.99
- 리밋 가격(Limit price): $99 * 1.011 = $100.089
- 수량(Quantity): 0.49
만약 현재 가격이 계속 떨어진다면, 새로운 매수 주문이 새로운 가격에 맞춰 다시 넣어집니다.
만약 마켓이 다음과 같이 변했다고 가정합니다:
- 현재 가격(Current price): $100
그러면 현재 가격이 스탑 가격($99.99)에 도달하였기 때문에, 매수 주문은 리밋 가격($100.089)에 체결이 됩니다.
만약 매도를 위한 충분한 코인이 있고 매수 가격(Last buy price)가 저장되었을 경우, 프로그램은 매도 신호를 모니터링하기 시작합니다. 현재 가격이 매도 시작 가격에 도달한다면, 프로그램은 매도 STOP-LOSS-LIMIT 주문을 넣습니다. 만약 현재 가격이 계속 상승한다면, 프로그램은 이전 주문을 취소하고, 새 가격으로 매도 STOP-LOSS-LIMIT 주문을 넣습니다.
- 만약 코인이 최소 주문 금액 ($10)보다 평가금이 낮다면, Binance에서 $10미만의 주문은 접수되지 않기 때문에 프로그램은 매수 가격(Last buy price) 기록을 없앴니다 .
- 만약 매수 가격(Last buy price)가 저장되지 않았다면, 프로그램은 코인을 매도하지 않습니다.
예를 들어, 매도 환경설정이 다음과 같이 되었다고 가정해봅시다:
- 매도 시작 퍼센트(Trigger percentage): 1.05 (5.0%)
- 스탑 가격 퍼센트(Stop price percentage): 0.98 (-2.0%)
- 리밋 가격 퍼센트(Limit price percentage): 0.979 (-2.1%)
그리고 현재 마켓이 아래와 같다고 가정합니다:
- 소유 코인 수량(Coin owned): 0.5
- 현재 가격(Current price): $100
- 매수 가격(Last buy price): $100
- 매도 시작 가격(Trigger price): $100 * 1.05 = $105
이럴 경우 매도 시작 가격($105)이 현재 가격 ($100)보다 높기 때문에 프로그램은 주문을 넣지 않습니다.
만약 현재 가격이 계속 하락한다면, 프로그램은 현재 가격이 매도 시작 가격에 도달할때까지 계속 모니터링합니다.
시간이 지나, 마켓이 다음과 같이 변했다고 가정합니다:
- 현재 가격(Current price): $105
- 매도 시작 가격(Trigger price): $105
현재 가격 ($105)가 매도 시작 가격($105)와 같거나 높기때문에 프로그램은 새로운 매도 STOP-LOSS-LIMIT 주문을 넣습니다. 간단한 계산을 위해 커미션은 계산하지 않았습니다. 실 거래시, 주문 수량은 다를 수 있습니다. 매도 주문은 다음과 같이 넣어집니다:
- 스탑 가격(Stop price): $105 * 0.98 = $102.9
- 리밋 가격(Limit price): $105 * 0.979 = $102.795
- 수량(Quantity): 0.5
시간이 지나 마켓이 다음과 같이 변했다고 가정합니다.:
- 현재 가격(Current price): $106
- 현재 리밋 가격(Current limit price): $103.774
- 주문 스탑 가격(Open order stop price): $102.29
주문 스탑 가격($102.29)가 현재 리밋 가격($103.774)보다 낮기 때문에, 프로그램은 현재 주문을 취소하고 새로운 매도 STOP-LOSS-LIMIT 주문을 넣습니다:
- 스탑 가격(Stop price): $106 * 0.98 = $103.88
- 리밋 가격(Limit price): $106 * 0.979 = $103.774
- 수량(Quantity): 0.5
만약 현재 가격이 계속 상승한다면, 새로운 매도 주문이 새로운 가격에 맞춰 다시 넣어집니다.
만약 마켓이 다음과 같이 변했다고 가정합니다:
- 현재 가격(Current price): $103
그러면 현재 가격이 스탑 가격($103.88)에 도달하였기 때문에, 매도 주문은 리밋 가격($103.774)에 체결이 됩니다.
예를 들어, 매도 스탑-로스 환경설정이 다음과 같이 되었다고 가정해봅시다:
- 최대 손실 퍼센트(Max loss percentage): 0.90 (-10%)
- 매수 중단 시간(분): 60
그리고 현재 마켓이 아래와 같다고 가정합니다:
- 현재 가격(Current price): $95
- 매수 가격(Last buy price): $100
- 스탑-로스 가격(Stop-Loss price): $90
이럴 경우 스탑-로스 가격($90)이 현재 가격($95)보다 낮기 때문에 프로그램은 매도 주문을 넣지 않습니다.
만약 현재 가격이 계속 하락한다면, 프로그램은 현재 가격이 스탑-로스 가격에 도달할때까지 계속 모니터링합니다.
시간이 지나, 마켓이 다음과 같이 변했다고 가정합니다:
- 현재 가격(Current price): $90
- 스탑-로스 가격(Stop-Loss price): $90
현재 가격($90)이 스탑-로스 가격($90)과 같거나 낮기때문에 프로그램은 새로운 매도 MARKET 주문을 넣습니다. 실 거래시, 주문 수량은 다를 수 있습니다.
그리고 지속적인 매수/매도를 방지하기 위해서 해당 코인은 60분동안 임시로 거래가 중단됩니다. 프론트엔드는 중단 아이콘과 다시 거래 시작까지 얼마나 남았는지 시간을 보여줍니다. 거래를 바로 시작할려면 플레이 아이콘을 클릭하시면 됩니다.
- 수동 거래
- 소규모 자산 BNB로 전환하기
- 모든 코인 거래하기
- 여러 코인들을 동시에 모니터링하기
- 스탑-로스
프론트엔드는 React.js 기반으로 개발 되었으며 웹소켓을 통해 통신합니다:
- 지정한 코인들의 매수/매도 신호와 현재 주문을 모니터링 할 수 있습니다.
- 계좌 현황을 볼 수 있습니다.
- 전체 환경 설정/코인 환경설정을 할 수 있습니다.
- 모니터링 되지 않은 코인의 캐시 정보를 지울 수 있습니다.
- 외부 링크를 볼수 있습니다.
- 홈 화면에 추가하기 기능을 지원합니다.
환경 변수를 이용해 환경 설정을 변경 가능합니다.
/config/custom-environment-variables.json
코드를 확인하시면 설정 가능한 환경변수 목록을 볼 수 있습니다.
아니면 프로그램 실행 후, 프론트엔드에서 설정을 변경 가능합니다.
-
먼저
.env.dist
파일을.env
파일로 복사합니다환경 변수명 설명 예시 BINANCE_LIVE_API_KEY 실서버 Binance API key (from Binance) BINANCE_LIVE_SECRET_KEY 실서버 Binance API secret (from Binance) BINANCE_TEST_API_KEY 테스트서버 Binance API key (from Binance Spot Test Network) BINANCE_TEST_SECRET_KEY 테스트서버 Binance API secret (from Binance Spot Test Network) BINANCE_SLACK_ENABLED 슬랙(Slack) 활성화/비활성화 true BINANCE_SLACK_WEBHOOK_URL 슬랙(Slack) 웹훅(webhook) URL (from Slack) BINANCE_SLACK_CHANNEL 슬랙(Slack) 채널(channel)명 "#binance" BINANCE_SLACK_USERNAME 슬랙(Slack) username Chris BINANCE_LOCAL_TUNNEL_ENABLED 로컬터널(local tunnel) 활성화/비활성화 true BINANCE_LOCAL_TUNNEL_SUBDOMAIN 외부 링크를 위한 로컬터널(local tunnel) 서브도메인 binance -
docker-compose를 이용하여 프로그램을 실행하시기 바랍니다.
먼저 최신 코드를 Pull합니다:
git pull
실서버 모드를 사용하실려면, DockerHub에서 최근에 빌드된 이미지를 사용하실 수 있습니다:
docker-compose -f docker-compose.server.yml pull docker-compose -f docker-compose.server.yml up -d
라즈베리 파이 4 32bit를 사용하실 경우, 이미지를 다시 빌드하시기 바랍니다:
npm run docker:build docker-compose -f docker-compose.rpi.yml up -d
테스트 모드를 사용하실려면, 아래 명령어를 실행하시면 됩니다:
docker-compose up -d
-
브라우저를 열어
http://0.0.0.0:8080
에 접근하시면 프론트엔드에 접근하실 수 있습니다.- 프로그램 실행시, 외부 URL은 슬랙(Slack)에 공지 됩니다.
- 봇을 사용시 문제가 발생할 경우, 먼저 로그를 확인하시기 바랍니다. 참조: Troubleshooting
프론트엔드 - 모바일 | 세팅 | 수동 거래 |
---|---|---|
프론트엔드 - 데스크탑 |
---|
차트 | 매수 주문 | 매도 주문 |
---|---|---|
이 프로젝트가 도움이 되셨다면, 개발자에게 작은 기부를 하실 수 있습니다.
저는 이 프로젝트에 포함된 정보 및 자료의 정확성이나 안정성에 대해서 어떠한 보증도 하지 않으며 어떠한 책임을 지지 않습니다. 손해의 가능성에 사전에 통보한 경우더라도, 이 코드나 연결된 코드를 직간접적으로 사용함으로써 발생하는 모든 청구, 손해, 손실, 비용 또는 책임 (이익 손실, 업무 중단 또는 정보 손실로 인한 직/간접적인 손해 포함)에 대해 어떠한 경우에도 책임을 지지 않습니다.
그러니 리스크를 감당하실 수 있을 경우에만 사용하십시요!