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


Python Misc.die方法代碼示例

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


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

示例1: main

# 需要導入模塊: from misc import Misc [as 別名]
# 或者: from misc.Misc import die [as 別名]
def main():
    killer = Killer()

    args = _parse_argv()

    logger = get_logger("DNSWatch", log_level=args.loglevel, log_file=args.logfile)
    logger.info("Starting dnswatch v.{}.".format(__version__))

    misc = Misc(logger)

    try: 
        exit_code = 2

        if not get_lock("dnswatch", timeout=5):
            misc.die("Lock exists")

        c = Config()
        action = None
        while True:
            config = c.read(args.config)
            dw = DNSWatch(config)

            if action == 'reload':
                dw.reload_config()
            else:
                dw.initial_config()
            
            try: 
                action = dw.watch(pause=config["watch"]["pause"])
            except: 
                action = dw.watch()

            if action == "kill":
                # Do DNS cleanup and exit loop
                dw.cleanup()
                break
            elif action == "softkill":
                # Exit loop without DNS cleanup
                break
            elif action == "reload":
                # Do nothing
                pass
            else:
                misc.die("Unknown action requested: {}".format(action))

        logger.info("Finished successfully.")
        exit_code = 0
    except SystemExit:
        exit_code = sys.exc_info()[1]
    except:
        logger.error("Exiting with errors.")
        if args.trace:
            print(sys.exc_info())
            trace = sys.exc_info()[2]
            traceback.print_tb(trace)
            exit_code = 1
    finally:
        sys.exit(exit_code)
開發者ID:nixargh,項目名稱:dnswatch,代碼行數:60,代碼來源:main.py

示例2: __init__

# 需要導入模塊: from misc import Misc [as 別名]
# 或者: from misc.Misc import die [as 別名]
class DHClient:

    def __init__(self):
        self.logger = logging.getLogger("DNSWatch.DHClient")
        self.misc = Misc(self.logger)
        self.args = self._collect_args()
        self.config_files = ["/etc/dhcp/dhclient.conf"]
        self.config_updated = False

    def _collect_args(self):
        self.logger.debug("Looking for dhclient process arguments.")

        default_cmdline = ['dhclient',
                '-1',
                '-v',
                '-pf',
                '/run/dhclient.eth0.pid',
                '-lf',
                '/var/lib/dhcp/dhclient.eth0.leases',
                'eth0']
        for proc in psutil.process_iter():
            if re.match("^dhclient\d*$", proc.name):
                self.logger.debug("dhclient cmdline: '{}'.".format(
                                    " ".join(proc.cmdline)))
                return proc.cmdline

        self.logger.warning(
            "dhclient process not found. Falling back to default: '{}'.".format(
                " ".join(default_cmdline)))
        self._request_lease(default_cmdline)
        return default_cmdline

    def set_nameserver(self, ns):
        self.logger.debug("Setting nameserver: {}.".format(ns))
        if not self._set_option("supersede", "domain-name-servers", ", ".join(ns)):
            self.misc.die("Failed to set nameserver for dhclient")

    def get_nameserver(self):
        self.logger.debug("Getting nameserver from dhclient config.")
        return self._get_option("domain-name-servers", otype="supersede")[2]

    def set_search(self, domain):
        self.logger.debug("Setting search domain: {}.".format(domain))
        if not self._set_option("prepend", "domain-name", '"{} "'.format(" ".join(domain))):
            self.misc.die("Failed to set search domain for dhclient")

    def renew_lease(self):
        self._release_lease(self.args)
        self._request_lease(self.args)
        self.config_updated = False

    def _release_lease(self, args_list):
        self.logger.debug("Releasing DHCP lease.")
        args = list(args_list)
        args.append("-r")
        FNULL = open(os.devnull, 'w')
        # If close_fds is true, all file descriptors except 0, 1 and 2 will be
        # closed before the child process is executed. (Unix only).
        check_call(args, stdout=FNULL, stderr=STDOUT, close_fds=True)

    def _request_lease(self, args_list):
        self.logger.debug("Requesting DHCP lease.")
        FNULL = open(os.devnull, 'w')
        # If close_fds is true, all file descriptors except 0, 1 and 2 will be
        # closed before the child process is executed. (Unix only).
        #
        # Here it's a must because in other case dhclient will inherit lock
        # file/socket. Which will prevent future starts.
        check_call(args_list, stdout=FNULL, stderr=STDOUT, close_fds=True)

    def _set_option(self, otype, option, value):
        if not otype in ["append", "prepend", "supersede"]:
            self.misc.die("Unknown dhclient option type: {}".format(otype))

        new_line = "{} {} {};".format(otype, option, value)
        new_config = list()
        option_exist = False
        write_config = False

        config_file = self._get_config_file()
        config = self._read_config(config_file)
        for line in config:
            if re.match("^{}\s+{}\s+.*;$".format(otype, option), line):
                option_exist = True
                self.logger.debug("Option '{}' exist, checking value.".format(option))
                if re.match("^{}\s+{}\s+{};$".format(otype, option, value), line):
                    self.logger.debug("Value '{}' is the same, skipping.".format(value))
                    new_config.append(line)
                else:
                    self.logger.debug("Values differ, updating to '{}'.".format(value))
                    write_config = True
                    new_config.append(new_line)
                    continue
            new_config.append(line)

        if not option_exist:
            write_config = True
            new_config.append(new_line)

        if write_config:
#.........這裏部分代碼省略.........
開發者ID:nixargh,項目名稱:dnswatch,代碼行數:103,代碼來源:dhclient.py

示例3: __init__

# 需要導入模塊: from misc import Misc [as 別名]
# 或者: from misc.Misc import die [as 別名]
class BindProvider:

    def __init__(self, config):
        self.logger = logging.getLogger("DNSWatch.BindProvider")
        self.misc = Misc(self.logger)
        self.dhcl = DHClient()
        self.dnso = DNSOps(config["dnsupdate"])

        self.zone = config["dnsupdate"]["zone"]
        self.fqdn = config["host"]["fqdn"]
        self.private_ip = config["host"]["private_ip"]
        self.public_ip = config["host"]["public_ip"]
        self.alias_dict = config["dnsupdate"]["alias"]
        self.aliases = None

    def initial_config(self):
        """To do on start"""
        self._initial_config_wo_resolvers()

        if len(self.slaves["private"]) > 0:
            self._setup_resolver(
                self.slaves["private"], [self.zone])
        else:
            self.misc.die("No private DNS slaves found: {}.".format(self.slaves))

    def reload_config(self):
        """To do on reload"""
        self._initial_config_wo_resolvers()

    def _initial_config_wo_resolvers(self):
        self.dnso.setup_key()

        self.masters = self.dnso.get_masters()
        self.aliases = Provider()._look_for_alias(self.fqdn, self.zone, self.alias_dict)

        if not self._update_records(self.masters['private'], self.private_ip, ptr=True):
            self.misc.die("DNS update of PRIVATE view failed on all masters: {}".format(self.masters['private']))
        if not self._update_records(self.masters['public'],self.public_ip, ptr=False):
            self.misc.die("DNS update of PUBLIC view failed on all masters: {}".format(self.masters['public']))

        self.slaves = self.dnso.get_slaves(self.masters)

    def watch(self):
        """Some periodic actions"""
    	# Check if masters changed
        new_masters = self.dnso.get_masters()
        if (self._list_changed(self.masters["private"], new_masters["private"])
            or self._list_changed(self.masters["public"], new_masters["public"])):
            self.logger.warning("Masters list changed.")
            self.initial_config()
        else:
            # Check if slaves list was changed
            new_slaves = self.dnso.get_slaves(self.masters)
            if len(new_slaves["private"]) > 0:
                old_slaves = self.dhcl.get_nameserver()
                if self._list_changed(old_slaves, new_slaves["private"]):
                    self.logger.warning("Slaves list changed.")
                    self.slaves = dict(new_slaves)
                    self._setup_resolver(self.slaves["private"], [self.zone])
            else:
                self.logger.error("No private DNS slaves found: {}.".format(new_slaves))

    def cleanup(self):
        """To do on shutdown"""
        # Delete aliases if any
        if self.aliases:
            for alias in self.aliases:
                self.dnso.delete_alias(self.masters["private"][0], alias, self.fqdn)
                self.dnso.delete_alias(self.masters["public"][0], alias, self.fqdn)

        # Delete hosts' records
        self.dnso.delete_host(
            self.masters["private"][0], self.fqdn, self.private_ip, ptr=True)
        self.dnso.delete_host(
            self.masters["public"][0], self.fqdn, self.public_ip)

    def _update_records(self, masters, ip, ptr):
        """Try update on any master"""
        for master in masters:
            self.logger.debug("Trying update at master: {}.".format(master))
            try:
                self.dnso.update_host(master, self.fqdn, ip, ptr=ptr)

                # Add aliases if any
                if self.aliases:
                    for alias in self.aliases:
                        self.dnso.update_alias(master, alias, self.fqdn)
                return True
            except:
                continue
        return False

    def _setup_resolver(self, servers, domain):
        self.logger.info(
            "Configuring local resolver with: NS={}; domain={}.".format(
                servers, domain))
        self.dhcl.set_nameserver(servers)
        self.dhcl.set_search(domain)
        if self.dhcl.config_updated:
            self.dhcl.renew_lease()
