EdgeGallery开发指南

API接口

简介

EdgeGallery支持第三方业务系统通过北向接口网关调用EdgeGallery的业务接口。调用流程如下图所示(融合前端edgegallery-fe包含融合前端界面以及北向接口网关功能,通过浏览器访问时打开的是融合前端的界面,通过IP:Port/urlPrefix的形式访问的是其作为北向接口网关的其它组件后端API):

目前由WebsiteGateway来承担北向接口网关的职责,具体是由通过WebsiteGateway运行起来的各业务平台前端来承担。 所以北向接口调用的Endpoint可以使用任意一个业务平台前端的Endpoint。如下:

平台

架构

endpoint

说明

EdgeGallery融合前端

融合

​​https://{PORTAL_IP}:30095​​

推荐使用该endpoint

AppStore平台前端

独立

​​https://{PORTAL_IP}:30091​​

Developer平台前端

独立

​​https://{PORTAL_IP}:30092​​

新版本1.5.2已弃用,访问会出现Bug

Mecm平台前端

独立

​​https://{PORTAL_IP}:30093​​

Atp平台前端

独立

​​https://{PORTAL_IP}:30094​​

通过北向接口调用各平台的业务接口时,URL按照如下格式调用:

https://x.x.x.x:30095/{urlPrefix}/{业务接口自身的URL路径}

其中urlPrefix是各平台在网关中定义的路由前缀,定义如下表所示:

平台

urlPrefix

AppStore

mec-appstore

Developer

mec-developer

Mecm-Inventory

mecm-inventory

Mecm-APPO

mecm-appo

Mecm-APM

mecm-apm

ATP

mec-atp

除了以上关于各业务平台以及MEO相关的URL以外,还有MEPM相关的URL,该URL通过Ingress访问,访问URL为:

https://10.8.59.12:31252/{urlPrefix}/{业务接口自身的URL}

其中urlPrefix是各平台在网关中定义的路由前缀,定义如下表所示:

平台

urlPrefix

Backend Service

mepm-fe

/

mepm-fe:8200

lcmcontroller

/lcmcontroller

mecm-mepm-lcmcontroller:8094

apprulemgr

/apprulemgr

mecm-mepm-apprulemgr:8096

rescontroller

/rescontroller

mecm-mepm-rescontroller:8098

EdgeGallery各个组件的Service/NodePort情况如下(仅供参考,新版本有一定变化):

Component

Pod Name

Service Name

Node Port

Internal Port

appstore-be

appstore-be-0

appstore-be-svc

ClusterIP

8099

appstore-fe

appstore-fe

appstore-fe-svc

30091

8443

appstore-be-postgres

appstore-be-postgres-0

appstore-be-postgres-svc

ClusterIP

5432

developer-be

developer-be-0

N/A

N/A

N/A

developer-fe

developer-fe

developer-fe-svc

30092

8443

developer-be-postgres

developer-be-postgres-0

developer-be-postgres-svc

ClusterIP

5432

file-system

file-system

file-system-svc

30090

9500

filesystem-postgres

filesystem-postgres

filesystem-postgres

ClusterIP

5432

healthcheck

healthcheck

healthcheck-svc

32759

9527

healthcheck-m

healthcheck-m

healthcheck-m-svc

32757

9529

user-mgmt

user-mgmt

user-mgmt-svc

30067

8067

user-mgmt-postgres

user-mgmt-postgres-0

user-mgmt-postgres-svc

ClusterIP

5432

user-mgmt-redis

user-mgmt-redis-0

user-mgmt-redis-svc

ClusterIP

6379

service-center

service-center

service-center

ClusterIP

30100

mecm-fe

mecm-fe

mecm-fe-svc

30093

8443

mecm-appo

mecm-appo

mecm-appo-svc

30201

8091

mecm-apm

mecm-apm

mecm-apm-svc

30202

8092

mecm-inventory

mecm-inventory

mecm-inventory-svc

30203

8093

mecm-north

mecm-north

mecm-north-svc

30303

8102

mecm-applcm-controller

mecm-applcm-controller

mecm-applcm-controller-svc

30204

8094

mecm-resource-controller

mecm-resource-controller

mecm-resource-controller-svc

31952

8098

mecm-applcm-k8splugin

mecm-applcm-k8splugin

