コード例 #1
0
    def post(self, request, *args, **kwargs):
        """
        服务构建
        ---
        parameters:
            - name: tenantName
              description: 租户名
              required: true
              type: string
              paramType: path
            - name: serviceAlias
              description: 服务别名
              required: true
              type: string
              paramType: path

        """
        probe = None
        try:
            is_deploy = request.data.get("is_deploy", True)
            # 数据中心创建应用
            new_service = app_service.create_region_service(self.tenant, self.service, self.user.nick_name)
            self.service = new_service
            # 为服务添加默认探针
            if self.is_need_to_add_default_probe():
                code, msg, probe = app_service.add_service_default_porbe(self.tenant, self.service)
            if is_deploy:
                # 添加服务有无状态标签
                label_service.update_service_state_label(self.tenant, self.service)
                # 部署应用
                app_manage_service.deploy(self.tenant, self.service, self.user, is_upgrade=True)

                # 添加应用部署关系
                deploy_repo.create_deploy_relation_by_service_id(service_id=self.service.service_id)

            result = general_message(200, "success", "构建成功")
        except Exception as e:
            logger.exception(e)
            result = error_message(e.message)
            # 删除probe
            # 删除region端数据
            if probe:
                probe_service.delete_service_probe(self.tenant, self.service, probe.probe_id)
            event_service.delete_service_events(self.service)
            port_service.delete_region_port(self.tenant, self.service)
            volume_service.delete_region_volumes(self.tenant, self.service)
            env_var_service.delete_region_env(self.tenant, self.service)
            dependency_service.delete_region_dependency(self.tenant, self.service)

            app_manage_service.delete_region_service(self.tenant, self.service)
            self.service.create_status = "checked"
            self.service.save()

        return Response(result, status=result["code"])
コード例 #2
0
    def __create_region_services(self, tenant, user, service_list,
                                 service_probe_map):
        service_prob_id_map = {}
        new_service_list = []
        try:
            for service in service_list:
                # 数据中心创建应用
                new_service = app_service.create_region_service(
                    tenant, service, user.nick_name)
                # 为服务添加探针
                probe_data = service_probe_map.get(service.service_id)
                probe_ids = []
                if probe_data:
                    for data in probe_data:
                        code, msg, probe = probe_service.add_service_probe(
                            tenant, service, data)
                        if code == 200:
                            probe_ids.append(probe.probe_id)
                else:
                    code, msg, probe = app_service.add_service_default_porbe(
                        tenant, service)
                    if probe:
                        probe_ids.append(probe.probe_id)
                if probe_ids:
                    service_prob_id_map[service.service_id] = probe_ids

                # 添加服务有无状态标签
                label_service.update_service_state_label(tenant, new_service)
                new_service_list.append(new_service)
            return new_service_list
        except Exception as e:
            logger.exception("local market install app error {0}".format(e))
            if service_list:
                for service in service_list:
                    if service_prob_id_map:
                        probe_ids = service_prob_id_map.get(service.service_id)
                        if probe_ids:
                            for probe_id in probe_ids:
                                try:
                                    probe_service.delete_service_probe(
                                        tenant, service, probe_id)
                                except Exception as le:
                                    logger.exception(
                                        "local market install app delete service probe {0}"
                                        .format(le))
            raise e
コード例 #3
0
    def __build_services(self, tenant, user, service_list, service_probe_map):
        service_prob_map = {}
        try:
            for service in service_list:
                # 数据中心创建应用
                new_service = app_service.create_region_service(
                    tenant, service, user.nick_name)
                # 为服务添加探针
                probe_data = service_probe_map.get(service.service_id)
                probe_ids = []
                if probe_data:
                    for data in probe_data:
                        code, msg, probe = probe_service.add_service_probe(
                            tenant, service, data)
                        if code == 200:
                            probe_ids.append(probe.probe_id)
                if probe_ids:
                    service_probe_map[service.service_id] = probe_ids

                # 添加服务有无状态标签
                label_service.update_service_state_label(tenant, new_service)
                # 部署应用
                app_manage_service.deploy(tenant, new_service, user)
        except Exception as e:
            logger.exception(e)
            if service_list:
                for service in service_list:
                    if service_prob_map:
                        probe_ids = service_prob_map.get(service.service_id)
                        if probe_ids:
                            for probe_id in probe_ids:
                                try:
                                    probe_service.delete_service_probe(
                                        tenant, service, probe_id)
                                except Exception as le:
                                    logger.exception(le)
            raise e
