當前位置: 首頁>>代碼示例>>Python>>正文


Python CsRoute.add_table方法代碼示例

本文整理匯總了Python中CsRoute.CsRoute.add_table方法的典型用法代碼示例。如果您正苦於以下問題:Python CsRoute.add_table方法的具體用法?Python CsRoute.add_table怎麽用?Python CsRoute.add_table使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在CsRoute.CsRoute的用法示例。


在下文中一共展示了CsRoute.add_table方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: post_config_change

# 需要導入模塊: from CsRoute import CsRoute [as 別名]
# 或者: from CsRoute.CsRoute import add_table [as 別名]
    def post_config_change(self, method):
        route = CsRoute()
        if method == "add":
            route.add_table(self.dev)
            route.add_route(self.dev, str(self.address["network"]))
        elif method == "delete":
            logging.warn("delete route not implemented")

        self.fw_router()
        self.fw_vpcrouter()

        # On deletion nw_type will no longer be known
        if self.get_type() in ["guest"] and self.config.is_vpc():

            CsDevice(self.dev, self.config).configure_rp()

            logging.error(
                "Not able to setup source-nat for a regular router yet")
            dns = CsDnsmasq(self)
            dns.add_firewall_rules()
            app = CsApache(self)
            app.setup()

        cmdline = self.config.cmdline()
        # If redundant then this is dealt with by the master backup functions
        if self.get_type() in ["guest"] and not cmdline.is_redundant():
            pwdsvc = CsPasswdSvc(self.address['public_ip']).start()

        if self.get_type() == "public" and self.config.is_vpc():
            if self.address["source_nat"]:
                vpccidr = cmdline.get_vpccidr()
                self.fw.append(
                    ["filter", "", "-A FORWARD -s %s ! -d %s -j ACCEPT" % (vpccidr, vpccidr)])
                self.fw.append(
                    ["nat", "", "-A POSTROUTING -j SNAT -o %s --to-source %s" % (self.dev, self.address['public_ip'])])
開發者ID:jannyg,項目名稱:cloudstack,代碼行數:37,代碼來源:CsAddress.py

示例2: post_configure

# 需要導入模塊: from CsRoute import CsRoute [as 別名]
# 或者: from CsRoute.CsRoute import add_table [as 別名]
    def post_configure(self, address):
        """ The steps that must be done after a device is configured """
        route = CsRoute()
        if not self.get_type() in ["control"]:
            route.add_table(self.dev)
            
            CsRule(self.dev).addMark()
            self.check_is_up()
            self.set_mark()
            self.arpPing()
            
            CsRpsrfs(self.dev).enable()
            self.post_config_change("add")

        '''For isolated/redundant and dhcpsrvr routers, call this method after the post_config is complete '''
        if not self.config.is_vpc():
            self.setup_router_control()
        
        if self.config.is_vpc() or self.cl.is_redundant():
            # The code looks redundant here, but we actually have to cater for routers and
            # VPC routers in a different manner. Please do not remove this block otherwise
            # The VPC default route will be broken.
            if self.get_type() in ["public"]:
                gateway = str(address["gateway"])
                route.add_defaultroute(gateway)
        else:
            # once we start processing public ip's we need to verify there
            # is a default route and add if needed
            if(self.cl.get_gateway()):
                route.add_defaultroute(self.cl.get_gateway())
開發者ID:jannyg,項目名稱:cloudstack,代碼行數:32,代碼來源:CsAddress.py

示例3: post_configure

# 需要導入模塊: from CsRoute import CsRoute [as 別名]
# 或者: from CsRoute.CsRoute import add_table [as 別名]
 def post_configure(self):
     """ The steps that must be done after a device is configured """
     if not self.get_type() in ["control"]:
         route = CsRoute()
         route.add_table(self.dev)
         CsRule(self.dev).addMark()
         self.check_is_up()
         self.set_mark()
         self.arpPing()
         CsRpsrfs(self.dev).enable()
         self.post_config_change("add")
開發者ID:maneesha-p,項目名稱:cloudstack,代碼行數:13,代碼來源:CsAddress.py

示例4: post_configure

# 需要導入模塊: from CsRoute import CsRoute [as 別名]
# 或者: from CsRoute.CsRoute import add_table [as 別名]
    def post_configure(self):
        """ The steps that must be done after a device is configured """
        if not self.get_type() in ["control"]:
            route = CsRoute()
            route.add_table(self.dev)
            CsRule(self.dev).addMark()
            self.check_is_up()
            self.set_mark()
            self.arpPing()
            CsRpsrfs(self.dev).enable()
            self.post_config_change("add")

        '''For isolated/redundant and dhcpsrvr routers, call this method after the post_config is complete '''
        if not self.config.is_vpc():
            self.setup_router_control()
開發者ID:scottwx,項目名稱:cloudstack,代碼行數:17,代碼來源:CsAddress.py

示例5: post_config_change

# 需要導入模塊: from CsRoute import CsRoute [as 別名]
# 或者: from CsRoute.CsRoute import add_table [as 別名]
    def post_config_change(self, method):
        route = CsRoute()
        if method == "add":
            route.add_table(self.dev)
            route.add_route(self.dev, str(self.address["network"]))
        elif method == "delete":
            logging.warn("delete route not implemented")

        self.fw_router()
        self.fw_vpcrouter()

        # On deletion nw_type will no longer be known
        if self.get_type() in ["guest"] and self.config.is_vpc():

            CsDevice(self.dev, self.config).configure_rp()

            logging.error("Not able to setup source-nat for a regular router yet")
            dns = CsDnsmasq(self)
            dns.add_firewall_rules()
            app = CsApache(self)
            app.setup()

        cmdline = self.config.cmdline()
        # Start passwd server on non-redundant routers and on the master router of redundant pairs
        # CsRedundant will handle fail-over.
        if self.get_type() in ["guest"] and (not self.cl.is_redundant() or self.cl.is_master()):
            CsPasswdSvc(self.address["public_ip"]).start()
        elif self.get_type() in ["guest"]:
            # Or else make sure it's stopped
            CsPasswdSvc(self.address["public_ip"]).stop()

        if self.get_type() == "public" and self.config.is_vpc():
            if self.address["source_nat"]:
                vpccidr = cmdline.get_vpccidr()
                self.fw.append(["filter", "", "-A FORWARD -s %s ! -d %s -j ACCEPT" % (vpccidr, vpccidr)])
                self.fw.append(
                    ["nat", "", "-A POSTROUTING -j SNAT -o %s --to-source %s" % (self.dev, self.address["public_ip"])]
                )
開發者ID:MissionCriticalCloudOldRepos,項目名稱:cosmic-core,代碼行數:40,代碼來源:CsAddress.py


注:本文中的CsRoute.CsRoute.add_table方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。