mecm-applcm-k8splugin-svc

30205

8095

mepserver

mepserver-deploy

mepserver-service

ClusterIP

8080

mepauth

mepauth-deploy

mepauth-service

ClusterIP

8088

kong-apigw

apigw-kongy

kong-service

30443

8443

mep-postgre-db

pg-deploy

pg-service

ClusterIP

5432

ServiceComb端口列表:

Component

Service Name

REST Port

Spring Server Port (default 8080)

appstore-be

mec-appstore

8099

8099

appstore-fe

appstore-fe

8080

8443

developer-be

mec-developer

9082

9082

developer-fe

developer-fe

8080

8443

user-mgmt

user-mgmt-be

8067

8067

user-mgmt-fe

user-mgmt-fe

8080

8443

调用AppStore接口示例

使用前需要安装新版本的Postman,较老版本可能无法上传文件导致调用人脸识别API接口返回500错误,新版本下载链接如下:http://10.8.56.160:8082/Postman-win64-Setup.exe(文尾附带静态资源服务器的启动YAML文件)

使用前关闭SSL证书认证:

  1. 获取XSRF-TOKEN
GET https://10.8.59.12:30095/

在发送请求后依次在Postman界面中点击Cookies、XSRF-TOKEN,就可以看到XSRF-TOKEN了:

  1. 获取AccessToken
POST https://10.8.59.12:30095/mec-usermgmt/v1/accesstoken

需要传递的字段:

Name

Definition

Type

Required

X-XSRF-TOKEN

XSRF-TOKEN

Header

userFlag

登录凭证(用户名/邮箱/手机号)

Body

password

密码

Body

需要注意Body部分只支持JSON格式,不支持form-data:

  1. 调用业务接口查看AppStore里面的app列表:
#示例
GET https://10.8.59.12:30095/mec-appstore/mec/appstore/v1/apps

通过H "X-XSRF-TOKEN: xxxx" -H "X-ACCESS-TOKEN: xxxx"两个token访问业务

​​开发者指导 — EdgeGallery Documentation 0.0.1 文档​​

MECM API
APM(应用包管理器)开放API接口

​​Projects/MECM/MECM_APIs/apm-swagger-openapi.yaml · EdgeGallery/docs - Gitee.com​​

APPO(应用编排器)开放API接口

​​Projects/MECM/MECM_APIs/appo-swagger-openapi.yaml · EdgeGallery/docs - 码云 - 开源中国 (gitee.com)​​

Inventory(应用视图)开放API接口

​​Projects/MECM/MECM_APIs/inventory-swagger-openapi.yaml · EdgeGallery/docs - 码云 - 开源中国 (gitee.com)​​

MEP开放API接口(Mp1和Mm5)

EdgeGallery从1.3.0版本开始MEP已经完全实现ETSI接口规范,具体实现接口及规范如下:

MEP server 接口分为两类,一类为遵循 ETSI MEC 011 v2.1.1 标准的 Mp1 接口,主要为 App 提供服务注册发现,App 状态通知订阅,Dns 规则获取等功能;另 一类为 Mm5 接口,主要为 MECM/MEPM 提供配置管理功能。MEP auth目前主要作为鉴权模块,为App提供token申请发放功能。

使用 Mp1 接口 mec 应用程序可以查询和激活/停用与其关联的 dns 规则。 该接口的实现按照 ETSI GS MEC 011 V2.1.1 文档

使用 Mp1 接口,mec 应用程序可以查询和修改与其关联的流量规则。 该接口的实现符合 ETSI GS MEC 011 V2.1.1 文档

使用 Mm5 接口,MECM 可以创建、查询、更新或删除应用程序配置,其中包括与应用程序关联的多个 dns 和流量规则。 此接口的实现在 ETSI GS MEC 010-1 V1.1.1 和 ETSI GS MEC 010-2 V2.1.1 文档中指定

​​Projects/MEP/MEP_Interfaces.md · EdgeGallery/docs - 码云 - 开源中国 (gitee.com)​​

补充这份文档(Mp1接口调用以及MEP单独部署):​​本地开发验证说明书​​

MEP Auth(无法调用,现在只能通过mep-agent进行MEP的授权)
#Service Authentication Interface
POST /mep/token
#AK/SK configuration interface
PUT /mep/appMng/v1/applications/{appInstanceId}/confs
Provider APP服务注册

