FMZの拡張APIでディスクのパラメータを大量に変更する方法を教えます

作者: リン・ハーン小さな夢, 作成日:2023-12-09 20:39:41, 更新日:2023-12-12 21:43:48

img

FMZで実力ディスクのパラメータを大量に変更するにはどうすればいいですか?実力ディスクの数が数十個を超え,数百個に達すると,一台ずつ手動で配置する場合は維持が非常に困難です.このとき,FMZの拡張APIを使用してこれらの操作を行うことができます.

前回の記事では,FMZの拡張APIを使用してすべてのディスク,グループディスクを監視し,ディスクに命令を送信する方法について説明しました.

パラメータ設定:

img

戦略コード:

// 全局变量
var isLogMsg = true   // 控制日志是否打印
var isDebug = false   // 调试模式
var arrIndexDesc = ["all", "running", "stop"]
var descRobotStatusCode = ["空闲中", "运行中", "停止中", "已退出", "被停止", "策略有错误"]
var dicRobotStatusCode = {
    "all" : -1,
    "running" : 1,
    "stop" : 4,
}

// 扩展的日志函数
function LogControl(...args) {
    if (isLogMsg) {
        Log(...args)
    }
}

// FMZ扩展API调用函数
function callFmzExtAPI(accessKey, secretKey, funcName, ...args) {
    var params = {
        "version" : "1.0",
        "access_key" : accessKey,
        "method" : funcName,
        "args" : JSON.stringify(args),
        "nonce" : Math.floor(new Date().getTime())
    }

    var data = `${params["version"]}|${params["method"]}|${params["args"]}|${params["nonce"]}|${secretKey}`
    params["sign"] = Encode("md5", "string", "hex", data)
    
    var arrPairs = []
    for (var k in params) {
        var pair = `${k}=${params[k]}`
        arrPairs.push(pair)
    }
    var query = arrPairs.join("&")
    
    var ret = null
    try {
        LogControl("url:", baseAPI + "/api/v1?" + query)
        ret = JSON.parse(HttpQuery(baseAPI + "/api/v1?" + query))
        if (isDebug) {
            LogControl("Debug:", ret)
        }
    } catch(e) {
        LogControl("e.name:", e.name, "e.stack:", e.stack, "e.message:", e.message)
    }
    Sleep(100)  // 控制频率
    return ret 
}

// 获取指定策略Id的所有运行中的实盘信息
function getAllRobotByIdAndStatus(accessKey, secretKey, strategyId, robotStatusCode, maxRetry) {
    var retryCounter = 0
    var length = 100
    var offset = 0
    var arr = []

    if (typeof(maxRetry) == "undefined") {
        maxRetry = 10
    }

    while (true) {
        if (retryCounter > maxRetry) {
            LogControl("超过最大重试次数", maxRetry)
            return null
        }
        var ret = callFmzExtAPI(accessKey, secretKey, "GetRobotList", offset, length, robotStatusCode)
        if (!ret || ret["code"] != 0) {
            Sleep(1000)
            retryCounter++
            continue
        }

        var robots = ret["data"]["result"]["robots"]
        for (var i in robots) {
            if (robots[i].strategy_id != strategyId) {
                continue
            }
            arr.push(robots[i])
        }

        if (robots.length < length) {
            break
        }
        offset += length
    }

    return arr 
}

FMZの拡張APIの RestartRobot関数について

このシナリオは,最初の2つのシナリオがあります.

  • 1 仮想ディスクが作成されました 作成済みのディスクでは,自然にRestartRobot関数を使用してFMZの拡張APIインターフェイスパックを使用して再起動します.
  • 2 リアルディスクはまだ作成されていません 仮想ディスクの作成なしでは, 変形可能な仮想ディスクのパラメータは存在しない. 量産可能な仮想ディスクが実行される. このとき,FMZの拡張APIインターフェースの NewRobot 関数を使用する.

しかし,いずれにせよ,次の考えや行動は大きく異なっています.RestartRobotこの拡張API関数は例文として使用されます.

RestartRobot は,次の2つの方法で動作します.

  • 1, リアルディスクIDのみ転送, リアルディスクのパラメータ設定は転送しません. この方法では,実機が停止したときのパラメータ配置が変わらず,単に実機を再起動するだけです.
  • 2、実力盤IDを転送し,実力盤のパラメータ設定を転送します. この方法により,新しいパラメータ設定で起動する.

最初の方法は,私たちの需要シナリオにはあまり使えません. なぜなら,私たちの需要は大量にリアルディスクのパラメータを修正することです. だから問題は,リアルディスクのパラメータ配置は,取引所のオブジェクト配置,戦略パラメータ配置,K線周期設定など,非常に複雑です.

心配しないで,私たちは一つずつ調べます.

操作するディスク情報を取得する

FMZでは,実態ディスクのパラメータ配置を変更する場合,実態ディスクは非実行状態である必要があります. なぜなら,実行状態でない実態ディスクのみにパラメータ配置を変更できるからです.実行状態でない実態ディスクは次の状態にある可能性があります:

  • 戦略は停止した.
  • 策略が間違っています.停止します.

設定された戦略のリアルディスクを入手します.停止状態可能性は停止するエラーメディアは,

function main() {
    var stopRobotList = getAllRobotByIdAndStatus(accessKey, secretKey, strategyId, 4)
    var errorRobotList = getAllRobotByIdAndStatus(accessKey, secretKey, strategyId, 5)
    var robotList = stopRobotList.concat(errorRobotList)
}

詳細なディスクの設定を入手します. 詳細なディスクの設定を入手するには,

ディスクの設定パラメータを変更する

