Example #1
0
    def response(self):
        '''edit
        '''
        node_type = data = download_link = ""

        normalized_path = normalize_path(self.path)
        znode = ZdZnode.one(path=normalized_path, cluster_name=self.cluster_name, deleted='0')
        if znode:
            node_type = znode.type

        # "0"代表普通节点, "1"代表文本节点
        if node_type == "1":
            # 文件节点提供下载路径
            download_link = "/config/znode/download?path={0}&cluster_name={1}".format(
                self.path, self.cluster_name)

        else:
            data = ZookeeperService.get(self.cluster_name, self.path)

        return self.render('config/znode/edit.html',
                           action='/config/znode/save',
                           cluster_name=self.cluster_name,
                           path=normalized_path,
                           data=data,
                           download_link=download_link)
Example #2
0
    def response(self):
        '''edit
        '''
        node_type = data = download_link = ""

        normalized_path = normalize_path(self.path)
        znode = ZdZnode.one(path=normalized_path,
                            cluster_name=self.cluster_name,
                            deleted='0')
        business = ""
        if znode:
            node_type = znode.type
            business = znode.business

        # "0"代表普通节点, "1"代表文本节点
        if node_type == "1":
            # 文件节点提供下载路径
            download_link = "/config/znode/download?path={0}&cluster_name={1}".format(
                self.path, self.cluster_name)

        else:
            data = ZookeeperService.get(self.cluster_name, self.path)

        return self.render('config/znode/edit.html',
                           action='/config/znode/save',
                           cluster_name=self.cluster_name,
                           path=normalized_path,
                           data=data,
                           business=business,
                           download_link=download_link)
Example #3
0
    def response(self):
        """返回指定zookeeper集群的znode信息, 响应ajax请求
        """
        nodes = []
        normalized_path = normalize_path(self.path)

        if USE_QCONF:
            ZnodeService.get_znode_tree_from_qconf(self.cluster_name,
                                                   normalized_path, nodes)
        else:
            zoo_client = ZookeeperService.get_zoo_client(self.cluster_name)
            if not zoo_client:
                return self.ajax_popup(code=300, msg="连接zookeeper出错!")
            ZnodeService.get_znode_tree(zoo_client, normalized_path, nodes)

        if normalized_path != "/" and len(nodes) <= 1:
            return self.ajax_popup(code=300,
                                   msg="对不起,该节点路径下(%s)无数据!" % self.path)

        for node in nodes:
            zk_node = ZdZnode.one(path=node["path"],
                                  cluster_name=self.cluster_name)
            if zk_node:
                node['type'] = zk_node.type
                node['business'] = zk_node.business
                node['data'] = ZookeeperService.get(self.cluster_name,
                                                    node["path"])

        znodes_data = json.dumps(nodes)
        return self.render('config/znode/displaytree.html',
                           cluster_name=self.cluster_name,
                           znodes_data=znodes_data)
Example #4
0
    def response(self):
        """返回指定zookeeper集群的znode信息, 响应ajax请求
        """
        nodes = []
        normalized_path = normalize_path(self.path)

        if USE_QCONF:
            ZnodeService.get_znode_tree_from_qconf(self.cluster_name, normalized_path, nodes)
        else:
            zoo_client = ZookeeperService.get_zoo_client(self.cluster_name)
            if not zoo_client:
                return self.ajax_popup(code=300, msg="连接zookeeper出错!")
            ZnodeService.get_znode_tree(zoo_client, normalized_path, nodes)

        if normalized_path != "/" and len(nodes) <= 1:
            return self.ajax_popup(code=300, msg="对不起,该节点路径下(%s)无数据!" % self.path)

        for node in nodes:
            zk_node = ZdZnode.one(path=node["path"], cluster_name=self.cluster_name)
            if zk_node:
                node['type'] = zk_node.type
                node['business'] = zk_node.business
                node['data'] = ZookeeperService.get(self.cluster_name, node["path"])

        znodes_data = json.dumps(nodes)
        return self.render('config/znode/displaytree.html',
                           cluster_name=self.cluster_name,
                           znodes_data=znodes_data)
