Launch Your First API
This tutorial describes launching and validating a simple API on API7 Gateway. You will complete the following steps:
- Create a Published Service with a Route and an Upstream that points to
httpbin
upstream. - Validate the created API by sending a request.
Prerequisites
Start a Sample Upstream Service
If you are running API7 on Kubernetes, you will be deploying an httpbin application to your cluster in this section as the sample upstream service. Otherwise, skip to the next section where you will be using the hosted httpbin application as the upstream.
Start a sample httpbin application:
kubectl run httpbin --image kennethreitz/httpbin --port 80
You should see a pod/httpbin created
response.
Expose the application's port 80
through a service:
kubectl expose pod httpbin --port 80
You should see a service/httpbin exposed
response.
Create Service and Route
- Dashboard
- ADC
- Ingress Controller
Create a Service
- Select Published Services under your gateway group from the side navigation bar and then click Add Service.
- Select Add Manually.
- From the Add Service dialog box, do the following:
- In the Name field, enter
httpbin
. - In the Service Type field, choose
HTTP (Layer 7 Proxy)
. - In the Upstream Scheme field, choose
HTTP
. - In the How to find the upstream field, choose
Use Nodes
. - Click Add Node.
- From the Add Node dialog box, do the following:
- In the Host field, enter
httpbin.org
. - In the Port field, enter
80
. - In the Weight field, enter
100
.
- In the Host field, enter
- In the Name field, enter
- Click Add. This will create a new service in the 'No Version' state.
Create a Route
- Click the service that you just created in the previous step, and then click Add Route.
- From the Add Route dialog box, do the following:
- In the Name field, enter
getting-started-ip
. - In the Path field, enter
/ip
. - In the Methods field, choose
GET
. - Click Add.
- In the Name field, enter
Below is an interactive demo that provides a hands-on introduction to creating no-version services. You will better understand how to use it in API7 Enterprise by clicking and following the steps.
Create the following configuration file:
services:
- name: httpbin
upstream:
name: default
scheme: http
nodes:
- host: httpbin.org
port: 80
weight: 100
routes:
- uris:
- /ip
name: getting-started-ip
methods:
- GET
Synchronize the configuration to API7 Enterprise:
adc sync -f adc.yaml
Create a configuration file containing the API7 Ingress Controller custom resource of a route:
apiVersion: apisix.apache.org/v2
kind: ApisixRoute
metadata:
name: httpbin-route
namespace: api7
spec:
http:
- name: httpbin-route
match:
paths:
- /ip
backends:
- serviceName: httpbin
servicePort: 80
Apply the configuration to your cluster:
kubectl apply -f httpbin-route.yaml
You should see a response of the following:
apisixroute.apisix.apache.org/httpbin-route created
Validate the API
- Dashboard
- ADC
- Ingress Controller
Send a request to the route:
curl "http://127.0.0.1:9080/ip"
You should see the following response:
{
"origin": "127.0.0.1"
}
Send a request to the route:
curl "http://127.0.0.1:9080/ip"
You should see the following response:
{
"origin": "127.0.0.1"
}
In the dashboard, you should see a service called api7_httpbin_80
under the Published Services.
First, expose the service port to your local machine by port forwarding:
kubectl port-forward svc/api7-ee-3-gateway-gateway 9080:80 &
The command above runs in the background and maps port 80
of the api7-ee-3-gateway-gateway
service to port 9080
on the local machine.
Send a request to the route:
curl "http://127.0.0.1:9080/ip"
You should see a response similar to the following:
{
"origin": "127.0.0.1"
}
And that’s it. You have your first API running now.
Add APIs by Importing OpenAPI
You can also add APIs by importing OpenAPI 3.0 specification.
Create a Service
- Select Published Services under your gateway group from the side navigation bar and then click Add Service.
- Select Import OpenAPI.
- From the Add Service dialog box, do the following:
- In the OpenAPI 3.0 Specification field, upload
httpbin.yaml
file. - In the Upstream Scheme and Service Type fields, keep the default settings
HTTP
. - In the How to find the upstream field, keep the default setting
Use Nodes
. - Click Add Node.
- From the Add Node dialog box, do the following:
- In the Host field, enter
httpbin.org
. - In the Port field, enter
80
. - In the Weight field, enter
100
.
- In the Host field, enter
- Click Next.
- In the OpenAPI 3.0 Specification field, upload
- Click Add. This will create a new service in the 'No Version' state. The basic information, labels are imported, and all paths in the openapi file are transformed to routes in the service.
Below is an interactive demo that provides a hands-on introduction to adding services by importing OpenAPI. You will better understand how to use it in API7 Enterprise by clicking and following the steps.
Additional Resources
- Getting Started
- Best Practices