生产者APP通过mep-agent自动将发布的能力注册到MEP平台上,用户无需手动注册,只需要在应用孵化流程的能力中心上补充如下信息即可:

其中服务名称和内部端口号必须填上传YAML文件中Service的名称和Cluster端口号,Service名称不区分大小写

除了在界面上填写相关信息实现MEP平台服务的自动注册,也可以由应用调用相关API接口进行手动注册:

#为指定APP注册服务(一般使用mep-agent自动注册,简化服务注册流程)
POST /mep/mec_service_mgmt/v1/applications/{appInstanceId}/services
#为APP手动注册服务实例(无意义的调用,因为没有指定Endpoint等信息):
curl -XPOST https://mep-api-gw.mep:8443/mep/mec_service_mgmt/v1/applications/644c0b3d-3e31-492d-9c7a-2392589b0cff/services -k -H "Authorization: Bearer $TOKEN" -d '{"serName":"FaceService","version":"1.0","state":"ACTIVE","serializer":"JSON"}'

#更新APP指定服务信息
PUT /mep/mec_service_mgmt/v1/applications/{appInstanceId}/services/{serviceId}

#删除APP指定服务
DELETE /mep/mec_service_mgmt/v1/applications/{appInstanceId}/services/{serviceId}

#应用发送确认消息,确保实例化和启动阶段成功完成
POST /mep/mec_app_support/v1/applications/{appInstanceId}/confirm_ready
Consumer APP服务发现和能力调用(服务管理相关接口)
  1. 部署Consumer APP
  2. 进入Consumer APP的容器进程网络栈
docker top `docker ps | grep mep-agent | awk '{print $10}'`
PID=xxx #该值为上一步命令返回结果中的PID值
nsenter -t $PID -n
  1. 通过mep-agent获取AccessToken
TOKEN=`curl -XGET -H "Content-Type: application/json" http://localhost:8080/mep-agent/v1/token | python3 -c "import sys,json;data=json.load(sys.stdin);print(data['access_token'])"`
  1. 获取当前MEP平台的Service列表

经测试,该URL仅仅能在Pod内部通过ServiceName或者Service的ClusterIP访问,在主机或者集群外访问会提示Unauthorized

#自动获取MEP平台API网关Service的Cluster IP
KONG_GW=`kubectl get svc -n mep | grep mep-api-gw | awk '{print $3}'`
#查看MEP平台的能力
curl -XGET https://$KONG_GW:8443/mep/mec_service_mgmt/v1/services -H "Authorization: Bearer $TOKEN" -k

以上方式查询MEP平台的所有Service是不推荐的,推荐使用mep-agent的API接口进行服务发现:

curl -XGET http://localhost:8080/mep-agent/v1/endpoint/face-recognition | python3 -c "import sys,json;data=json.load(sys.stdin);print(data['uris'][0])"

该接口调用后会返回JSON格式的Response,从Response中取出data["uris"][0]的内容即为服务对应的Endpoint

  1. 调用MEP平台提供的能力

通过上一步获取到的服务Endpoint中的URI + 应用服务本身的URI路径,即可访问该应用提供的API接口

curl -XGET https://$KONG_GW:8443/face-recognition1eae39e5618a11eda9d7/v1/face-recognition/ -H "Authorization: Bearer $TOKEN" -k

其它服务管理相关接口

#查询指定应用提供的服务
GET /mep/mec_service_mgmt/v1/applications/{appInstanceId}/services
#查询APP指定服务
GET /mep/mec_service_mgmt/v1/applications/{appInstanceId}/services/{serviceId}

GET /mep/mec_service_mgmt/v1/services
事件订阅相关接口(未实验)
#查询指定APP的可用事件订阅信息
GET /mep/mec_service_mgmt/v1/applications/{appInstanceId}/subscriptions

#为指定APP注册可用事件订阅
POST /mep/mec_service_mgmt/v1/applications/{appInstanceId}/subscriptions

#删除指定可用事件订阅信息
DELETE /mep/mec_service_mgmt/v1/applications/{appInstanceId}/subscriptions/{subscriptionId}

#查询指定ID的可用事件订阅信息
GET /mep/mec_service_mgmt/v1/applications/{appInstanceId}/subscriptions/{subscriptionId}