例えば,パラメータを修正する実区画の戦略は,次のとおりです (すなわち,戦略IDは,strategyId変数の戦略です):

img

img

この戦略には3つのパラメータがあり,実験として使用されます.

リアルディスクのポリシーのパラメータを変更する,しかし,おそらく我々はポリシーの交換設定を変更したくないが,拡張APIインターフェイスRestartRobot関数では,いずれもパラメータを指定しない (原始封筒はリアルディスクを起動するだけで動かない) またはすべてのパラメータの設定を指定しなければならない.

つまり,次に,RestartRobot関数でディスクを起動する前に,拡張APIインターフェイスGetRobotDetail関数でディスクの現在の設定にアクセスし,修正したいパラメータの一部を入れ,ディスクの起動 (つまりRestartRobotを呼び出すときに使用するパラメータ) の設定パラメータを再構成し,ディスクを再起動する必要があります.

ロボットリストをクリックして,次のコードで,現在のパラメータの設定を一つずつ取得します./**/書き込み部分には,実際のディスクの詳細が書かれていて,次にそのデータを処理する必要があります.

function main() {
    var stopRobotList = getAllRobotByIdAndStatus(accessKey, secretKey, strategyId, 4)
    var errorRobotList = getAllRobotByIdAndStatus(accessKey, secretKey, strategyId, 5)

    var robotList = stopRobotList.concat(errorRobotList)
    _.each(robotList, function(robotInfo) {
        var robotDetail = callFmzExtAPI(accessKey, secretKey, "GetRobotDetail", robotInfo.id)
        
        /*
        {
            "code": 0,
            "data": {
                "result": {
                    "robot": {
                        ...
                        "id": 130350,
                        ...
                        "name": "测试1B",
                        "node_id": 3022561,
                        ...
                        "robot_args": "[[\"pairs\",\"BTC_USDT,ETH_USDT,EOS_USDT,LTC_USDT\"],[\"col\",3],[\"htight\",300]]",
                        "start_time": "2023-11-19 21:16:12",
                        "status": 5,
                        "strategy_args": "[[\"pairs\",\"币种列表\",\"英文逗号间隔\",\"BTC_USDT,ETH_USDT,EOS_USDT,LTC_USDT\"],[\"col\",\"宽度\",\"页面总宽度为12\",6],[\"htight\",\"高度\",\"单位px\",600],[\"$$$__cmd__$$$coverSymbol\",\"平仓\",\"平仓交易对\",\"\"]]",
                        "strategy_exchange_pairs": "[3600,[186193],[\"BTC_USD\"]]",
                        "strategy_id": 131242,
                        "strategy_last_modified": "2023-12-09 23:14:33",
                        "strategy_name": "测试1",
                        ...
                    }
                },
                "error": null
            }
        }
        */

        // 解析交易所配置数据
        var exchangePairs = JSON.parse(robotDetail.data.result.robot.strategy_exchange_pairs)

        // 拿到交易所对象索引、交易对,这些设置是不打算修改的
        var arrExId = exchangePairs[1]
        var arrSymbol = exchangePairs[2]

        // 解析参数配置数据
        var params = JSON.parse(robotDetail.data.result.robot.robot_args)

        // 更新参数
        var dicParams = {
            "pairs" : "AAA_BBB,CCC_DDD",
            "col" : "999",
            "htight" : "666"
        }
        
        var newParams = []
        _.each(params, function(param) {
            for (var k in dicParams) {
                if (param[0] == k) {
                    newParams.push([k, dicParams[k]])  // 构造策略参数,更新上新参数值
                }
            }
        })
        
        // 注意如果数据中有空格需要转码,否则请求的时候会报错
        settings = {
            "name": robotDetail.data.result.robot.name,
            // 策略参数
            "args": newParams,         
            // 策略ID,可以用GetStrategyList方法获取到
            "strategy": robotDetail.data.result.robot.strategy_id,
            // K线周期参数,60即为60秒
            "period": exchangePairs[0],
            // 指定在哪个托管者上运行,不写该属性就是自动分配运行
            "node" : robotDetail.data.result.robot.node_id,
            "exchanges": []
        }
                                
        for (var i = 0 ; i < arrExId.length ; i++) {
            settings["exchanges"].push({"pid": arrExId[i], "pair": arrSymbol[i]})
        }
        Log(settings) // 测试
        var retRestart = callFmzExtAPI(accessKey, secretKey, "RestartRobot", robotInfo.id, settings)
        Log("retRestart:", retRestart)
    })
}

このプロパガンダを大量に修正する戦略を実行した後に,私の仮想ディスクは:

  • テスト1A
  • テスト1B

設定された取引所オブジェクト,取引ペア,K線周期が変わらない場合,パラメータを変更しました:

リアルディスクページでは,自動的に変更されます.

img

修正されたパラメータを指定したからです.

        // 更新参数
        var dicParams = {
            "pairs" : "AAA_BBB,CCC_DDD",
            "col" : "999",
            "htight" : "666"
        }

エンド

数十,数百の実盘の量変更参数に対して,この方法は比較的に便利である.この例では,統一参数に変更する.もちろん,あなたはコードの中で独自の変更規則をカスタマイズして,各実盘に異なる参数配置を指定したり,異なる取引所オブジェクト,取引対等を指定したりすることもできます.

FMZのプラットフォームでは,これらのニーズが柔軟にカスタマイズされ,どんなニーズが考えられているか,皆さんの意見は歓迎されます.


もっと

アレッズ数十,数百の実機,月租は,かなりお金です.

小さな夢FMZの拡張APIを使用したパッケージ製品がいくつかあり,多くの実用盤があります.