コード例 #4
0
    def post(self, request, *args, **kwargs):
        """
        组件构建
        ---
        parameters:
            - name: tenantName
              description: 租户名
              required: true
              type: string
              paramType: path
            - name: serviceAlias
              description: 组件别名
              required: true
              type: string
              paramType: path

        """
        probe = None
        is_deploy = request.data.get("is_deploy", True)
        status = 200
        try:
            if self.service.service_source == "third_party":
                is_deploy = False
                # 数据中心连接创建第三方组件
                new_service = app_service.create_third_party_service(
                    self.tenant, self.service, self.user.nick_name)
            else:
                # 数据中心创建组件
                new_service = app_service.create_region_service(
                    self.tenant, self.service, self.user.nick_name)

            self.service = new_service
            # 为组件添加默认探针
            if self.is_need_to_add_default_probe():
                code, msg, probe = app_service.add_service_default_porbe(
                    self.tenant, self.service)
                logger.debug("add default probe; code: {}; msg: {}".format(
                    code, msg))
            if is_deploy:
                # 添加组件有无状态标签
                label_service.update_service_state_label(
                    self.tenant, self.service)
                # 部署组件
                app_manage_service.deploy(self.tenant,
                                          self.service,
                                          self.user,
                                          group_version=None)

                # 添加组件部署关系
                deploy_repo.create_deploy_relation_by_service_id(
                    service_id=self.service.service_id)

            result = general_message(200, "success", "构建成功")
            return Response(result, status=result["code"])
        except HttpClient.CallApiError as e:
            logger.exception(e)
            if e.status == 403:
                result = general_message(10407, "no cloud permission",
                                         e.message)
                status = e.status
            elif e.status == 400:
                if "is exist" in e.message.get("body", ""):
                    result = general_message(400,
                                             "the service is exist in region",
                                             "该组件名称在数据中心已存在")
                else:
                    result = general_message(400, "call cloud api failure",
                                             e.message)
                status = e.status
            else:
                result = general_message(500, "call cloud api failure",
                                         e.message)
                status = 500

        # 删除probe
        # 删除region端数据
        if probe:
            probe_service.delete_service_probe(self.tenant, self.service,
                                               probe.probe_id)
        if self.service.service_source != "third_party":
            event_service.delete_service_events(self.service)
            port_service.delete_region_port(self.tenant, self.service)
            volume_service.delete_region_volumes(self.tenant, self.service)
            env_var_service.delete_region_env(self.tenant, self.service)
            dependency_service.delete_region_dependency(
                self.tenant, self.service)
            app_manage_service.delete_region_service(self.tenant, self.service)
        self.service.create_status = "checked"
        self.service.save()
        return Response(result, status=status)