#查询指定APP的终止事件订阅信息
GET /mep/mec_app_support/v1/applications/{appInstanceId}/subscriptions
#为指定APP注册终止事件订阅
POST /mep/mec_app_support/v1/applications/{appInstanceId}/subscriptions
#删除指定终止事件订阅信息
DELETE /mep/mec_app_support/v1/applications/{appInstanceId}/subscriptions/{subscriptionId}
#查询指定ID的终止事件订阅信息
GET /mep/mec_app_support/v1/applications/{appInstanceId}/subscriptions/{subscriptionId}
DNS规则API接口

GET /mep/mec_app_support/v1/applications/{appInstanceId}/dns_rules
#Query a specific dns rule
GET /mep/mec_app_support/v1/applications/{appInstanceId}/dns_rules/{dnsRuleId}
#Update a specific dns rule
PUT /mep/mec_app_support/v1/applications/{appInstanceId}/dns_rules/{dnsRuleId}
流规则(未实验)
GET /mep/mec_app_support/v1/applications/{appInstanceId}/traffic_rules
GET /mep/mec_app_support/v1/applications/{appInstanceId}/traffic_rules/{trafficRuleId}
PUT /mep/mec_app_support/v1/applications/{appInstanceId}/traffic_rules/{trafficRuleId}
消费者应用集成Mp1接口代码实现网络开放能力调用

clientsdk.py,实现通过服务名查找对应的mep endpoint url:

import requests
import restclient

clientObjects = {}

def get_service_endpoint(service):
    """
       This is a get service endpoint method for getting endpoint information by using service name
    """
    url = restclient.MEP_AGENT_URL + "/mep-agent/v1/endpoint/{0}".format(service)
    headers = {'Content-Type': "application/json"}
    if restclient.SSL_ENABLED:
        url = restclient.HTTPS_URL + url
        response = requests.get(url, headers=headers, verify=restclient.SSL_CACERTPATH)
    else:
        url = restclient.HTTP_URL + url
        response = requests.get(url, headers=headers)

    # extracting data in json format
    if response:
        data = response.json()
        url = data["uris"]
        print("mep endpoint url = " + url[0])
        return url[0]
    return ""

class ClientFactory:
    """
       This is a class for client factory implementation.
    """
    #  constructor
    def __init__(self, list_of_services):
        self.update_client_object(list_of_services)

    @classmethod
    def update_client_object(cls, list_of_services):
        """
           This is a update client object method to get endpoint information
        """
        for service in list_of_services:
            endpoint = get_service_endpoint(service)
            if endpoint != "" and "http" in endpoint or "https" in endpoint:
                clientObjects[service] = restclient.RestClient(endpoint)

    @classmethod
    def get_client_by_service_name(cls, service):
        """
           This is a get client by service name method to return client object by using service name
        """
        return clientObjects[service]

restclient.py,实现获取Mp1接口Token和发起Mp1接口服务调用请求:

import os
import requests

HTTP_URL = "http://"
HTTPS_URL = "https://"
MEP_AGENT_URL = os.environ.get("MEP_AGENT", "127.0.0.1:8080")
SSL_ENABLED = False
ACCESS_TOKEN_ENABLED = False
CONTENT_TYPE = "application/json"
SSL_CACERTPATH = "/usr/app/ssl/ca.crt"

def get_access_token():
    """Get access token from mep-agent and return access token."""
    url = MEP_AGENT_URL + "/mep-agent/v1/token"
    headers = {'Content-Type': CONTENT_TYPE}
    if SSL_ENABLED:
        url = HTTPS_URL + url
        response = requests.get(url, headers=headers, verify=SSL_CACERTPATH)
    else:
        url = HTTP_URL + url
        response = requests.get(url, headers=headers)
    # extracting data in json format
    data = response.json()
    access_token = data["access_token"]
    return access_token

class RestClient:
    """
       This is a class for rest client implementation.
    """
    # rest client constructor
    def __init__(self, endpoint):
        self.endpoint = endpoint

    @classmethod
    def get(cls, url):
        """
        This is a get method for calling mep service via kong
        """
        access_token = get_access_token()
        access_token = "Bearer " + access_token
        headers = {'Authorization': access_token}
        requests.packages.urllib3.disable_warnings() #disable warnings
        response = requests.get(url, headers=headers, verify=False)
        return response.json()

    def get_endpoint(self):
        """
           This is a get endpoint method for getting endpoint information
        """
        return self.endpoint

