If you are aiming for a production setup you should use ECS.
We will be using Docker on EC2 to deploy in this post.
Launch an EC2 instance
Log into your AWS Console, click the EC2 link to go to the EC2 Console, and click the blue “Launch Instance” button:
On the next page, you need to pick an Amazon Machine Image (AMI) to run on your EC2 Instance. For this tutorial, just pick the top option, which is the Ubuntu Server 16.04 LTS :
Next, you need to pick the Instance Type, which determines what kind of CPU, memory, storage, and network capacity your server will have. Stick with the default option, t2.micro, and click the gray “Next: Configure Instance Details” button:
In the Instance Details configuration, make sure to choose the same VPC that is used by your RDS instance.
Then keep clicking “Next” until you get to the “Configure Security Group” page. A Security Group is a set of firewall rules that control network traffic for your instance. By default, all incoming ports are blocked, so use this page to add rules that allow incoming SSH (TCP, port 22), HTTP (TCP, port 80) and HTTPS (TCP, port 443) requests from any source (0.0.0.0/0). Give the Security Group a name such as graphql-engine-test-sg, and click the blue “Review and Launch” button:
On the “Review Instance Launch” page, click the blue “Launch” button. This will pop up a modal that asks you to pick a Key Pair. This used to connect to your EC2 instance over SSH. Select “create a new key pair” from the drop-down, give the Key Pair a name like my-ec2-key-pair, and click “Download Key Pair”:
NOTE: Save the Key Pair .pem file to a safe and accessible location on your computer (once you close this modal, you will never be able to download this .pem file again, so make sure to save it!).
Now if you go to your EC2 dashboard, you should see your EC2 instances running.
Installing Docker
The next step is to install Docker on your EC2 Instance. Open a terminal, cd over to the folder where you saved your Key Pair, and run the following commands:
Then let’s add this user to the docker group, so we can run docker commands without sudo:
$ sudo usermod -a -G docker ubuntu
Exit the shell and login again. Check if docker works:
$ exit
$ ssh -i my-ec2-key-pair.pem ubuntu@<EC2-INSTANCE-PUBLIC-IP-ADDRESS>
$ docker info
Deploying Hasura GraphQL Engine
Save the following docker-compose snippet into file docker-compose.yaml
Change the HASURA_GRAPHQL_DATABASE_URL to point to your RDS instance, and HASURA_GRAPHQL_ACCESS_KEY to a long random string.
Then run:
$ docker-compose up -d
Check if the container is running:
$ docker ps
CONTAINER ID IMAGE ... CREATED STATUS PORTS ...
097f58433a2b hasura/graphql-engine ... 1m ago Up 1m 8080->8080/tcp ...
The status should be "Up". If the status is not up, check logs with docker logs <container-id>
Access GraphQL engine console
Now go to the public IP address of the EC2 instance on your browser and it should open up the Hasura console.
It should prompt for the access key, enter the access key you used in the above steps. Access the console and make GraphQL queries!
Troubleshooting
If you can't access the console, check the GraphQL Engine docker logs. By running docker logs <container-id>.
Postgres connection failed / Connection refused
If the public IP is not accessible, check the docker logs. If the logs say postgres connection failed or something along those lines, it is most likely a security group issue. You would have to edit the security-group associated with the RDS instance.
Go to the security-group of the RDS instance, and then to the "Inbound" rules. Click on "Edit", and then click on "Add Rule". Select "PostgreSQL" from the type dropdown and add the Private IP of your EC2 instance. You have to add it in a CIDR format, so it should be x.x.x.x/32. Then click "Save". Now check the logs again if graphql-engine sucessfully connects to the RDS instance.