コード例 #5
0
    def post(self, request, *args, **kwargs):
        """
        docker-compose组件检测
        ---
        parameters:
            - name: tenantName
              description: 租户名
              required: true
              type: string
              paramType: path
            - name: group_id
              description: 组ID
              required: true
              type: string
              paramType: path
            - name: compose_id
              description: group_compose ID
              required: true
              type: string
              paramType: form
        """
        probe_map = dict()
        services = None

        try:
            compose_id = request.data.get("compose_id", None)
            if not compose_id:
                return Response(general_message(400, "params error", "参数异常"),
                                status=400)
            group_compose = compose_service.get_group_compose_by_compose_id(
                compose_id)
            services = compose_service.get_compose_services(compose_id)
            # 数据中心创建组件
            new_app_list = []
            for service in services:
                new_service = app_service.create_region_service(
                    self.tenant, service, self.user.nick_name)
                new_app_list.append(new_service)
                # 为组件添加默认探针
                code, msg, probe = app_service.add_service_default_porbe(
                    self.tenant, new_service)
                if probe:
                    probe_map[service.service_id] = probe.probe_id
                # 添加组件有无状态标签
                label_service.update_service_state_label(
                    self.tenant, new_service)

            group_compose.create_status = "complete"
            group_compose.save()
            for s in new_app_list:
                try:
                    app_manage_service.deploy(self.tenant,
                                              s,
                                              self.user,
                                              group_version=None)
                except Exception as e:
                    logger.exception(e)
                    continue

            result = general_message(200, "success", "构建成功")
        except Exception as e:
            logger.exception(e)
            result = error_message(e.message)
            # 删除probe
            # 删除region端数据
            if services:
                for service in services:
                    if probe_map:
                        probe_id = probe_map.get(service.service_id)
                        probe_service.delete_service_probe(
                            self.tenant, service, probe_id)

                    event_service.delete_service_events(service)
                    port_service.delete_region_port(self.tenant, service)
                    volume_service.delete_region_volumes(self.tenant, service)
                    env_var_service.delete_region_env(self.tenant, service)
                    dependency_service.delete_region_dependency(
                        self.tenant, service)

                    app_manage_service.delete_region_service(
                        self.tenant, service)
                    service.create_status = "checked"
                    service.save()

        return Response(result, status=result["code"])
コード例 #6
0
    def post(self, request, *args, **kwargs):
        """
        组件构建
        ---
        parameters:
            - name: tenantName
              description: 租户名
              required: true
              type: string
              paramType: path
            - name: serviceAlias
              description: 组件别名
              required: true
              type: string
              paramType: path

        """
        probe = None
        is_deploy = request.data.get("is_deploy", True)
        try:
            if not check_memory_quota(
                    self.oauth_instance, self.tenant.enterprise_id,
                    self.service.min_memory, self.service.min_node):
                raise ServiceHandleException(msg="not enough quota",
                                             error_code=20002)
            if self.service.service_source == "third_party":
                is_deploy = False
                # create third component from region
                new_service = app_service.create_third_party_service(
                    self.tenant, self.service, self.user.nick_name)
            else:
                # 数据中心创建组件
                new_service = app_service.create_region_service(
                    self.tenant, self.service, self.user.nick_name)

            self.service = new_service
            if is_deploy:
                try:
                    app_manage_service.deploy(
                        self.tenant,
                        self.service,
                        self.user,
                        group_version=None,
                        oauth_instance=self.oauth_instance)
                except ErrInsufficientResource as e:
                    result = general_message(e.error_code, e.msg, e.msg_show)
                    return Response(result, status=e.status_code)
                except Exception as e:
                    logger.exception(e)
                    err = ErrComponentBuildFailed()
                    result = general_message(err.error_code, e, err.msg_show)
                    return Response(result, status=400)
                # 添加组件部署关系
                deploy_repo.create_deploy_relation_by_service_id(
                    service_id=self.service.service_id)

            result = general_message(200, "success", "构建成功")
            return Response(result, status=result["code"])
        except HttpClient.CallApiError as e:
            logger.exception(e)
            if e.status == 403:
                result = general_message(10407, "no cloud permission",
                                         e.message)
                status = e.status
            elif e.status == 400:
                if "is exist" in e.message.get("body", ""):
                    result = general_message(400,
                                             "the service is exist in region",
                                             "该组件在数据中心已存在,你可能重复创建?")
                else:
                    result = general_message(400, "call cloud api failure",
                                             e.message)
                status = e.status
            else:
                result = general_message(400, "call cloud api failure",
                                         e.message)
                status = 400
        # 删除probe
        # 删除region端数据
        if probe:
            probe_service.delete_service_probe(self.tenant, self.service,
                                               probe.probe_id)
        if self.service.service_source != "third_party":
            event_service.delete_service_events(self.service)
            port_service.delete_region_port(self.tenant, self.service)
            volume_service.delete_region_volumes(self.tenant, self.service)
            env_var_service.delete_region_env(self.tenant, self.service)
            dependency_service.delete_region_dependency(
                self.tenant, self.service)
            app_manage_service.delete_region_service(self.tenant, self.service)
        self.service.create_status = "checked"
        self.service.save()
        return Response(result, status=status)