Merge pull request #47 from donnemartin/develop

Polish up HTTP, RPC, and intro sections
This commit is contained in:
Donne Martin 2017-04-02 08:09:50 -04:00 committed by GitHub
commit 7ac68aa090

View File

@ -7,11 +7,11 @@
## Motivation ## Motivation
> Learn how to design large scale systems. > Learn how to design large-scale systems.
> >
> Prep for the system design interview. > Prep for the system design interview.
### Learn how to design large scale systems ### Learn how to design large-scale systems
Learning how to design scalable systems will help you become a better engineer. Learning how to design scalable systems will help you become a better engineer.
@ -1330,12 +1330,13 @@ A basic HTTP request consists of a verb (method) and a resource (endpoint). Bel
*Can be called many times without different outcomes. *Can be called many times without different outcomes.
The difference between `PUT` and `PATCH` is explained by example [here](https://laracasts.com/discuss/channels/general-discussion/whats-the-differences-between-put-and-patch?page=1).
HTTP is an application layer protocol relying on lower-level protocols such as **TCP** and **UDP**. HTTP is an application layer protocol relying on lower-level protocols such as **TCP** and **UDP**.
* [HTTP](https://www.nginx.com/resources/glossary/http/) #### Source(s) and further reading: HTTP
* [README](https://www.quora.com/What-is-the-difference-between-HTTP-protocol-and-TCP-protocol)
* [What is HTTP?](https://www.nginx.com/resources/glossary/http/)
* [Difference between HTTP and TCP](https://www.quora.com/What-is-the-difference-between-HTTP-protocol-and-TCP-protocol)
* [Difference between PUT and PATCH](https://laracasts.com/discuss/channels/general-discussion/whats-the-differences-between-put-and-patch?page=1)
### Transmission control protocol (TCP) ### Transmission control protocol (TCP)
@ -1423,12 +1424,12 @@ POST /anotheroperation
RPC is focused on exposing behaviors. RPCs are often used for performance reasons with internal communications, as you can hand-craft native calls to better fit your use cases. RPC is focused on exposing behaviors. RPCs are often used for performance reasons with internal communications, as you can hand-craft native calls to better fit your use cases.
Choose a Native Library aka SDK when: Choose a native library (aka SDK) when:
* You know your target platform. * You know your target platform.
* You want to control how your "logic" is accessed * You want to control how your "logic" is accessed.
* You want to control how error control happens off your library * You want to control how error control happens off your library.
* Performance and end user experience is your primary concern * Performance and end user experience is your primary concern.
HTTP APIs following **REST** tend to be used more often for public APIs. HTTP APIs following **REST** tend to be used more often for public APIs.