एफएमजेड पर आधारित क्वांटिफाइड ऑर्डर सिंक्रनाइज़ेशन मैनेजमेंट सिस्टम डिजाइन (2)

लेखक:छोटे सपने, बनाया गयाः 2022-02-16 12:11:36, अद्यतन किया गयाः 2023-09-15 20:46:46

img

एफएमजेड पर आधारित क्वांटिफाइड ऑर्डर सिंक्रनाइज़ेशन मैनेजमेंट सिस्टम डिजाइन (2)

सिंक्रोनोस सर्वर (Synchronous Server)

हम अपने पिछले लेख को जारी रखते हैंःएफएमजेड पर आधारित क्वांटिफाइड ऑर्डर सिंक्रनाइज़ेशन मैनेजमेंट सिस्टम डिजाइन (1)इस तरह की चर्चाओं के बाद, हम एक रणनीति तैयार करने के लिए शुरू कर रहे हैं।

इस तरह के डिजाइन प्रश्नों पर विचार करेंः

  • 1, यदि आप अस्थायी रूप से समन्वित नहीं करना चाहते हैं, तो क्या आप रोक सकते हैं. एक बार रोकने के बाद, विस्तार एपीआई से आरंभ करने और पासवर्ड सत्यापन का उपयोग करने पर प्रतिबंध लगा दिया जाता है. इस सुविधा को लागू करने के लिए, दो वैश्विक चर जोड़े गए हैंः

    var isStopFollow = false   // 用于标记当前是否跟单
    var reStartPwd = null      // 用于记录重启密码
    

    img

    इसके बाद नीति संपादक पृष्ठ पर एक इंटरैक्टिव नियंत्रण जोड़ा जाता है, जिसका उपयोग नीति को रोकने / फिर से शुरू करने के लिए किया जाता है ((यह वास्तविक डिस्क को बंद नहीं करता है, केवल तार्किक रोक है, कोई सूची नहीं है, कुछ भी नहीं किया गया है) । रोक के समय एक रोक पासवर्ड सेट किया जा सकता है, ताकि आपके पास एपीआई के लिए एक विस्तारित एपीआई कुंजी भी हो।订单同步管理系统类库(Single Server)डिस्क भी आपकी नीति को नहीं जगा सकती है. अनुवर्ती सूची को पुनः आरंभ करते समय, पूर्वनिर्धारित पासवर्ड दर्ज करें, अनुवर्ती फ़ंक्शन को जगाएं. संबंधित सुविधाओं के लिए कार्यान्वयन कोडः

    ...
              // 判断交互指令
              if (arr.length == 2) {
              	// 带控件的按钮
              	if (arr[0] == "stop/restart") {
              		// 暂停/重启跟单
              		if (!isStopFollow) {
              		    isStopFollow = true
              		    reStartPwd = arr[1]
              		    Log("已经停止跟单,", "设置的重启密码为:", reStartPwd, "#FF0000")
              		} else if (isStopFollow && arr[1] == reStartPwd) {
              			isStopFollow = false 
              			reStartPwd = null 
              			Log("已经重启跟单,", "清空重启密码。", "#FF0000")
              		} else if (isStopFollow && arr[1] != reStartPwd) {
              			Log("重启密码错误!")
              		}
              	}
              	continue 
              }
    
  • 2, आप सूची के नीचे की मात्रा निर्दिष्ट कर सकते हैं या आप गुणांक को बढ़ा सकते हैं नीति के लिए पैरामीटर जोड़ेंः

    img

    specifiedAmount: सूची की संख्या निर्दिष्ट करता है, डिफ़ॉल्ट रूप से -1, यानी निर्दिष्ट नहीं करता है. zoomAmountRatio: भेजे गए सिग्नल में निम्न मात्रा के आधार पर मापन, उदाहरण के लिए, भेजे गए सिग्नलःETH_USDT,swap,buy,1, तो इसमें से निचले एकल मात्रा के मूल्य को zoomAmountRatio से गुणा करें.

        var amount = specifiedAmount == -1 ? action.amount : specifiedAmount
        amount = zoomAmountRatio == -1 ? amount : amount * zoomAmountRatio
    

    यहाँ प्राप्त संकेतों में से एक की आवश्यकता के लिए अनुसूची की मात्रा को कम करने के लिए लागू किया गया हैस्केलिंगयाविशिष्ट मान निर्दिष्ट करें

  • 3. कोड को यथासंभव सरल बनाएं और अन्य टेम्पलेट लाइब्रेरी का उपयोग करके अपना आदेश संसाधित करें।

    लाइब्रेरी का उपयोग करेंःhttps://www.fmz.com/strategy/10989फ्यूचर्स के लिए उपयोग की जाने वाली कक्षाएंःhttps://www.fmz.com/strategy/203258

      function trade(action) {
          // 切换交易对,设置合约
          exchange.SetCurrency(action.symbol)
          if (action.ct != "spot") {
              exchange.SetContractType(action.ct)        
          }        
    
          var retTrade = null 
          var amount = specifiedAmount == -1 ? action.amount : specifiedAmount
          amount = zoomAmountRatio == -1 ? amount : amount * zoomAmountRatio    
    
          if (action.direction == "buy") {
              retTrade = action.ct == "spot" ? $.Buy(amount) : $.OpenLong(exchange, action.ct, amount)
          } else if (action.direction == "sell") {
              retTrade = action.ct == "spot" ? $.Sell(amount) : $.OpenShort(exchange, action.ct, amount)
          } else if (action.direction == "closebuy") {
              retTrade = action.ct == "spot" ? $.Sell(amount) : $.CoverLong(exchange, action.ct, amount)
          } else if (action.direction == "closesell") {
              retTrade = action.ct == "spot" ? $.Buy(amount) : $.CoverShort(exchange, action.ct, amount)
          }
          return retTrade
      }
    

    तो आप देख सकते हैं, नीचे दिए गए आदेश में केवल एक वाक्य हैः$.Sell(amount)$.Buy(amount)$.OpenLong(exchange, action.ct, amount)... और इसी तरह।

रणनीति कोडः

पहले订单同步管理系统(Synchronous Server)अस्थायी कोड इस प्रकार हैः

img

अब इसे फिर से डिजाइन करना शुरू करें।订单同步管理系统(Synchronous Server)

// 全局变量
var isStopFollow = false
var reStartPwd = null 

function trade(action) {
    // 切换交易对,设置合约
    exchange.SetCurrency(action.symbol)
    if (action.ct != "spot") {
        exchange.SetContractType(action.ct)        
    }    

    var retTrade = null 
    var amount = specifiedAmount == -1 ? action.amount : specifiedAmount
    amount = zoomAmountRatio == -1 ? amount : amount * zoomAmountRatio

    if (action.direction == "buy") {
        retTrade = action.ct == "spot" ? $.Buy(amount) : $.OpenLong(exchange, action.ct, amount)
    } else if (action.direction == "sell") {
    	retTrade = action.ct == "spot" ? $.Sell(amount) : $.OpenShort(exchange, action.ct, amount)
    } else if (action.direction == "closebuy") {
    	retTrade = action.ct == "spot" ? $.Sell(amount) : $.CoverLong(exchange, action.ct, amount)
    } else if (action.direction == "closesell") {
    	retTrade = action.ct == "spot" ? $.Buy(amount) : $.CoverShort(exchange, action.ct, amount)
    }
    return retTrade
}

function parseCmd(cmd) {
	var objAction = {}
	// 解析cmd ,例如:ETH_USDT,swap,buy,1
    var arr = cmd.split(",")
    if (arr.length != 4) {
    	return null 
    }
    objAction.symbol = arr[0]
    objAction.ct = arr[1]
    objAction.direction = arr[2]
    objAction.amount = arr[3]
    return objAction
}

function main() {
	// 清除所有日志
    LogReset(1)  

    if (isSimulateOKEX) {
    	exchange.IO("simulate", true)
    	Log("切换到OKEX模拟盘!")
    }

    // 设置精度
    exchange.SetPrecision(pricePrecision, amountPrecision)

    // 检查缩放、指定不能同时设置
    if (specifiedAmount != -1 && zoomAmountRatio != -1) {
    	throw "不能同时指定同步量和缩放量"
    }

    while (true) {
        var cmd = GetCommand()
        if (cmd) {
            Log("cmd: ", cmd)
            var arr = cmd.split(":")

            // 判断交互指令
            if (arr.length == 2) {
            	// 带控件的按钮
            	if (arr[0] == "stop/restart") {
            		// 暂停/重启跟单
            		if (!isStopFollow) {
            		    isStopFollow = true
            		    reStartPwd = arr[1]
            		    Log("已经停止跟单,", "设置的重启密码为:", reStartPwd, "#FF0000")
            		} else if (isStopFollow && arr[1] == reStartPwd) {
            			isStopFollow = false 
            			reStartPwd = null 
            			Log("已经重启跟单,", "清空重启密码。", "#FF0000")
            		} else if (isStopFollow && arr[1] != reStartPwd) {
            			Log("重启密码错误!")
            		}
            	}
            	continue 
            }
            
            // 允许跟单
            if (!isStopFollow) {
                // 解析跟单信号交互指令
                var objAction = parseCmd(cmd)
                if (objAction) {
            	    // 解析正确
            	    var ret = trade(objAction)
                } else {
                	Log("错误的信号指令 cmd:", cmd)
                }
            }
        }
        
        // 显示跟单情况
        LogStatus(_D(), isStopFollow ? "停止同步" : "保持同步", "\n")

        Sleep(1000)
    }
}

परीक्षण

इस बार बैंड खाता बिनेंस डिस्क परीक्षण का उपयोग करता है, और बैंड का परीक्षण ओकेएक्स खाते का उपयोग करता है.订单同步管理系统类库(Single Server)टेम्पलेट मेंmainफ़ंक्शन) ।

