AWS is an online platform that provides scalable and cost-effective cloud solutions.
Servers are placed across the whole world inside 25 AWS regions, and 215 availability zones for disaster recovery purposes.
It is a pay-as-you-go pricing system, which means that you pay for the amount of usage.
Scalability (horizontal and vertical), high availability, performance, security, reliability are some of the features that AWS provides.
Amazon Elastic Compute Cloud (Amazon EC2) provides scalable computing capacity in the AWS Cloud. You can use Amazon EC2 to launch as many or as few virtual servers as you need, configure security and networking, and manage storage.
When you reserve an instance you need to choose an instance type that consists of instance family and instance size.
Each family is optimized for some workflow, and based on your setup you should choose the appropriate one.
For scaling purposes, AWS provides Auto Scaling Groups(ASG) and Load Balancers.
When defining ASG, you define the minimum, desired and maximum number of instances, AWS will add or remove instances based on your configuration example when the CPU reaches over 80%.
A load balancer is used for intelligent routing or requests, it can be internet-facing ( public ) or internal ( between private instances)
VPC is the main representative of this group. In the example above we defined a simple VPC with a private and public subnet. Internet-facing servers are configured in a public subnet, and private servers are not exposed to the internet, and so put inside a private subnet.
Nat gateway is one of the possibilities to provide internet to private servers without exposing them to the internet.
Route tables are used for request redirection inside VPC.
In this example, it is demonstrated how security inside VPC is handled. Before each subnet, we have Access Control Lists ( ACL) where we define inbound and outbound rules for accessing the subnet. The second level of security is Security groups, which are checked before reaching concrete instances or instances.
IAM is the main representative of this group.
It is defined by Users, Groups, and Roles, each one of them can have attached permissions to it, and you can assign users to groups or add them roles.
To do some action on AWS, you need to have permission for it. It is defined by “least privilege” which means that by default users don’t have rights to anything and you need to specify and add one that you want to provide them with.
A typical architecture for serverless development:
Mock example of Facebook architecture on AWS:
We are looking for a Senior Blockchain Developer with 5+ years of experience who will join our team.
Your core skills are:
Requirements:
What We Offer:
If you’re ready to take on exciting challenges and grow your career with a supportive and innovative team, we’d love to hear from you!
We are looking for a Senior Full Stack Developer with 5+ years of experience who will join our team.
Your core skills are:
Requirements:
We can give you a fair amount of great benefits such as:
Feel free to apply for the job if you think we are a perfect match!
We are looking for a Senior iOS Developer with 5+ years of experience who will join our team.
Your core skills are:
Requirements:
We can give you a fair amount of great benefits such as:
Feel free to apply for the job if you think we are a perfect match!
We are looking for a Senior .NET Developer with 5+ years of experience who will join our team.
Your core skills are:
Requirements:
We can give you a fair amount of great benefits such as:
Feel free to apply for the job if you think we are a perfect match!