#.........這裏部分代碼省略.........
開發者ID:nixargh,項目名稱:dnswatch,代碼行數:103,代碼來源:dnsproviders.py

示例4: __init__

# 需要導入模塊: from misc import Misc [as 別名]
# 或者: from misc.Misc import die [as 別名]
class Route53:

    def __init__(self, config, sync=True):
        self.logger = logging.getLogger("DNSWatch.Route53")
        self.misc = Misc(self.logger)
        self.config = config
        self.sync = sync
        self.unchecked_requests = list()
        self.client = boto3.client(
                        "route53",
                        aws_access_key_id=config["update_key"]["name"],
                        aws_secret_access_key=config["update_key"]["key"])

    def update_host(self, host, ip, ptr=False):
        result = True
        return result

    def get_zones(self):
        self.logger.debug("Getting hosted DNS zones.")
        zones = dict()
        response = self.client.list_hosted_zones()

        if not response["IsTruncated"]:
            zones_info = response["HostedZones"]
        else:
            self.misc.die(("Truncated aswers are not supported yet"))

        for zone in zones_info:
            zone_id = self._extract_id(zone["Id"])
            zones[zone_id] = {
                "Name": zone["Name"],
                "Private": zone["Config"]["PrivateZone"]
            }
        return zones

    def add_host(self, zone_id, hostname, ip, ptr=False):
        self._operate_record("create", zone_id, hostname, "A", ip)

    def delete_host(self, zone_id, hostname, ip, ptr=False):
        self._operate_record("delete", zone_id, hostname, "A", ip)

    def update_host(self, zone_id, hostname, ip, ptr=False):
        self._operate_record("upsert", zone_id, hostname, "A", ip)

    def add_ptr(self, zone_id, ptr_name, hostname):
        self._operate_record("create", zone_id, ptr_name, "PTR", self._ensure_fqdn(hostname))

    def delete_ptr(self, zone_id, ptr_name, hostname):
        self._operate_record("delete", zone_id, ptr_name, "PTR", self._ensure_fqdn(hostname))

    def update_ptr(self, zone_id, ptr_name, hostname):
        self._operate_record("upsert", zone_id, ptr_name, "PTR", self._ensure_fqdn(hostname))

    def add_alias(self, zone_id, cname, hostname):
        self._operate_record("create", zone_id, cname, "CNAME", self._ensure_fqdn(hostname))

    def delete_alias(self, zone_id, cname, hostname):
        self._operate_record("delete", zone_id, cname, "CNAME", self._ensure_fqdn(hostname))

    def update_alias(self, zone_id, cname, hostname):
        self._operate_record("upsert", zone_id, cname, "CNAME", self._ensure_fqdn(hostname))

    def _operate_record(self, action, zone_id, rdname, rdtype, data):
        action = action.upper()
        if not action in ["CREATE", "DELETE", "UPSERT"]:
            self.misc.die("{} with DNS record isn't supported".format(action))

        self.logger.debug("Requesting {} of '{}':'{}' record at {} with data '{}'.".format(
            action, rdtype, rdname, zone_id, data))

        response = self.client.change_resource_record_sets(
            HostedZoneId=zone_id,
            ChangeBatch={
                "Comment": "made by dnswatch",
                "Changes": [
                    {
                        "Action": action,
                        "ResourceRecordSet": {
                            "Name": rdname,
                            "Type": rdtype,
                            "TTL": self.config["ttl"],
                            "ResourceRecords": [
                                { "Value": data },
                            ]
                        },
                    },
                ],
            }
        )

        request_id = self._extract_id(response["ChangeInfo"]["Id"])
        self.logger.debug("Request sent: %s." % request_id)

        if self.sync:
            self._wait_request(request_id)
        else:
            self.unchecked_requests.append(request_id)

    def check_request_status(self, request_id=None):
        if request_id:
#.........這裏部分代碼省略.........
開發者ID:nixargh,項目名稱:dnswatch,代碼行數:103,代碼來源:route53.py

示例5: __init__

# 需要導入模塊: from misc import Misc [as 別名]
# 或者: from misc.Misc import die [as 別名]

#.........這裏部分代碼省略.........
    def delete_host(self, dnsserver, host, ip, ptr=False):
        self._operate_record("delete", dnsserver, host, "A", ip)
        if ptr:
            self.delete_ptr(dnsserver, host, ip)

    def update_host(self, dnsserver, host, ip, ptr=False):
        self._operate_record("replace", dnsserver, host, "A", ip)
        if ptr:
            self.update_ptr(dnsserver, host, ip)

    def add_ptr(self, dnsserver, host, ip):
        ptr_record = dns.reversename.from_address(ip)
        self._operate_record("add", dnsserver, ptr_record, "PTR", self._ensure_fqdn(host))

    def delete_ptr(self, dnsserver, host, ip):
        ptr_record = dns.reversename.from_address(ip)
        self._operate_record("delete", dnsserver, ptr_record, "PTR", self._ensure_fqdn(host))

    def update_ptr(self, dnsserver, host, ip):
        ptr_record = dns.reversename.from_address(ip)
        self._operate_record("replace", dnsserver, ptr_record, "PTR", self._ensure_fqdn(host))

    def add_alias(self, dnsserver, cname, hostname):
        self._operate_record("add", dnsserver, cname, "CNAME", self._ensure_fqdn(hostname))

    def delete_alias(self, dnsserver, cname, hostname):
        self._operate_record("delete", dnsserver, cname, "CNAME", self._ensure_fqdn(hostname))

    def update_alias(self, dnsserver, cname, hostname):
        self._operate_record("replace", dnsserver, cname, "CNAME", self._ensure_fqdn(hostname))

    def _operate_record(self, action, dnsserver, rdname, rdtype, data):
        if not action in ["add", "delete", "replace"]:
            self.misc.die("{} with DNS record isn't supported".format(action))
        if not self.keyring:
            self.misc.die("Keyring for DNS action not found")
        if not self.key_algorithm:
            self.misc.die("Key algorithm for DNS action not specified")
        self.logger.debug("Doing {} of '{}':'{}' record at {} with data '{}'.".format(
            action, rdtype, rdname, dnsserver, data))

        # Adjusting variables
        if rdtype == "PTR":
            rdname, origin = str(rdname).split(".", 1)
        else:
            origin = dns.name.from_text(self.config["zone"])
            rdname = dns.name.from_text(rdname) - origin
        data = data.encode("utf-8")

        # Collecting arguments for DNS update
        args = list()
        if action in ["add", "replace"]:
            args.append(self.config["ttl"])
        args.append(rdtype)        
        if action in ["add", "replace"]:
            args.append(data)

        # Doing DNS update
        update = dns.update.Update(
            origin,
            keyring=self.keyring, 
            keyalgorithm=self.key_algorithm)  
        eval('update.{}(rdname, *args)'.format(action))

        result = dns.query.tcp(update, dnsserver, timeout=self.config["timeout"])
開發者ID:nixargh,項目名稱:dnswatch,代碼行數:69,代碼來源:dnsops.py


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