调用clientsdk,clientsdk再调用restclient实现人脸识别业务的调用:

import clientsdk
listofService = ["face-recognition"]
sdk = clientsdk.ClientFactory(listofService)
# 通过ServiceName得到url
face_client = sdk.get_client_by_service_name(listofService[0])
# 通过url等到response
print(face_client.get(face_client.get_endpoint() + "/v1/face-recognition"))

SDK安装和使用指南

开发者平台集成了API多语言SDK的生成,通过Swagger Codegen组件自动生成API的客户端源码,本地安装后更加方便的调用edgegallery平台提供的API能力,目前支持python、java、go语言。

以人脸识别的SDK为例,下面详细介绍SDK的安装和使用教程:

  1. 进入融合前端集成开发选项中的能力中心,找到并点击人脸识别的能力,点击在线模拟器按钮,会出现SDK的下载页面

下载python3的开发环境镜像,使用以下Dockerfile构建安装好人脸识别SDK的镜像:

FROM python:3.10-slim
ADD face-recognition.tgz test.py /
RUN https_proxy=http://10.8.59.173:10809 pip3 install python-dateutil certifi urllib3 -i https://pypi.douban.com/simple && cd /face-recognition && python3 setup.py install

上面的Dockerfile文件中使用到的test.py文件的内容如下:

#!/usr/bin/python3
import swagger_client
test = swagger_client.FaceRecognitionApi()
print(test.health_check_get())

在EdgeGallery的集群中运行刚刚构建的镜像,进行调试:

kubectl run -it face-client --image face-client --image-pull-policy Never -- bash

#进入容器后执行test.py脚本,可以看到健康检查接口返回为1,表示人脸识别应用运行正常
python3 test.py

5G网络能力集成

MEP集成5G网络能力的步骤如下:

  1. 确定网络能力需求:首先需要明确需要集成哪些5G网络能力,例如UPF(User Plane Function)、AMF(Access and Mobility Management Function)、SMF(Session Management Function)等等。根据业务需求和网络架构,选择需要集成的网络能力。
  2. 集成网络能力模块:根据选择的网络能力需求,选择对应的网络能力模块进行集成。这些模块可以是标准化的3GPP网络功能模块(5GC网元),也可以是自定义的网络功能模块。将这些模块打包成Docker镜像或者Kubernetes应用程序,部署到EdgeGallery中的Kubernetes集群上。
  3. 实现网络能力接口:为了让其他应用程序可以使用集成的网络能力,需要实现对应的网络能力接口。这些接口可以是标准的3GPP接口,也可以是自定义的RESTful API接口等。开发者可以使用API网关等技术,将网络能力接口暴露给其他应用程序。
  4. 集成网络能力SDK:为了简化开发者集成网络能力的流程,可以提供网络能力SDK(Software Development Kit)。这些SDK包含了网络能力模块和对应的接口实现,以及相关的文档和示例代码等。开发者可以使用这些SDK,快速集成所需的网络能力。

集成5G网络能力需要明确网络需求,选择对应的网络能力模块进行集成,实现对应的网络能力接口,并提供网络能力SDK以方便开发者集成。EdgeGallery提供了开放的平台和相关工具,方便开发者集成和管理各种网络能力和应用。

MEP Pod网络详解

由于应用需要使用MEP平台开放能力或者暴露网络能力给MEP平台,因此对于应用来说,需要具有调用MEP平台API接口的能力,并将这部分调用MEP平台API能力的代码集成在自己的应用代码中,才能正常将应用集成到MEC平台上,而应用调用MEP平台的API是通过在应用内集成mep-agent实现的,具体实现流程如下:

图中MEP的Pod暴露了2个Service(其它Service如dnsserver等未列出),同时通过Multus使用默认Calico网络创建了Pod的默认网卡,MACVLAN驱动为该Pod另外创建两张网卡mp1和mm5,分别负责Mm5接口和Mp1接口的API调用。mep-mm5的Service虽然定义的是Mm5接口的Service,但实际调用的是MEP中默认的Calico网卡,而Pod中通过Macvlan创建的另一张Mm5网卡没有被其它应用或Service调用,不知道这个是EdgeGallery v1.5.2版本的Bug还是故意这么做的。

