开源软件名称(OpenSource Name):aus-social/mastodon-aws
开源软件地址(OpenSource Url):https://github.com/aus-social/mastodon-aws
开源编程语言(OpenSource Language):
开源软件介绍(OpenSource Introduction):AWS Cloudformation Stack - End to End deployment
- 1x EC2 Server (Dockerised Mastodon Instance)
- 1x RDS PostgreSQL (for Database)
- 1 x ElasticCache Redis (for shared cache)
- 1 x S3 Bucket for storage (with IAM user account linked)
Installation Guide
- Setup a new Route53 zone and forward the domain nameservers correctly.
- Register with mailgun.com and setup required DNS records for approval.
- Create the AWS CFN Stack with the required details.
- Register an account on your instance (log in and promote as admin using cli)
Troubleshooting
User-data/meta-data debug information is stored in /var/tmp/bootstrap.txt - /var/tmp$ tail -f /var/tmp/bootstrap.txt
TODO
- Setup scheduled tasks (documentation related to recommend tasks is slim)
- Automate creation of admin account (task is currently interactive only)
- 1 x ElasticSearch [Optional] (for full text search)
- KMS for at-rest encryption
- EIP for dedicated Public IP.
Cost
-
EC2 Instance: $16.79 (t2.small)
-
S3 Bucket: $5-$100
-
ElasticCache: $13.14 (cache.t2.micro)
-
RDS PostgreSQL: $13.14 (db.t2.micro)
-
Monthly cost estimated at: $50~ a month
- I'm running my https://aus.social instance on t2.small instances and we're almost at 100 active users.
- While much more expensive than digital ocean but much more stable with lower techdebt due to the managed services (RDS/ElasticCache).
Automation steps
- Creates ec2 instance (t2.small can support hundreds of users)
- Installs Ubuntu 18.04
- Installs supporting packages
- Installs all updates
- TODO: Install held AWS packages
- --
- Setups DNS record on Route53
- Creates mastodon user
- Installs docker
- Installs docker-compose
- Setups swap
- --
- clones mastodon
- tweaks docker-compose.yml
- creates .env.production
- builds docker images
- prepares the DB
- precompiles assets
- boots docker
- --
- Installs nginx
- configures nginx
- Installs certbot for LetsEncypt TLS
- --
- Reboots box
|
请发表评论