Example #5
0
    def response(self):
        """返回指定zookeeper集群的znode信息, 响应ajax请求
        """
        nodes = []
        normalized_path = normalize_path(self.path)

        zoo_client = ZookeeperService.get_zoo_client(self.cluster_name)
        if not zoo_client:
            return self.ajax_popup(code=300, msg="连接zookeeper出错!")
        ZnodeService.get_znode_tree(zoo_client, normalized_path, nodes)

        #if normalized_path != "/" and len(nodes) <= 1:
        #    return self.ajax_popup(
        #        code=300, msg="对不起,该节点路径下(%s)无数据!" % self.path)

        for node in nodes:
            zk_node = ZdZnode.one(path=node["path"],
                                  cluster_name=self.cluster_name)
            if zk_node:
                node['description'] = zk_node.description
                node['data'] = ZookeeperService.get(self.cluster_name,
                                                    node["path"])

        znodes_data = json.dumps(nodes)
        return self.render('config/znode/displaytree.html',
                           cluster_name=self.cluster_name,
                           service_name=self.service_name,
                           znodes_data=znodes_data)
Example #6
0
    def response(self):
        '''edit
        '''
        node_type = data = download_link = ""

        normalized_path = normalize_path(self.path)
        znode = ZdZnode.one(path=normalized_path,
                            cluster_name=self.cluster_name,
                            deleted='0')
        description = ""
        if znode:
            #node_type = znode.type
            description = znode.description

        # "0"代表普通节点, "1"代表文本节点
        #if node_type == "1":
        #    # 文件节点提供下载路径
        #    download_link = "/config/znode/download?path={0}&cluster_name={1}".format(
        #        self.path, self.cluster_name)

        #else:
        #    data = ZookeeperService.get(self.cluster_name, self.path)

        data = ZookeeperService.get(self.cluster_name, self.path)
        return self.render('config/znode/edit.html',
                           action='/config/znode/save',
                           cluster_name=self.cluster_name,
                           path=normalized_path,
                           data=data,
                           description=description,
                           download_link=download_link)
Example #7
0
    def response(self):
        """edit
        """
        node_type = data = download_link = ""

        normalized_path = normalize_path(self.path)
        znode = ZdZnode.one(path=normalized_path, cluster_name=self.cluster_name, deleted="0")
        business = ""
        if znode:
            node_type = znode.type
            business = znode.business

        # "0"代表普通节点, "1"代表文本节点
        if node_type == "1":
            # 文件节点提供下载路径
            download_link = "/config/znode/download?path={0}&cluster_name={1}".format(self.path, self.cluster_name)

        else:
            data = ZookeeperService.get(self.cluster_name, self.path)

        return self.render(
            "config/znode/edit.html",
            action="/config/znode/save",
            cluster_name=self.cluster_name,
            path=normalized_path,
            data=data,
            business=business,
            download_link=download_link,
        )
Example #8
0
    def response(self):
        """返回指定zookeeper集群的znode信息
        """
        normalized_path = normalize_path(self.path)
        nodes = SnapshotService.get_snapshot_tree(self.cluster_name, normalized_path)
        if not nodes:
            return self.ajax_popup(code=300, msg="对不起,该节点路径下(%s)无快照数据!" % self.path)

        znodes_data = json.dumps(nodes)
        return self.render("config/snapshot/displaytree.html", cluster_name=self.cluster_name, znodes_data=znodes_data)
Example #9
0
    def response(self):
        """返回指定zookeeper集群的znode信息
        """
        normalized_path = normalize_path(self.path)
        nodes = SnapshotService.get_snapshot_tree(self.cluster_name,
                                                  normalized_path)
        if not nodes:
            return self.ajax_popup(code=300,
                                   msg="对不起,该节点路径下(%s)无快照数据!" % self.path)

        znodes_data = json.dumps(nodes)
        return self.render('config/snapshot/displaytree.html',
                           cluster_name=self.cluster_name,
                           znodes_data=znodes_data)
