本文整理匯總了Python中vnc_kubernetes_config.VncKubernetesConfig.cluster_project_fq_name方法的典型用法代碼示例。如果您正苦於以下問題:Python VncKubernetesConfig.cluster_project_fq_name方法的具體用法?Python VncKubernetesConfig.cluster_project_fq_name怎麽用?Python VncKubernetesConfig.cluster_project_fq_name使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類vnc_kubernetes_config.VncKubernetesConfig
的用法示例。
在下文中一共展示了VncKubernetesConfig.cluster_project_fq_name方法的12個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。
示例1: _get_linklocal_entry_name
# 需要導入模塊: from vnc_kubernetes_config import VncKubernetesConfig [as 別名]
# 或者: from vnc_kubernetes_config.VncKubernetesConfig import cluster_project_fq_name [as 別名]
def _get_linklocal_entry_name(name, k8s_ns):
if not k8s_ns:
project_fq_name = vnc_kube_config.cluster_default_project_fq_name()
else:
project_fq_name = vnc_kube_config.cluster_project_fq_name(k8s_ns)
ll_name = project_fq_name + [name]
return "-".join(ll_name)
示例2: _get_ns_address_list
# 需要導入模塊: from vnc_kubernetes_config import VncKubernetesConfig [as 別名]
# 或者: from vnc_kubernetes_config.VncKubernetesConfig import cluster_project_fq_name [as 別名]
def _get_ns_address_list(self, np_sg_uuid, labels=None):
address_list = []
if not labels:
ns_uuid_list = NamespaceKM.keys()
labels = self._get_ns_allow_all_label()
else:
ns_uuid_set = self._find_namespaces(labels)
ns_uuid_list = list(ns_uuid_set)
for ns_uuid in ns_uuid_list or []:
address = {}
ns = NamespaceKM.get(ns_uuid)
if not ns:
continue
proj_fq_name = vnc_kube_config.cluster_project_fq_name(ns.name)
ns_sg_fq_name = proj_fq_name[:]
ns_sg = "-".join([vnc_kube_config.cluster_name(), ns.name, 'sg'])
ns_sg_fq_name.append(ns_sg)
address['security_group'] = ns_sg_fq_name
address['ns_selector'] = labels
if ns_sg in self._default_ns_sgs[ns.name]:
address['ns_sg_uuid'] = self._default_ns_sgs[ns.name][ns_sg]
address_list.append(address)
for label in labels.items():
key = self._label_cache._get_key(label)
self._label_cache._locate_label(key,
self._ingress_ns_label_cache, label, np_sg_uuid)
return address_list
示例3: _get_project
# 需要導入模塊: from vnc_kubernetes_config import VncKubernetesConfig [as 別名]
# 或者: from vnc_kubernetes_config.VncKubernetesConfig import cluster_project_fq_name [as 別名]
def _get_project(self, service_namespace):
proj_fq_name =\
vnc_kube_config.cluster_project_fq_name(service_namespace)
try:
proj_obj = self._vnc_lib.project_read(fq_name=proj_fq_name)
return proj_obj
except NoIdError:
return None
示例4: _get_project
# 需要導入模塊: from vnc_kubernetes_config import VncKubernetesConfig [as 別名]
# 或者: from vnc_kubernetes_config.VncKubernetesConfig import cluster_project_fq_name [as 別名]
def _get_project(self, ns_name):
proj_fq_name = vnc_kube_config.cluster_project_fq_name(ns_name)
try:
proj_obj = self._vnc_lib.project_read(fq_name=proj_fq_name)
except NoIdError:
self._logger.error("%s - %s Not Found" %(self._name, proj_fq_name))
return None
return proj_obj
示例5: _get_ns_address
# 需要導入模塊: from vnc_kubernetes_config import VncKubernetesConfig [as 別名]
# 或者: from vnc_kubernetes_config.VncKubernetesConfig import cluster_project_fq_name [as 別名]
def _get_ns_address(self, ns_name):
address = {}
proj_fq_name = vnc_kube_config.cluster_project_fq_name(ns_name)
ns_sg_fq_name = proj_fq_name[:]
ns_sg = "-".join([vnc_kube_config.cluster_name(), ns_name, 'sg'])
ns_sg_fq_name.append(ns_sg)
address['security_group'] = ns_sg_fq_name
return address
示例6: _create_project
# 需要導入模塊: from vnc_kubernetes_config import VncKubernetesConfig [as 別名]
# 或者: from vnc_kubernetes_config.VncKubernetesConfig import cluster_project_fq_name [as 別名]
def _create_project(self, project_name):
proj_fq_name = vnc_kube_config.cluster_project_fq_name(project_name)
proj_obj = Project(name=proj_fq_name[-1], fq_name=proj_fq_name)
try:
self.vnc_lib.project_create(proj_obj)
except RefsExistError:
proj_obj = self.vnc_lib.project_read(
fq_name=proj_fq_name)
ProjectKM.locate(proj_obj.uuid)
return proj_obj
示例7: _check_service_uuid_change
# 需要導入模塊: from vnc_kubernetes_config import VncKubernetesConfig [as 別名]
# 或者: from vnc_kubernetes_config.VncKubernetesConfig import cluster_project_fq_name [as 別名]
def _check_service_uuid_change(self, svc_uuid, svc_name,
svc_namespace, ports):
proj_fq_name = vnc_kube_config.cluster_project_fq_name(svc_namespace)
lb_fq_name = proj_fq_name + [svc_name]
lb_uuid = LoadbalancerKM.get_fq_name_to_uuid(lb_fq_name)
if lb_uuid is None:
return
if svc_uuid != lb_uuid:
self.vnc_service_delete(lb_uuid, svc_name, svc_namespace, ports)
self.logger.notice("Uuid change detected for service %s. "
"Deleteing old service" % lb_fq_name);
示例8: vnc_namespace_delete
# 需要導入模塊: from vnc_kubernetes_config import VncKubernetesConfig [as 別名]
# 或者: from vnc_kubernetes_config.VncKubernetesConfig import cluster_project_fq_name [as 別名]
def vnc_namespace_delete(self,namespace_id, name):
proj_fq_name = vnc_kube_config.cluster_project_fq_name(name)
project_uuid = ProjectKM.get_fq_name_to_uuid(proj_fq_name)
if not project_uuid:
self._logger.error("Unable to locate project for k8s namespace "
"[%s]" % (name))
return
project = ProjectKM.get(project_uuid)
if not project:
self._logger.error("Unable to locate project for k8s namespace "
"[%s]" % (name))
return
default_sg_fq_name = proj_fq_name[:]
sg = "-".join([vnc_kube_config.cluster_name(), name, 'default'])
default_sg_fq_name.append(sg)
ns_sg_fq_name = proj_fq_name[:]
ns_sg = "-".join([vnc_kube_config.cluster_name(), name, 'sg'])
ns_sg_fq_name.append(ns_sg)
sg_list = [default_sg_fq_name, ns_sg_fq_name]
try:
# If the namespace is isolated, delete its virtual network.
if self._is_namespace_isolated(name) == True:
vn_name = self._get_namespace_vn_name(name)
self._delete_isolated_ns_virtual_network(name, vn_name=vn_name,
proj_fq_name=proj_fq_name)
# delete default-sg and ns-sg security groups
security_groups = project.get_security_groups()
for sg_uuid in security_groups:
sg = SecurityGroupKM.get(sg_uuid)
if sg and sg.fq_name in sg_list[:]:
self._vnc_lib.security_group_delete(id=sg_uuid)
sg_list.remove(sg.fq_name)
if not len(sg_list):
break
# delete the label cache
if project:
self._clear_namespace_label_cache(namespace_id, project)
# delete the namespace
self._delete_namespace(name)
# If namespace=project, delete the project
if vnc_kube_config.cluster_project_name(name) == name:
self._vnc_lib.project_delete(fq_name=proj_fq_name)
except Exception as e:
pass
示例9: _vnc_create_sg
# 需要導入模塊: from vnc_kubernetes_config import VncKubernetesConfig [as 別名]
# 或者: from vnc_kubernetes_config.VncKubernetesConfig import cluster_project_fq_name [as 別名]
def _vnc_create_sg(self, np_spec, namespace, name,
uuid=None, **kwargs_annotations):
proj_fq_name = vnc_kube_config.cluster_project_fq_name(namespace)
proj_obj = Project(name=proj_fq_name[-1], fq_name=proj_fq_name,
parent='domain')
sg_obj = SecurityGroup(name=name, parent_obj=proj_obj)
if uuid:
sg_obj.uuid = uuid
if np_spec:
kwargs_annotations.update({'np_spec': json.dumps(np_spec)})
self._set_sg_annotations(namespace, name,
sg_obj, **kwargs_annotations)
try:
self._vnc_lib.security_group_create(sg_obj)
except Exception as e:
self._logger.error("%s - %s SG Not Created" %s(self._name, name))
return None
sg = SecurityGroupKM.locate(sg_obj.uuid)
return sg
示例10: _get_ingress_sg_rule_list
# 需要導入模塊: from vnc_kubernetes_config import VncKubernetesConfig [as 別名]
# 或者: from vnc_kubernetes_config.VncKubernetesConfig import cluster_project_fq_name [as 別名]
def _get_ingress_sg_rule_list(self, namespace, name,
ingress_rule_list, ingress_pod_sg_create=True):
ingress_pod_sgs = set()
ingress_ns_sgs = set()
ingress_sg_rule_list = []
ingress_pod_sg_dict = {}
ingress_pod_sg_index = 0
for ingress_rule in ingress_rule_list or []:
proj_fq_name = vnc_kube_config.cluster_project_fq_name(namespace)
src_sg_fq_name = proj_fq_name[:]
dst_port = ingress_rule['dst_port']
src_address = ingress_rule['src_address']
if 'pod_selector' in src_address:
pod_sg_created = False
src_sg_name = src_address['src_sg_name']
pod_selector = src_address['pod_selector']
if src_sg_name in ingress_pod_sg_dict:
pod_sg_created = True
if ingress_pod_sg_create and not pod_sg_created:
pod_sg = self._create_ingress_sg(
namespace, src_sg_name, json.dumps(pod_selector))
if not pod_sg:
continue
ingress_pod_sg_dict[src_sg_name] = pod_sg.uuid
pod_sg.ingress_pod_selector = pod_selector
ingress_pod_sgs.add(pod_sg.uuid)
self._update_sg_cache(self._ingress_pod_label_cache,
pod_selector, pod_sg.uuid)
pod_ids = self._find_pods(pod_selector)
for pod_id in pod_ids:
self._update_sg_pod_link(namespace,
pod_id, pod_sg.uuid, 'ADD', validate_vm=True)
src_sg_fq_name.append(src_sg_name)
else:
if 'ns_selector' in src_address:
ns_sg_uuid = src_address['ns_sg_uuid']
ingress_ns_sgs.add(ns_sg_uuid)
src_sg_fq_name = src_address['security_group']
ingress_sg_rule = self._get_ingress_sg_rule(
src_sg_fq_name, dst_port)
ingress_sg_rule_list.append(ingress_sg_rule)
return ingress_sg_rule_list, ingress_pod_sgs, ingress_ns_sgs
示例11: vnc_namespace_add
# 需要導入模塊: from vnc_kubernetes_config import VncKubernetesConfig [as 別名]
# 或者: from vnc_kubernetes_config.VncKubernetesConfig import cluster_project_fq_name [as 別名]
def vnc_namespace_add(self, namespace_id, name, labels, annotations):
isolated_ns_ann = 'True' if self._is_namespace_isolated(name) == True\
else 'False'
proj_fq_name = vnc_kube_config.cluster_project_fq_name(name)
proj_obj = Project(name=proj_fq_name[-1], fq_name=proj_fq_name)
ProjectKM.add_annotations(self, proj_obj, namespace=name, name=name,
k8s_uuid=(namespace_id), isolated=isolated_ns_ann)
try:
self._vnc_lib.project_create(proj_obj)
except RefsExistError:
proj_obj = self._vnc_lib.project_read(fq_name=proj_fq_name)
project = ProjectKM.locate(proj_obj.uuid)
# Validate the presence of annotated virtual network.
ann_vn_fq_name = self._get_annotated_virtual_network(name)
if ann_vn_fq_name:
# Validate that VN exists.
try:
self._vnc_lib.virtual_network_read(ann_vn_fq_name)
except NoIdError as e:
self._logger.error("Unable to locate virtual network [%s]"
"annotated on namespace [%s]. Error [%s]" %\
(ann_vn_fq_name, name, str(e)))
return None
# If this namespace is isolated, create it own network.
if self._is_namespace_isolated(name) == True:
vn_name = self._get_namespace_vn_name(name)
self._create_isolated_ns_virtual_network(ns_name=name,
vn_name=vn_name, proj_obj=proj_obj)
try:
network_policy = self._get_network_policy_annotations(name)
sg_dict = self._update_security_groups(name, proj_obj, network_policy)
self._ns_sg[name] = sg_dict
except RefsExistError:
pass
if project:
self._update_namespace_label_cache(labels, namespace_id, project)
return project
示例12: _is_service_exists
# 需要導入模塊: from vnc_kubernetes_config import VncKubernetesConfig [as 別名]
# 或者: from vnc_kubernetes_config.VncKubernetesConfig import cluster_project_fq_name [as 別名]
def _is_service_exists(self, service_name, service_namespace):
resource_type = "services"
service_info = self._kube.get_resource(resource_type,
service_name, service_namespace)
if service_info and 'metadata' in service_info:
uid = service_info['metadata'].get('uid')
if not uid:
return False, None
else:
return False, None
name = VncCommon.make_name(service_name, uid)
proj_fq_name = vnc_kube_config.cluster_project_fq_name(service_namespace)
lb_fq_name = proj_fq_name + [name]
try:
lb_obj = self._vnc_lib.loadbalancer_read(fq_name=lb_fq_name)
except NoIdError:
return False, None
if lb_obj is None:
return False, None
else:
return True, lb_obj.uuid