全部產品
Search
文件中心

Platform For AI:公網地址調用

更新時間:Jul 13, 2024

EAS支援使用通用公網對服務進行公網地址調用,通用公網調用又包括使用官方的Python SDK、Java SDK及自行實現調用邏輯三種方式。本文介紹詳細介紹每種調用方式的實現方法。

通用公網調用

在PAI-EAS部署模型服務後,系統會自動產生一個公網調用的服務地址。您可以在模型線上服務(EAS)頁面,單擊待調用服務服務方式列下的調用資訊,查看公網訪問地址調用文檔連結Token。通過該調用資訊可以進行調用測試,樣本如下。

$ curl http://166408185518****.cn-hangzhou.pai-eas.aliyuncs.com/api/predict/heart_predict_online -H 'Authorization: ZGI1YWYxNmQwYjMzMDM1YTNlMmFmNmEzYjIzZTVlZGQ0NDJhYTRm****' -d '[{"sex":0,"cp":0,"fbs":0,"restecg":0,"exang":0,"slop":0,"thal":0,"age":0,"trestbps":0,"chol":0,"thalach":0,"oldpeak":0,"ca":0}]'
說明

您可以將http替換成https,進行更安全的加密傳輸。

調用測試成功後,即可調用服務。為方便您調用服務,PAI-EAS提供了以下三種通用公網調用方式:

使用官方SDK調用(Python)

  1. 安裝。

    pip install -U eas-prediction --user

    該Python SDK的調用詳情請參見GitHub官網

  2. 編寫調用程式。

    以字串作為輸入輸出的程式為例,其他格式(TensorFlow或PyTorch等)的輸入輸出程式樣本請參見GitHub官網

    #!/usr/bin/env python
    from eas_prediction import PredictClient
    from eas_prediction import StringRequest
    if __name__ == '__main__':
        #下面的client = PredictClient()入參源於公網調用的訪問地址。
        client = PredictClient('http://166408185518****.cn-hangzhou.pai-eas.aliyuncs.com','heart_predict_online')
        #Token可以在公網地址調用資訊中擷取,詳情請參見通用公網調用部分。
        client.set_token('ZGI1YWYxNmQwYjMzMDM1YTNlMmFmNmEzYjIzZTVlZGQ0NDJhYTRm****')    
        client.init()
        #輸入請求需要根據模型進行構造,此處僅以字串作為輸入輸出的程式為例。
        request = StringRequest('[{"sex":0,"cp":0,"fbs":0,"restecg":0,"exang":0,"slop":0,"thal":0,"age":0,"trestbps":0,"chol":0,"thalach":0,"oldpeak":0,"ca":0}]')    
        for x in range(0, 1):
            resp = client.predict(request)
            print(resp)

    其中client = PredictClient()的函數入參源於公網調用的訪問地址。例如公網調用的訪問地址為http://166408185518****.cn-hangzhou.pai-eas.aliyuncs.com/api/predict/heart_predict_online,則PredictClient()函數的調用格式為client = PredictClient('http://166408185518****.cn-hangzhou.pai-eas.aliyuncs.com','heart_predict_online')

  3. 執行調用程式。

    $ python heart_predict.py

    其中heart_predict.py為Python程式的檔案名稱,需要根據實際情況修改。獲得的預測結果如下。

    IT-C02YJ0V8JHD2:Desktop wowei$ python heart_predict.py
    [{"p_0":0.9941226679708888,"p_1":0.005877332029111252}]

使用官方SDK調用(Java)

  1. 添加依賴包。

    因為編寫Java用戶端代碼需要使用Maven管理專案,所以需要在pom.xml檔案中添加用戶端依賴包eas-sdk。最新Release版本為2.0.1,程式碼範例如下。

    <dependency>
      <groupId>com.aliyun.openservices.eas</groupId>
      <artifactId>eas-sdk</artifactId>
      <version>2.0.1</version>
    </dependency>

    該Java SDK調用詳情請參見GitHub官網

  2. 編寫調用程式。

    以字串作為輸入輸出的程式為例,其他格式(TensorFlow或PyTorch等)的輸入輸出程式樣本請參見GitHub官網

    import com.aliyun.openservices.eas.predict.http.PredictClient;
    import com.aliyun.openservices.eas.predict.http.HttpConfig;
    public class Test_String {
        public static void main(String[] args) throws Exception{
            //啟動並初始化用戶端。        
            PredictClient client = new PredictClient(new HttpConfig());
            //Token可以在公網地址調用資訊中擷取,詳情請參見通用公網調用部分。    
            client.setToken("ZGI1YWYxNmQwYjMzMDM1YTNlMmFmNmEzYjIzZTVlZGQ0NDJhYTRm****");
            //下面的Endpoint資訊源於公網調用的訪問地址。
            client.setEndpoint("166408185518****.cn-hangzhou.pai-eas.aliyuncs.com");
            //佈建服務名稱。
            client.setModelName("heart_predict_online"); 
            //定義輸入字串。輸入請求需要根據模型進行構造,此處僅以字串作為輸入輸出的程式為例。
            String request = "[{\"sex\":0,\"cp\":0,\"fbs\":0,\"restecg\":0,\"exang\":0,\"slop\":0,\"thal\":0,\"age\":0,\"trestbps\":0,\"chol\":0,\"thalach\":0,\"oldpeak\":0,\"ca\":0}]";
            System.out.println(request);  
            //通過PAI-EAS返回字串。      
            try {
                String response = client.predict(request);
                System.out.println(response);
            } catch(Exception e) {
                e.printStackTrace();
            }
            //關閉用戶端。
            client.shutdown();
            return;
        }
    }

    其中 client.setEndpoint()client.setModelName()的函數入參源於公網調用的訪問地址。例如公網調用的訪問地址為http://166408185518****.cn-hangzhou.pai-eas.aliyuncs.com/api/predict/heart_predict_online,則 client.setEndpoint()函數的調用格式為client.setEndpoint("166408185518****.cn-hangzhou.pai-eas.aliyuncs.com")client.setModelName()函數的調用格式為client.setModelName("heart_predict_online")

  3. 執行調用程式。

    執行調用邏輯程式可以獲得如下結果。

    [{"p_0":0.9941226679708888,"p_1":0.005877332029111252}]

自行實現調用邏輯

PAI-EAS支援使用Python、Java或其他語言自行實現調用邏輯,您需要根據不同架構構建服務要求,詳情請參見構建通用Processor服務要求。編寫調用邏輯的樣本如下。

import requests
#URL資訊可以在公網地址調用資訊中擷取,詳情請參見通用公網調用部分。
url = 'http://166408185518****.cn-hangzhou.pai-eas.aliyuncs.com/api/predict/heart_predict_online'
#header資訊(Token)可以在公網地址調用資訊中擷取,詳情請參見通用公網調用部分。
headers = {"Authorization": 'ZGI1YWYxNmQwYjMzMDM1YTNlMmFmNmEzYjIzZTVlZGQ0NDJhYTRm****'}
#根據具體模型要求的資料格式構造服務要求,此處僅以字串作為輸入輸出的程式為例。
data = '[{"sex":0,"cp":0,"fbs":0,"restecg":0,"exang":0,"slop":0,"thal":0,"age":0,"trestbps":0,"chol":0,"thalach":0,"oldpeak":0,"ca":0}]'
resp = requests.post(url, data=data, headers=headers)
print(resp)
print(resp.content)