Example #10
0
  def __load_root(self) -> None:
    """Loads all files in the root folder."""
    # loop through all files and load them as separate pages
    for root, _, files in os.walk(self.__root):
      for fileName in files:
        filePath = normalize_path(os.path.join(root, fileName))
        newPage = Page(fileName)

        if self.__linkMgr is not None:
          pageLinks = self.__linkMgr.get_links_for(fileName)
          newPage.add_links(pageLinks)

        self.__read_file(filePath, newPage)
        self.__pages.add(newPage)
Example #11
0
def set_znode(cluster_name, path, data, znode_type='0', business=''):
    """更新或增加znode节点,包括存储于mysql的元数据和存储于zookeeper上的data
    """
    path = normalize_path(path)

    ZookeeperService.set_or_create(cluster_name, path, data)

    # 在mysql上存储znode的相关元数据,节点类型和业务说明
    znode = ZdZnode.one(cluster_name=cluster_name, path=path, deleted="0")
    if znode is None:
        znode = ZdZnode(cluster_name=cluster_name, path=path)
    znode.type = znode_type
    znode.business = business
    znode.save()

    try:
        # 自动快照(如果配置信息没有变更,实际不会进行快照)
        SnapshotService.make_snapshot(cluster_name, path, data)
    except MakeSnapshotError as exc:
        log.error('make snapshot error: %s', str(exc))
Example #12
0
def set_znode(cluster_name, path, data, znode_type='0', business=''):
    """更新或增加znode节点,包括存储于mysql的元数据和存储于zookeeper上的data
    """
    path = normalize_path(path)

    ZookeeperService.set_or_create(cluster_name, path, data)

    # 在mysql上存储znode的相关元数据,节点类型和业务说明
    znode = ZdZnode.one(cluster_name=cluster_name, path=path, deleted="0")
    if znode is None:
        znode = ZdZnode(cluster_name=cluster_name, path=path)
    znode.type = znode_type
    znode.business = business
    znode.save()

    try:
        # 自动快照(如果配置信息没有变更,实际不会进行快照)
        SnapshotService.make_snapshot(cluster_name, path, data)
    except MakeSnapshotError as exc:
        log.error('make snapshot error: %s', str(exc))
Example #13
0
    def response(self):
        '''savecopy
        '''
        # node_name中不可包含`/`特殊字符
        if self.path and not ZnodeService.is_node_name_ok(self.path):
            return self.ajax_popup(code=300, msg="节点名不允许包含特殊字符'/'!")

        zk_path = ""
        if not self.path:
            # 新增节点需要进行存在检验
            return self.ajax_popup(code=300, msg="节点名称不能为空!")
        else:
            zk_path = os.path.join(self.parent_path, self.path)
            if ZookeeperService.exists(self.cluster_name, zk_path):
                return self.ajax_popup(code=300, msg="节点已经存在!")

        normalized_path = normalize_path(self.old_path)
        nodes = []

        if USE_QCONF:
            ZnodeService.get_znode_tree_from_qconf(self.cluster_name, normalized_path, nodes)
        else:
            zoo_client = ZookeeperService.get_zoo_client(self.cluster_name)
            if not zoo_client:
                return self.ajax_popup(code=300, msg="连接zookeeper出错!")
            ZnodeService.get_znode_tree(zoo_client, normalized_path, nodes)

        path = full_path(self.path,self.parent_path)
        #ZnodeService.save_znode_tree(self.cluster_name , normalized_path , path)

        index = self.old_path.rfind('/')
        old_node_name = self.old_path[index+1:]

        for node in nodes:
            new_path = node['path'].replace(old_node_name,self.path,1)
            ZnodeService.save_znode_tree(self.cluster_name , node['path'] ,new_path)
        #ret = ZnodeService.save_znode_tree(self.cluster_name ,self.parent_path,self.old_path,self.path)

        #if not ret:
        #    return self.ajax_popup(code=300,msg='添加失败')
        return self.ajax_ok(close_current=True)
Example #14
0
 def __load_root(self) -> None:
   for root, _, files in os.walk(self.__root):
     for fileName in files:
       filePath = normalize_path(os.path.join(root, fileName))
       fileContents = self.__read_file(filePath)
       self.__linkMap[fileName] = fileContents