Skip to main content
Version: apisix-3.11.0

Example

This example is used for functional verification and is not recommended for performance testing. For performance testing, please refer to benchmark.

Run#

docker-compose -d

Configure#

curl http://127.0.0.1:9180/apisix/admin/services/1 -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PUT -d '
{
"upstream": {
"type": "roundrobin",
"nodes": {
"web1:80": 1
}
}
}'

curl http://127.0.0.1:9180/apisix/admin/services/2 -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PUT -d '
{
"upstream": {
"type": "roundrobin",
"nodes": {
"web2:80": 1
}
}
}'

curl http://127.0.0.1:9180/apisix/admin/routes/12 -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PUT -d '
{
"uri": "/*",
"host": "web1.lvh.me",
"service_id": "1"
}'

curl http://127.0.0.1:9180/apisix/admin/routes/22 -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PUT -d '
{
"uri": "/*",
"host": "web2.lvh.me",
"service_id": "2"
}'

curl http://127.0.0.1:9180/apisix/admin/ssl/1 -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PUT -d "
{
\"cert\": \"$( cat './mkcert/lvh.me+1.pem')\",
\"key\": \"$( cat './mkcert/lvh.me+1-key.pem')\",
\"sni\": \"lvh.me\"
}"

curl http://127.0.0.1:9180/apisix/admin/ssl/2 -H 'X-API-KEY: edd1c9f034335f136f87ad84b625c8f1' -X PUT -d "
{
\"cert\": \"$( cat './mkcert/lvh.me+1.pem')\",
\"key\": \"$( cat './mkcert/lvh.me+1-key.pem')\",
\"sni\": \"*.lvh.me\"
}"

Test#

When testing subdomains, using localhost is not a good option. Due to this, lets use http://lvh.me/ free service to resolve itself along with all subdomains to localhost.

curl http://web1.lvh.me:9080/hello -v # hello web1

curl http://web2.lvh.me:9080/hello -v # hello web2
curl https://web1.lvh.me:9443/ -v --cacert ./mkcert/rootCA.pem

Clean#

docker-compose down

sudo rm -rf etcd_data/member

rm -rf apisix_log/*.log