img

लेकिन हम लेन-देन की दिशा को शून्य में बदलते हैं, और लेनदेन की मात्रा 0.003 में बदल जाती है ((बिनान USDT स्थानिक अनुबंध को अंश संख्या में ऑर्डर किया जा सकता है) । लेकिन ओकेएक्स खाते का खाता पूर्णांक होना चाहिए ((ओकेएक्स एक्सचेंज का खाता पूर्णांक होना चाहिए) इसलिए पैरामीटर मैं रणनीति पैरामीटर निर्दिष्ट करता हूंspecifiedAmountएक के लिए ∞

img

订单同步管理系统类库(Single Server)एक परीक्षण फ़ंक्शन की वास्तविक डिस्क लेनदेन को ट्रिगर करती है।

img

एक वास्तविक डिस्क नीति को एक संकेत प्राप्त होता है और एक अनुवर्ती क्रिया करता हैः

img

इस तरह के आदेशों को जारी करने के लिए, एक्सचेंजों ने आदेश जारी किए।

img

इसके बाद, परीक्षण मुख्य में निचले पंक्ति की दिशा को 0.003 रिक्त स्थान को समतल करने के लिए समतल स्थिति का परीक्षण करें।

img

फिर फिर से इस वास्तविक डिस्क को चलाएं जो बैंड के लिए जिम्मेदार है)))订单同步管理系统类库(Single Server))。

img

एक ही डिस्क के साथ एक ही ऑपरेशन को ट्रिगर करेंः

img

इस रणनीति का पताःऑर्डर सिंक्रनाइज़ेशन मैनेजमेंट सिस्टम क्लासरूम (Single Server) सिंक्रोनोस सर्वर (Synchronous Server)

रणनीतिक डिजाइन केवल आदान-प्रदान सीखने के लिए है, वास्तविक उत्पादन को स्वयं को संशोधित करने, समायोजित करने और अनुकूलित करने की आवश्यकता है।


संबंधित

अधिक