EdgeGallery代码重构裁剪

  1. Postgres向国产数据库迁移,包括所有使用数据库的组件代码修改,4人/月
  2. MECM,包含MEPM和MEO,因为暂时不做MEO,所以需要理清MEPM与B/OSS的交互流程,另外lcmcontroller和k8splugin问题较多,经常出现业务部署失败的情况,4人/月
  3. MEP,包含DNS Server、Kong、MEP Auth、MEP Server四个组件,目前该组件Bug较多,需要投入人力解决,2人/月
  4. Appstore,偶尔出现发布失败的问题,需要优化,1人/月
  5. Developer,Swagger界面无法使用的问题需要投入人力解决,1人/月
  6. ATP,无需重构,投入人力理解测试原理,1人/月
  7. User-Mgmt,无需重构
  8. 与5GC的联调,N33/N5/N6接口适配,2人/月
  9. 前端界面,包括Developer、MEPM、MECM、ATP、Appstore,部分界面已经弃用,需投入人力研究是否可以裁剪,2人/月
  10. 便捷部署,与Kubernetes适配,和信创操作系统适配,2人/月

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/494321.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Overcooked!(并查集区间元素合并优化)

本题链接:登录—专业IT笔试面试备考平台_牛客网登录—专业IT笔试面试备考平台_牛客网登录—专业IT笔试面试备考平台_牛客网 题目: 样例: 输入 5 5 1 1 2 3 1 2 2 2 4 3 1 4 3 2 5 输出 YES YES NO 思路: 根据题意,这…

KubeSphere简单介绍及安装使用

KubeSphere 概述 官网地址:https://kubesphere.io/zh/ 什么是 kubesphere KubeSphere 是一个开源的多云容器管理平台,旨在简化企业级 k8s 集群的部署、管理和运维。它提供了一个可视化的管理界面,帮助用户更轻松地管理和监控 k8s 集群&…

『Apisix进阶篇』动态负载均衡:APISIX的实战演练与策略应用

🚀『Apisix系列文章』探索新一代微服务体系下的API管理新范式与最佳实践 【点击此跳转】 📣读完这篇文章里你能收获到 🎯 掌握APISIX中多种负载均衡策略的原理及其适用场景。📈 学习如何通过APISIX的Admin API和Dashboard进行负…

设计模式——行为型——策略模式Strategy

