AWS Machine Image Setup Instructions
This guide will walk you through setting up an instance of the HTML/PDF to ZPL API Server in your private AWS cloud.
Step 1: Login to AWS console
Login to your AWS console, navigate to EC2 Instances, and click on Launch Instance.
Step 2: Configure the EC2 Instance
-
Name: Assign a name of your choice for the new EC2 instance.
-
AMI: Select the AMI shared with your account. Navigate to My AMIs, choose Shared with me, and select the
zpl-api
AMI. Contact support if the AMI is not present. -
Instance Type: Choose your instance type based on performance needs. The instance type
t3.medium
or larger is recommended. -
Key Pair (Login): Select an existing key pair, or choose Proceed without a key pair.
Note that logins are usually not required. You will only need a key pair if you plan on modifying any advanced settings.
data:image/s3,"s3://crabby-images/d56b9/d56b98c20a0c206a51427a7c02a1b17ac9538dcb" alt="EC2 Keypair settings"
- Network Settings:
Configure according to your infrastructure. Do not assign a public IP address.
Firewall & Security group settings: The API server is available via TCP port8000
. Create a new security group and adjust the firewall settings in a later step.
data:image/s3,"s3://crabby-images/f9b7e/f9b7e1e6987efd844dd2f84bd79b96c3556432c3" alt="EC2 Network Settings"
- Storage: The storage settings are automatically defaulted. It is not necessary to change these settings.
1x 40 GiB gp3 Root Volume
data:image/s3,"s3://crabby-images/695b5/695b5ee9dae8497fc01118a32a16e5fd1c63f36c" alt="EC2 Storage Settings"
- Launch Instance:: Click on the Launch Instance button. The API server is now initializing and will be available within a few minutes.
Step 3: Adjust Security Group (Firewall Settings)
Adjust the newly created security group to allow connections on TCP port 8000
:
- Open the new instance, navigate to the Security tab, and click on the newly created Security Group.
data:image/s3,"s3://crabby-images/ec831/ec831b4b9a64be352d8c8ead4ea704268997c0f4" alt="EC2 Security Group Settings"
- Click on Edit inbound rules.
data:image/s3,"s3://crabby-images/b0b82/b0b828386132563cdcb3dd4b201273828d7c90bf" alt="EC2 Security Group: Inbound Rules Settings"
- Add a rule to allow TCP connections on port 8000, according to your networking setup. For example, to allow connections from any IP address in the 10.0.0.0 - 10.255.255.255 range, add a source
10.0.0.0/8
.
data:image/s3,"s3://crabby-images/27308/27308da49d5a029611fe74afc07e4160308c76d1" alt="EC2 Security Group Settings: Add network rules"
Testing of the API Server
With the server up, you can test it by running a request from a bastion host:
# Replace IP_ADDRESS below with your server's IP
curl -X POST \
-H "Content-Type: application/json" \
-d '{ "width":"4", "height":"6", "html":"Hello World" }' \
http://IP_ADDRESS:8000/htmltozpl
data:image/s3,"s3://crabby-images/06df9/06df96a3131f6f167fc0567782ed91b584806f44" alt="Test results from a PDF to ZPL conversion"