Open Service APIs For Aliyun API Gateway
1. Experiment
1.1 Knowledge points
In this experiment, Alibaba Cloud API Gateway is used. This experiment demonstrates the process of connecting services to API Gateway. API Gateway provides high-performance and high-availability API hosting services to help expose your applications that are deployed on Alibaba Cloud products, such as ECS and Container Service. API Gateway allows you to publish and manage APIs, and maintain their lifecycles. You can perform simple operations to make data or services public rapidly, cost-effectively, and safely.
1.2 Experiment process
- Deploy Django.
- Create API Gateway.
1.3 Required cloud resources
1.4 Prerequisites
- If you are using your own Alibaba Cloud account instead of the account provided by this lab for this experiment, be sure to choose the same Ubuntu 16.04 operating system for your ECS in order to run the experiment smoothly.
- Before starting the experiment, confirm that the previous experiment has been normally closed and exited.
2. Start the experiment environment
Click Start Lab in the upper-right corner of the page to start the experiment.
.
After the experiment environment is started, the system has deployed resources required by this experiment in the background, including the ECS instance, RDS instance, Server Load Balancer (SLB) instance, and OSS bucket. An account consisting of the username and password for logging on to the Alibaba Cloud console is also provided.
data:image/s3,"s3://crabby-images/a458b/a458bbce69314bbff9600cbec260468df83ae777" alt="image desc"
After the experiment environment is started and related resources are deployed, an experiment countdown starts. You have two hours to perform experimental operations. After the countdown ends, the experiment stops and related resources are released. During the experiment, pay attention to the remaining time and arrange your time wisely. Use the username and password provided by the system to log on to the Alibaba Cloud console and view related resources:
data:image/s3,"s3://crabby-images/a0da1/a0da1a194cee7342d87baa97cf4ad513f0c2a97f" alt="openCole"
Go to the logon page of the Alibaba Cloud console.
data:image/s3,"s3://crabby-images/bdd88/bdd885f4f332e53c4c8f0947d061ef8935051f27" alt="image desc"
Enter the sub-user account and click Next.
data:image/s3,"s3://crabby-images/068c3/068c31a067596fd898385d32c4de1880ba3a7f6d" alt="image desc"
Enter the sub-user password and click Log on.
data:image/s3,"s3://crabby-images/bc761/bc761a6d7e7c6e417834d2b8f2cc28e346a76d92" alt="image desc"
After you log on to the console, the following page appears.
data:image/s3,"s3://crabby-images/1b7d6/1b7d6957e888a4e13fb405a23b44b1278ecdacae" alt="image desc"
3. Deploy Django
3.1 Log on to an ECS instance
Click Elastic Compute Service, as shown in the following figure.
data:image/s3,"s3://crabby-images/4f3db/4f3db9600508dfaeaf164d6c8dca10cdd55c16b7" alt="image desc"
We can see one running ECS instance in the US West 1 region.
data:image/s3,"s3://crabby-images/cc448/cc448a515acf4673e4b4adf887f65f5962ba4b59" alt="image desc"
Copy this ECS instance’s Internet IP address and remotely log on to this ECS (Ubuntu system) instance. For details of remote login, refer to login。
data:image/s3,"s3://crabby-images/c1cc7/c1cc7357d3ceda7a4e94b6d7676b9347182df8f7" alt="image desc"
The default account name and password of the ECS instance:
Account name: root
Password: nkYHG890..
3.2 Install Django
After you log on, run the following command to update the APT installation source:
apt update
data:image/s3,"s3://crabby-images/60bb4/60bb437e0c04c01787178aabde4d854950ebd69d" alt="image desc"
Run the following command to install Django:
apt install -y python3-pip && pip3 install Django==2.2.7
data:image/s3,"s3://crabby-images/50181/50181ce492330797830c215683661cfebf2589f0" alt="image desc"
Run the following command to create a Django project named Labex:
django-admin startproject Labex
data:image/s3,"s3://crabby-images/10b24/10b249c3c2748f837d325a7645ebe611d360b522" alt="image desc"
Run the following command to create an app named aliyun in the Labex project:
cd Labex && django-admin startapp aliyun
data:image/s3,"s3://crabby-images/7be94/7be948de776c98bc199fc1f38ffb597d5da7a107" alt="image desc"
Run the following command to configure the default database for the Labex project:
python3 manage.py migrate
data:image/s3,"s3://crabby-images/2e4cb/2e4cbb6d6a63d34c1989a887f16021830cb23e3c" alt="image desc"
Run the vim Labex/settings.py
command to open the configuration file of the Labex project and modify the settings, as shown in the following figure. Save the modifications and exit.
data:image/s3,"s3://crabby-images/9d49f/9d49f9749811e4322550e66fb0c261e9e7f14e13" alt="image desc"
Run the vim aliyun/views.py
command, delete the source content in the file, and copy the following content to the file. Save the modifications and exit.
This file defines the functions that are used to receive and process client requests.
from django.shortcuts import render
from django.http import HttpResponse
# Create your views here.
def show(request):
return HttpResponse("<h1>this is aliyun app</h1>")
def add(request):
a = request.GET['a']
b = request.GET['b']
c = int(a) + int(b)
return HttpResponse(str(c))
def subtract(request):
a = request.GET.get('a','none_a')
b = request.POST.get('b','none_b')
c = int(a) - int(b)
return HttpResponse(str(c))
data:image/s3,"s3://crabby-images/3f319/3f319bd958c0852d8a02efb324588e4f2b32d8d7" alt="image desc"
Run the vim Labex/urls.py
command to open the URL file of the Labex project and modify the file, as shown in the following figure. Save the modifications and exit.
from aliyun import views
path('', views.show),
path('add/', views.add, name='add'),
path('subtract/', views.subtract, name='subtract'),
data:image/s3,"s3://crabby-images/f9f90/f9f907e0842e190770614f2428b28f9618c6ec27" alt="image desc"
Run the following command to start Django:
python3 manage.py runserver 0.0.0.0:80
data:image/s3,"s3://crabby-images/03e2f/03e2f3d0cd76c2552f88e5d0744d00384724c14f" alt="image desc"
4. Create API Gateway
4.1 Create an API group
Return to the Alibaba Cloud console and access the API Gateway console, as shown in the following figure.
data:image/s3,"s3://crabby-images/98a95/98a95c89878b7b589945dec4ea80ba261ae0872f" alt="image desc"
data:image/s3,"s3://crabby-images/1bc83/1bc83b95dfec9ba2b558848f4bfb52c4584092df" alt="image desc"
Create an API group, as shown in the following figure.
data:image/s3,"s3://crabby-images/3cf30/3cf304da4c42a6d3c7825202ec93d18cd77cf92c" alt="image desc"
Set Group Name and click Confirm.
data:image/s3,"s3://crabby-images/abcfa/abcfa5510e0066fc21d5b863f1cce8bfe8e1a6cf" alt="image desc"
Click OK.
data:image/s3,"s3://crabby-images/c81a1/c81a101e359a36454118e30d39e749396de99bf0" alt="image desc"
data:image/s3,"s3://crabby-images/4c5e6/4c5e6b32a8266fcd8e95e690f6b96185dadfb0da" alt="image desc"
4.2 Create a VPC access
Create a Virtual Private Cloud (VPC) access, as shown in the following figure.
data:image/s3,"s3://crabby-images/8c792/8c792da235d6d532b4e14dece81c5d52a2e8211a" alt="image desc"
Set VPC Access Name, VPC Id, Instance Id Or IP, and Instance Port, and click Confirm, as shown in the following figure.
data:image/s3,"s3://crabby-images/de4cc/de4cc923c853b0ecc6c7e87e51d4943d5e3b1506" alt="image desc"
Click VPC instances, as shown in the preceding figure. On the page that appears, obtain the VPC ID, as shown in the following figure.
data:image/s3,"s3://crabby-images/c5136/c513665d359268ef62e90c9b204356d5a388ae85" alt="image desc"
Obtain the ECS ID, as shown in the following figure.
data:image/s3,"s3://crabby-images/97f30/97f307578abbe68b24a1a65ee3cce9f7369b271c" alt="image desc"
Create success.
data:image/s3,"s3://crabby-images/90d45/90d45fbf769b3ab54cb2c0c03449a56a8558ab02" alt="image desc"
4.3 Create an API
Create an API to receive parameters in the GET request, as shown in the following figure.
data:image/s3,"s3://crabby-images/b01c4/b01c4ad345cbf18b213bdee316160321f8cc0c3b" alt="image desc"
Set Group, API Name, and Security Certification, and then click Next.
data:image/s3,"s3://crabby-images/2b4e6/2b4e67916e275de34d11cf3f06e72b849cac0546" alt="image desc"
Set the frontend request path and parameters of the API, and then click Next.
data:image/s3,"s3://crabby-images/88d25/88d25b0db68604f1eb137b49e56638fe21641e94" alt="image desc"
Set the backend request path and parameters of the API, enter the name of the created VPC access, and click Next.
data:image/s3,"s3://crabby-images/bb26f/bb26f7a4cce5a9c05b9c183de04775ab36572eed" alt="image desc"
Click Create.
data:image/s3,"s3://crabby-images/681fd/681fdffb817a6a6f42e76fe77dcde3008221aaa5" alt="image desc"
Click Confirm.
data:image/s3,"s3://crabby-images/eeb3e/eeb3e51b61f3d474dd73c8cf51f1fb0f232cf8eb" alt="image desc"
You can see that the API has been created. Then, click Publish.
data:image/s3,"s3://crabby-images/faff8/faff8e53eb9a4f84d2c2d9c8624dd1fa78a60c61" alt="image desc"
Select Test, enter test online in the Enter Change Remarks field, and click Publish to publish the API in the test environment, as shown in the following figure.
data:image/s3,"s3://crabby-images/610f8/610f87704d380cac8a0ad2edfe6aad6375092818" alt="image desc"
You can see that the API has been published in the test environment.
data:image/s3,"s3://crabby-images/b7ace/b7aced939b952839f8bb2d6956658ba3f31370d3" alt="image desc"
Create the second API to receive parameters in both the GET and POST requests.
Click Create API.
data:image/s3,"s3://crabby-images/d9780/d9780c85ac340e3a75bccf9f75288a7fd6653f75" alt="image desc"
Set API Name and click Next.
data:image/s3,"s3://crabby-images/60c27/60c270230e85481a0bb97d8695fde387d8496df4" alt="image desc"
Set the frontend request path and parameters, with one parameter as the Query parameter and the other as the Body parameter. Set HTTP Method to POST and click Next.
data:image/s3,"s3://crabby-images/31aa9/31aa95cff33e3710026d0d71a2a97c681c1d35db" alt="image desc"
Set the backend request path and parameters.
data:image/s3,"s3://crabby-images/b99ff/b99ff1b00813b1f379ef833008da75ffb39cf8f8" alt="image desc"
Click Next.
data:image/s3,"s3://crabby-images/a10f9/a10f9feb40d7c4950159b719075449d82646342d" alt="image desc"
Click Create.
data:image/s3,"s3://crabby-images/e8830/e883062eec669e8a1870ddd0ca3b2a5812bf14bd" alt="image desc"
Publish api2 in the test environment with the same method.
data:image/s3,"s3://crabby-images/4482e/4482e513904cb264f8c360559b739cd25d485968" alt="image desc"
4.4 Authorize an app
To test whether the APIs can be normally used, create an app.
data:image/s3,"s3://crabby-images/bae8e/bae8e5c3ad959ff8517396a52df85285c23be0fc" alt="image desc"
Set APP Name and click Confirm.
data:image/s3,"s3://crabby-images/7166f/7166fe8a9a040bdd93f4efee8799ce89ee4aeeaa" alt="image desc"
Click Confirm.
data:image/s3,"s3://crabby-images/afea6/afea6104fa68d406ec6e67b770c2c4f964658409" alt="image desc"
You can access the corresponding API only after authorizing the app.
Authorize labex_app to use api1 first.
data:image/s3,"s3://crabby-images/73033/73033b5e8b5370cd15f4b3317991682811d5b458" alt="image desc"
Select Test, enter the keyword in the search box, click Search, and then click Add. api1 is published in the test environment. If api1 is published in the production environment, select Release.
data:image/s3,"s3://crabby-images/6e5a9/6e5a9c0a697f98d39844cd30bb289be738e41d40" alt="image desc"
After the app is added, click Confirm.
data:image/s3,"s3://crabby-images/35403/3540317302a1cdc10a7decd150b3f900cacbd7de" alt="image desc"
Use the same method to authorize labex_app to use api2.
4.5 Call APIs
After the app is authorized to use both APIs, click the app name to go to the APP details page.
data:image/s3,"s3://crabby-images/f94f5/f94f5550336a8ea5327d1231833df6d2d8cf19e0" alt="image desc"
You can see both APIs. Click Debug API for api1.
data:image/s3,"s3://crabby-images/1ff0a/1ff0a02e90bce3976d52e0222881e0b0accd480a" alt="image desc"
Enter any two numbers in the text boxes of the Query parameters and click Send Request, as shown in the following figure.
data:image/s3,"s3://crabby-images/de4dd/de4ddf18be67dc2fdca96996f37117ad942da092" alt="image desc"
You can see that the response failed.
data:image/s3,"s3://crabby-images/f0fe6/f0fe69ed16b38a759cfd065e568fd01c569ee97f" alt="image desc"
Return to the CLI of ECS instances. The following errors occur on the Django server. Note the IP address in the following error information, which needs to be added to the Django configuration file later.
data:image/s3,"s3://crabby-images/3cd89/3cd8998b2dae771bd770aeb568b86e94c6a44abb" alt="image desc"
Press Ctrl+C to stop the service.
data:image/s3,"s3://crabby-images/29e9e/29e9e371b459e68df8c991c97e33430a7566820a" alt="image desc"
Run the vim Labex/settings.py
command to open the Django configuration file, and add the noted IP address to the file, as shown in the following figure. Save the modification and exit.
data:image/s3,"s3://crabby-images/3f9eb/3f9eb4902e4e1829022408e3832ec87a6582357a" alt="image desc"
Run the following command to start Django:
python3 manage.py runserver 0.0.0.0:80
data:image/s3,"s3://crabby-images/38cc3/38cc39136b4ea235f0c9d1c19e73b3ab9decf371" alt="image desc"
Return to the Alibaba Cloud console and click Send Request again. You can see a normal response this time.
data:image/s3,"s3://crabby-images/ef4d9/ef4d93b7c184bb4ccaff4ae77080048a45d9b9e7" alt="image desc"
<font color='red'>The user can cut off the above result picture when doing the experiment and send it to the teacher, indicating that the part of the current chapter has been completed.</font>
Click Debug API for api2.
data:image/s3,"s3://crabby-images/18dce/18dceb11f5c4c7f4205de1f870dbbafe67b442cd" alt="image desc"
Set the Query and Body parameters and click Send Request. You can see the response.
data:image/s3,"s3://crabby-images/f952f/f952f71f2adeaabcefcbeff7ab2be30e43b7d292" alt="image desc"
Now, the APIs have been successfully called.
<font color='red'>Users can cut off the above result picture when they are doing the experiment and send it to the teacher, indicating that the current experiment has been completed.</font>
Tips:
Before you leave this lab, remember to log out from your Alibaba RAM account before clicking the stop button of your lab. Otherwise, you will encounter some issues when opening a new lab session in the same browser.
data:image/s3,"s3://crabby-images/a1dbb/a1dbb117391df469534486354c59fb85c57ba59e" alt="image desc"
data:image/s3,"s3://crabby-images/72fb8/72fb856c272066ef3b466c977e1bd7b2bf5565bc" alt="image desc"
5. Experiment summary
This experiment demonstrates the process of connecting services to API Gateway. Alibaba Cloud API Gateway uses a distributed deployment and automatic scaling model to respond to a large number of API access requests with very low latency. It provides highly secure and efficient gateway functions for your backend services. API Gateway can also handle complex transactions, such as API reference maintenance, SDK maintenance, and API version management. This greatly reduces daily maintenance costs.