Q:策略模式的特点 A: 具体算法从具体的业务方法中独立出来策略模式是同行为的不同实现 Q:什么时候使用策略模式 A:多个if-else使用策略模式 收费对象类 public class CashContext {private CashStrategy cashStrategy;public…

备考ICA----Istio实验10---为单个主机配置TLS Istio Ingress Gateway实验

备考ICA----Istio实验10—为单个主机配置 TLS Istio Ingress Gateway实验 1. 环境准备 部署httpbin kubectl apply -f istio/samples/httpbin/httpbin.yaml 2. 证书生成 2.1 生成根证书 生成根证书keyfile和crt文件 mkdir example_certs_root openssl req -x509 -sha256 …

Code Review 最佳实践

成功的同行评审策略要求严格记录的流程与非威胁性、协作性环境之间保持平衡。高度规范的同行评审可能会抑制生产力,然而,过于随意的流程往往效果不佳。经理们需要找到一种折中方案,使同行评审既高效又有效,同时促进团队成员之间的…

特斯拉铺路 小米SU7稳了

文 | AUTO芯球 作者 | 李逵 我把特斯拉的销售拉黑了 拉完又后悔了 因为我欠他一个人情啊 具体怎么回事 看完你就会明白了 今天一大早 特斯拉的销售就发信息给我 说从4月1号开始 特斯拉就要涨价了 我以前去看的Model Y 要提价5000块 而且之前的补贴 什么保险补贴、…

Tunes不能读取iPhone的内容,请前往iPhone偏好设置的摘要选项卡,然后单击恢复以将此iPhone恢复为出厂设置

重启itunes: 参考链接: https://baijiahao.baidu.com/s?id1642568736254330322&wfrspider&forpc 人工智能学习网站: https://chat.xutongbao.top

「媒体宣传」媒体邀约几种常见方法!-51媒体

传媒如春雨,润物细无声,大家好,我是51媒体网胡老师。 媒体邀约的常见方法确实包括电话邀约、邮件邀约、社交媒体邀约以及通过媒体公关公司代邀约等。 电话邀约:这是一种直接且高效的方式,可以通过电话与媒体记者沟通&…

FANUC机器人KAREL语言程序结构(入门)

一、karel语言程序结构 FANUC机器人keral语言编程结构如下图所示: Keral指令对应的基础用法如下所示: 二、创建一个简单的写屏程序 依照对应的karel语法写写入下列程序 运行对应的程序进行测试:

强化安全防护:升级桌面网管软件提升医院信息系统安全

在当今信息化发展的时代,医院作为重要的医疗服务机构,对终端设备的管理尤为重要。然而,随着国家对医院终端管理的要求日益提高,传统的桌面网管软件已经难以满足现代医院的需求。针对这一现状,升级桌面网管软件已成为当…

JVM(五)——类加载阶段

一、类加载阶段 一个类型从被加载到虚拟机内存中开始,到卸载出内存为止,它的整个生命周期将会经历加载 (Loading)、验证(Verification)、准备(Preparation)、解析(Resol…

HCIA-Datacom实验_03_实验一:华为VRP系统基本操作

1.运行eNSP,设置-界面设置-自定义界面-设备标签,“总显示接口标签” 打钩。 2.按照实验拓扑添加设备 注:如果是真实环境,需要接两条线: (1)串口线:电脑USB口到网络设备Console口&am…

第二篇:3.1 广告印象(AD Impression) - IAB与MRC及《增强现实广告效果测量指南1.0》

--- 我为什么要翻译美国IAB科技公司系列标准 翻译计划 第一篇概述—IAB与MRC及《增强现实广告效果测量指南》之目录、适用范围及术语第二篇广告效果测量定义和其他矩阵之- 3.1 广告印象(AD Impression)第三篇广告效果测量定义和其他矩阵之- 3.2 可见度 …

网络安全-提权篇

我们在文件包含的时候可以将错误的用户名包含进日志,但是权限问题让人很烦恼,今天的侧重点主要是跟大家聊一聊提权 用户名包含进日志参考:RCE with LFI and SSH Log Poisoning - Hacking Articles 目录 一、环境 二、看看权限(…

17、GateWay和Sentinel继承实现服务限流

注:本篇文章主要参考周阳老师讲解的cloud进行整理的! 1、需求说明 cloudalibaba-sentinel-gateway9528 保护 cloudalibaba-provider-payment9001 2、启动nacos服务器8848 startup.cmd -m standalone 3、启动sentinel服务器8080 java -jar sentinel-dash…

基于java实现学科竞赛管理系统【Springboot+mybatis+layui】

基于java实现学科竞赛管理系统【Springbootmybatislayui】 博主介绍:多年java开发经验,专注Java开发、定制、远程、文档编写指导等,csdn特邀作者、专注于Java技术领域 作者主页 央顺技术团队 Java毕设项目精品实战案例《1000套》 欢迎点赞 收藏 ⭐留言 文…

深入Facebook的世界:探索数字化社交的无限可能性

引言 随着数字化时代的到来,社交媒体平台已经成为了人们日常生活中不可或缺的一部分,而其中最为突出的代表之一便是Facebook。作为全球最大的社交媒体平台之一,Facebook不仅仅是一个社交网络,更是一个数字化社交的生态系统&#…

2024年云计算使用报告,89%组织用多云,25%广泛使用生成式AI,45%需要跨云数据集成,节省成本是云首要因素

备注:本文来自Flexera2024年的云现状调研报告的翻译。原报告地址: https://info.flexera.com/CM-REPORT-State-of-the-Cloud Flexera是一家专注于做SaaS的IT解决方案公司,有30年发展历史,5万名客户,1300名员工。Flex…

鸿蒙OS开发实例:【工具类封装-http请求】

import http from ohos.net.http; import promptAction from ohos.promptAction; 封装HTTP接口请求类,提供格式化的响应信息输出功能。 使用 DevEco Studio 3.1.1 Release 及以上版本,API 版本为 api 9 及以上。 示例: import { MyHttpUtil…