Skip to content

Commit

Permalink
More AWS questions
Browse files Browse the repository at this point in the history
Created also the file for Grafana questions.
  • Loading branch information
abregman committed Nov 22, 2021
1 parent ed45cd1 commit 63a3b2e
Show file tree
Hide file tree
Showing 8 changed files with 205 additions and 7 deletions.
37 changes: 32 additions & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@

:information_source:  This repo contains questions and exercises on various technical topics, sometimes related to DevOps and SRE

:bar_chart:  There are currently **1999** exercises and questions
:bar_chart:  There are currently **2112** exercises and questions

:books:  To learn more about DevOps and SRE, check the resources in [devops-resources](https://github.com/bregman-arie/devops-resources) repository

Expand Down Expand Up @@ -527,10 +527,6 @@ HTTP Strict Transport Security is a web server directive that informs user agent
Read more [here](https://www.globalsign.com/en/blog/what-is-hsts-and-how-do-i-use-it#:~:text=HTTP%20Strict%20Transport%20Security%20(HSTS,and%20back%20to%20the%20browser.)
</b></details>

<details>
<summary>What is the difference if any between SSL and TLS?</summary><br><b>
</b></details>

#### Network - Misc

<details>
Expand Down Expand Up @@ -5913,6 +5909,7 @@ Platform teams in organisations that wish to offer developers additional tools t

<details>
<summary>List some Cloud Run for Anthos use cases</summary><br><b>

As it does not support stateful applications or sticky sessions, it is suitable for running stateless applications such as:

* Machine learning model predictions e.g Tensorflow serving containers
Expand Down Expand Up @@ -7219,6 +7216,8 @@ Yes, you can use DNS for performing load balancing.
<summary>What is DNS load balancing? What its advantages? When would you use it?</summary><br><b>
</b></details>

#### Load Balancers - Sticky Sessions

<details>
<summary>What are sticky sessions? What are their pros and cons?</summary><br><b>

Expand All @@ -7231,6 +7230,34 @@ Pros:
* Ensures in-proc sessions are not lost when a new request is created
</b></details>

<details>
<summary>Name one use case for using sticky sessions</summary><br><b>

You would like to make sure the user doesn't lose the current session data.
</b></details>

<details>
<summary>What sticky sessions use for enabling the "stickiness"?</summary><br><b>

Cookies. There are application based cookies and duration based cookies.
</b></details>

<details>
<summary>Explain application-based cookies</summary><br><b>

* Generated by the application and/or the load balancer
* Usually allows to include custom data
</b></details>

<details>
<summary>Explain duration-based cookies</summary><br><b>

* Generated by the load balancer
* Session is not sticky anymore once the duration elapsed
</b></details>

#### Load Balancers - Load Balancing Algorithms

<details>
<summary>Explain each of the following load balancing techniques

Expand Down
100 changes: 100 additions & 0 deletions exercises/aws/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@ Note: Provided solutions are using the AWS console. It's recommended you'll use
|--------|--------|------|----|----|
| Application Load Balancer | ELB, ALB | [Exercise](app_load_balancer.md) | [Solution](solutions/app_load_balancer.md) | Easy |
| Multiple Target Groups | ELB, ALB | [Exercise](alb_multiple_target_groups.md) | [Solution](solutions/alb_multiple_target_groups.md) | Easy |
| Network Load Balancer | ELB, NLB | [Exercise](network_load_balancer.md) | [Solution](solutions/network_load_balancer.md) | Easy |

#### AWS - Lambda

Expand Down Expand Up @@ -1110,6 +1111,14 @@ Application Load Balancer (ALB).
True.
</b></details>

<details>
<summary>What are some use cases for using Gateway Load Balancer?</summary><br><b>

* Intrusion Detection
* Firewall
* Payload manipulation
</b></details>

<details>
<summary>Explain "health checks" in the context of AWS ELB</summary><br><b>

Expand Down Expand Up @@ -1157,12 +1166,94 @@ Application Load Balancer (routing based on different endpoints + HTTP is used).
False. ALB can route to multiple target groups.
</b></details>

<details>
<summary>If you wanted to analyze network traffic, you would use the `____ load balancer`</summary><br><b>

Gateway Load Balancer
</b></details>

<details>
<summary>Who has better latency? Application Load Balancer or Network Load Balancer?</summary><br><b>

Network Load Balancer (~100 ms) as ALB has a latency of ~400 ms
</b></details>

<details>
<summary>True or False? Network load balancer has one static IP per availability zone</summary><br><b>

True.
</b></details>

<details>
<summary>What are the supported target groups for network load balancer?</summary><br><b>

* EC2 instance
* IP addresses
* Application Load Balancer
</b></details>

<details>
<summary>What are the supported target groups for gateway load balancer?</summary><br><b>

* EC2 instance
* IP addresses (must be private IPs)
</b></details>

<details>
<summary>Name one use case for using application load balancer as a target group for network load balancer</summary><br><b>

You might want to have a fixed IP address (NLB) and then forward HTTP traffic based on path, query, ... which is then done by ALB
</b></details>

<details>
<summary>What are some use cases for using Network Load Balancer?</summary><br><b>

* TCP, UDP traffic
* Extreme performance
</b></details>

<details>
<summary>True or False? Network load balancers operate in layer 4</summary><br><b>

True. They forward TCP, UDP traffic.
</b></details>

<details>
<summary>True or False? It's possible to enable sticky session for network load balancer so the same client is always redirected to the same instance</summary><br><b>

False. This is only supported in Classic Load Balancer and Application Load Balancer.
</b></details>

<details>
<summary>Explain Cross Zone Load Balancing</summary><br><b>

With cross zone load balancing, traffic distributed evenly across all (registered) instances in all the availability zones.
</b></details>

<details>
<summary>True or False? For application load balancer, cross zone load balancing is always on and can't be disabled</summary><br><b>

True
</b></details>

<details>
<summary>True or False? For network load balancer, cross zone load balancing is always on and can't be disabled </summary><br><b>

False. It's disabled by default
</b></details>

<details>
<summary>True or False? In regards to cross zone load balancing, AWS charges you for inter AZ data in network load balancer but no in application load balancer</summary><br><b>

False. It charges fir inter AZ data in network load balancer, but not in application load balancer
</b></details>

<details>
<summary>True or False? Both ALB and NLB support multiple listeners with multiple SSL certificates </summary><br><b>

True
</b></details>

#### AWS Security

<details>
Expand Down Expand Up @@ -2180,3 +2271,12 @@ Security group isn't attached to your EFS or it lacks a rule to allow NFS traffi
2. Copy the snapshot and mark the "Encrypt" option
3. Create a new EBS volume out of the encrypted snapshot
</b></details>

<details>
<summary>You've created a network load balancer but it doesn't work (you can't reach your app on your EC2 instance). What might be a possible reason?</summary><br><b>

Missing security group or misconfigured one.
For example, if you go to your instances in the AWS console you might see that the instances under your NLB are in "unhealthy status" and if you didn't create a dedicated security group for your NLB, that means that the security group used is the one attached to the EC2 instances.

Go to the security group of your instance(s) and enable the traffic that NLB should forward (e.g. TCP on port 80).
</b></details>
2 changes: 1 addition & 1 deletion exercises/aws/alb_multiple_target_groups.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,5 +11,5 @@ One EC2 instance with a simple web application that shows the web page with the
1. healthy threshold: 3
2. unhealthy threshold: 3
3. interval: 10 seconds
2. Create another target group
2. Create another target group for the third instance
1. Traffic should be forwarded to this group based on the "/test" path
13 changes: 13 additions & 0 deletions exercises/aws/network_load_balancer.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
## AWS ELB - Network Load Balancer

### Requirements

Two running EC2 instances

### Objectives

1. Create a network load balancer
1. healthy threshold: 3
2. unhealthy threshold: 3
3. interval: 10 seconds
4. Listener should be using TCP protocol on port 80
2 changes: 1 addition & 1 deletion exercises/aws/solutions/alb_multiple_target_groups.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ One EC2 instance with a simple web application that shows the web page with the
1. healthy threshold: 3
2. unhealthy threshold: 3
3. interval: 10 seconds
2. Create another target group
2. Create another target group for the third instance
1. Traffic should be forwarded to this group based on the "/test" path

### Solution
Expand Down
35 changes: 35 additions & 0 deletions exercises/aws/solutions/network_load_balancer.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
## AWS ELB - Network Load Balancer

### Requirements

Two running EC2 instances

### Objectives

1. Create a network load balancer
1. healthy threshold: 3
2. unhealthy threshold: 3
3. interval: 10 seconds
4. Listener should be using TCP protocol on port 80

### Solution

#### Console

1. Go to EC2 service
2. Click in the left side menu on "Load balancers" under "Load balancing"
3. Click on "Create load balancer"
4. Choose "Network Load Balancer"
5. Insert a name for the LB
6. Choose AZs where you want the LB to operate
7. Choose a security group
8. Under "Listeners and routing" click on "Create target group" and choose "Instances"
1. Provide a name for the target group
2. Set healthy threshold to 3
3. Set unhealthy threshold to 3
4. Set interval to 10 seconds
5. Set protocol to TCP and port to 80
6. Click on "Next" and choose two instances you have
7. Click on "Create target group"
9. Refresh target groups and choose the one you've just created
10. Click on "Create load balancer" and wait for it to be provisioned
7 changes: 7 additions & 0 deletions exercises/grafana/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
## Grafana

<details>
<summary>Explain what is Grafana</summary><br><b>

[Grafana Docs](https://grafana.com/docs/grafana/latest/introduction): "Grafana is a complete observability stack that allows you to monitor and analyze metrics, logs and traces. It allows you to query, visualize, alert on and understand your data no matter where it is stored. Create, explore, and share beautiful dashboards with your team and foster a data driven culture."
</b></details>
16 changes: 16 additions & 0 deletions exercises/security/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -389,7 +389,23 @@ MAC address flooding attack (CAM table flooding attack) is a type of network att
<summary>What is Cache Poisoned Denial of Service?</summary><br><b>

CPDoS or Cache Poisoned Denial of Service. It poisons the CDN cache. By manipulating certain header requests, the attacker forces the origin server to return a Bad Request error which is stored in the CDN’s cache. Thus, every request that comes after the attack will get an error page.
</b></details>

<details>
<summary>What is the difference if any between SSL and TLS?</summary><br><b>
</b></details>

<details>
<summary>What is SNI (Server Name Indication)?</summary><br><b>

[Wikipedia](https://en.wikipedia.org/wiki/Server_Name_Indication): "an extension to the Transport Layer Security (TLS) computer networking protocol by which a client indicates which hostname it is attempting to connect to at the start of the handshaking process"
</b></details>

<details>
<summary>What benefits SNI introduces?</summary><br><b>

SNI allows a single server to serve multiple certificates using the same IP and port.<br>
Practically this means that a single IP can server multiple web services/pages, each using a different certificate.
</b></details>

#### Security - Threats
Expand Down

0 comments on commit 63a3b2e

Please sign in to comment.