基本上 Gekko 交易機器人本身就推薦使用 Commandline 介面 (CLI),一來它對電腦設備要求較低 (其實本來就不高),二來它能直接開啟複數個機器人 (沒有 UI Port 問題),加上能自訂的細節也較多,有些功能是沒有做出來到網頁 UI 介面的,像是 Telegram bot 功能、Email 通知功能...等,而且如果你跟我一樣是把 Gekko 開在雲端主機上,使用 CLI 多少也能降低使用量,避免它超出限額。
Gekko 原作者也有提到 childprocess has died. 的情況可以用 CLI 的方式來開啟 Gekko,它對策略的執行比較不會出現錯誤。
再來就是多線交易的問題了,由於為了避免不同機器人互相「搶資金」而造成錯誤所以在 UI 介面直接限制了單一交易所多個機器人這點,但在 CLI 並不存在這個問題,所以可以直接多開 Gekko。舉例來說,即使你有 XVG/BTC、XRP/BTC 兩個機器人在運作,兩者並不會互相衝突任,因為誰先達成策略的條件就會先執行該貨幣的買賣,然後根據買賣後的結果再繼續跑原本的策略。
用 CLI 開啟 Gekko
以下的操作是基於 Gekko 已經完整安裝的情況,如果還沒在本機或雲端上裝好 Gekko 請參考前篇提到的安裝教學、安裝到雲端。
首先要建立一個 config.js 在 Gekko 資料夾中,它裡面本身就有附一個 sample-config.js 能直接讓你拿來改。
基本上我把 config.js 的內容分為六層 :
- - config.watch - 指定觀測的市場,也就是要交易的貨幣
- - config.tradingAdvisor - 設定 Candlestick 的時間長短與選擇策略
- - config.strategy - 個別策略的參數
- - config.paperTrader - 模擬交易機器人
- - config.trader - 實際交易機器人
- - config.plugins - 外附的插件 (非必要),像 mailer、telegrambot...等
其中 paperTrader 和 trader 只能擇一,plugins 也可以都不要啟用。
config.watch = {
exchange: 'binance',
currency: 'USDT',
asset: 'BTC',
tickrate: 20 //更新速度,預設 20 秒更新一次
}
config.watch 的部分只能針對一個交易所、一組貨幣 (e.g. BTC/USDT),如果你想達到多線交易就必須複製多個 config.js 然後去改每個 config.watch,最後用指令批次執行多個 Gekko。
config.tradingAdvisor = {
enabled: true,
method: 'RSI_BULL_BEAR', //選用的策略
candleSize: 15, //K棒時間 (分鐘)
historySize: 10,
adapter: 'sqlite'
}
config.tradingAdvisor 是一定要開的,不然你就只是單純的看盤功能而已,在這邊也一樣可以指定你的自訂策略,但後面的 config.strategy 要把參數手動加進去,在 CLI 模式 .toml 檔似乎是沒有用的。
config.RSI_BULL_BEAR = {
SMA_long : 800,
SMA_short : 40,
BULL_RSI : 10,
BULL_RSI_high : 80,
BULL_RSI_low : 50,
BEAR_RSI : 15,
BEAR_RSI_high : 50,
BEAR_RSI_low : 25
}
這邊直接拿之前介紹的 RSI 自訂策略來當範例,內建策略它都已經幫你建好了 config.strategy,只要修改裡面的數字微調就可以了,但如果你是要使用自己的策略則要把 .toml 檔轉成像我上面這種形式它才能正確讀取。
config.paperTrader = {
enabled: true, //開啟模擬交易
reportInCurrency: true,
simulationBalance: {
asset: 1,
currency: 100,
},
feeMaker: 0.15,
feeTaker: 0.25,
feeUsing: 'maker',
slippage: 0.05,
}
config.paperTrader 就是模擬交易,功能和 UI 介面的完全一樣,可以自訂起始資產、手續費等,但若開啟了 paperTrader 就不能再使用真實資金的交易機器人了,所以兩者請擇一或再開一個 Gekko。
config.trader = {
enabled: false,
key: '', //API key
secret: '', //secret API key
username: '', //交易所沒有需要用戶名就免填
passphrase: '', //交易所沒有需要 passphrase 就免填
orderUpdateDelay: 1, //未成交的單要在幾分鐘後調整
}
config.trader 會需要用到交易所提供的 API Key 且在交易所方面開啟 API 交易功能,用戶名跟 passphrase 如果沒有的話就不需要填。
plugins 的部分可以適自己需要開啟,對於交易功能沒有影響。
config['I understand that Gekko only automates MY OWN trading strategies'] = true;
還有在整個 config.js 的最下方有一行類似同意書的概念,要改成 true 才能正確啟用。
node gekko --config config.js
修改完整個 config.js 並儲存後就可以用 CMD 開啟 Gekko 了,如果你有多個 config 設定想要多開 Gekko 只要改指令後方的檔名就可以了。
用 CLI 的方式執行 Gekko 對於想要多線操作的人方便不少,不用改 UI 顯示的 Port 或得為網頁介面多付出電腦效能,同樣的,在雲端也可以用這個辦法多開 Commandline 介面的 Gekko,就不用被一堆 CMD 佔滿畫面了。
留言
張貼留言