cluster.py 3.0 KB
Newer Older
haoranc's avatar
haoranc 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26
from ssl import ALERT_DESCRIPTION_CERTIFICATE_UNOBTAINABLE
import taos
import sys
import time
import os 
import  socket

from util.log import *
from util.sql import *
from util.cases import *
from util.dnodes import *
from util.common import *

class ClusterDnodes(TDDnodes):
    """rewrite TDDnodes and make MyDdnodes as TDDnodes child class"""
    def __init__(self ,dnodes_lists):

        super(ClusterDnodes,self).__init__()
        self.dnodes = dnodes_lists  # dnode must be TDDnode instance
        self.simDeployed = False
        self.testCluster = False
        self.valgrind = 0
        self.killValgrind = 1


class ConfigureyCluster:
haoranc's avatar
haoranc 已提交
27
    """This will create defined number of dnodes and create a cluster.
haoranc's avatar
haoranc 已提交
28 29
       at the same time, it will return TDDnodes list:  dnodes, """
    hostname= socket.gethostname()
haoranc's avatar
haoranc 已提交
30 31

    def __init__(self):
haoranc's avatar
haoranc 已提交
32 33
        self.dnodes = []      
        self.dnodeNums = 5
haoranc's avatar
haoranc 已提交
34
        self.independent = True
haoranc's avatar
haoranc 已提交
35
        self.startPort = 6030
haoranc's avatar
haoranc 已提交
36
        self.portStep = 100
haoranc's avatar
haoranc 已提交
37
        self.mnodeNums = 0
haoranc's avatar
haoranc 已提交
38

haoranc's avatar
haoranc 已提交
39 40
    def configure_cluster(self ,dnodeNums=5,mnodeNums=0,startPort=6030,portStep=100,hostname="%s"%hostname): 
        self.startPort=int(startPort)
haoranc's avatar
haoranc 已提交
41 42
        self.portStep=int(portStep)
        self.hostname=hostname
haoranc's avatar
haoranc 已提交
43 44
        self.dnodeNums = int(dnodeNums)
        self.mnodeNums = int(mnodeNums)
haoranc's avatar
haoranc 已提交
45
        self.dnodes = []
haoranc's avatar
haoranc 已提交
46 47
        startPort_sec = int(startPort+portStep)
        for num in range(1, (self.dnodeNums+1)):
haoranc's avatar
haoranc 已提交
48
            dnode = TDDnode(num)
haoranc's avatar
haoranc 已提交
49
            dnode.addExtraCfg("firstEp", f"{hostname}:{self.startPort}")
haoranc's avatar
haoranc 已提交
50
            dnode.addExtraCfg("fqdn", f"{hostname}")
haoranc's avatar
haoranc 已提交
51 52 53 54 55 56
            dnode.addExtraCfg("serverPort", f"{self.startPort + (num-1)*self.portStep}")
            dnode.addExtraCfg("secondEp", f"{hostname}:{startPort_sec}")

            # configure  dnoe of independent mnodes
            if num <= self.mnodeNums and self.mnodeNums != 0 :
                dnode.addExtraCfg("supportVnodes", 0)
haoranc's avatar
haoranc 已提交
57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
            # print(dnode)
            self.dnodes.append(dnode)
        return self.dnodes
        
    def create_dnode(self,conn):
        tdSql.init(conn.cursor())
        for dnode in self.dnodes[1:]:
            # print(dnode.cfgDict)
            dnode_id = dnode.cfgDict["fqdn"] +  ":" +dnode.cfgDict["serverPort"]
            tdSql.execute(" create dnode '%s';"%dnode_id)

        
        
    def check_dnode(self,conn):
        tdSql.init(conn.cursor())
        count=0
        while count < 5:
            tdSql.query("show dnodes")
            # tdLog.debug(tdSql.queryResult)
            status=0
haoranc's avatar
haoranc 已提交
77
            for i in range(self.dnodeNums):
haoranc's avatar
haoranc 已提交
78 79
                if tdSql.queryResult[i][4] == "ready":
                    status+=1
haoranc's avatar
haoranc 已提交
80
            # tdLog.debug(status)
haoranc's avatar
haoranc 已提交
81
            
haoranc's avatar
haoranc 已提交
82 83
            if status == self.dnodeNums:
                tdLog.debug(" create cluster with %d dnode and check cluster dnode all ready within 5s! " %self.dnodeNums)
haoranc's avatar
haoranc 已提交
84 85 86 87
                break 
            count+=1
            time.sleep(1)
        else:
haoranc's avatar
haoranc 已提交
88 89
            tdLog.exit("create cluster with %d dnode but  check dnode not ready within 5s ! "%self.dnodeNums)
            
haoranc's avatar
haoranc 已提交
90 91


haoranc's avatar
haoranc 已提交
92
cluster = ConfigureyCluster()