- Docker and Kubernetes for Java Developers
- Jaroslaw Krochmalski
- 411字
- 2021-07-02 18:44:57
Introduction to REST
The REST acronym stands for Representational State Transfer. It's an architectural style and a design for network-based software. It describes how one system can communicate a state with another. This fits perfectly well into the microservice world. As you will remember from Chapter 3, Working with Microservices, the software applications based on the microservices architecture is a bunch of separated, independent services talking to each other.
There are some concepts in REST that we need to understand, before we go further:
- resource: This is the main concept in the REST architecture. Any information can be a resource. A bank account, a person, an image, a book. A representation of a resource must be stateless
- representation: A specific way a resource can be represented. For example, a bank account resource can be represented using JSON, XML, or HTML. Different clients might request different representations of the resource, one can accept JSON, while others will be expecting XML
- server: A service provider. It exposes services which can be consumed by clients
- client: A service consumer. This could be another microservice, application, or just a user's web browser running an Angular application, for example
As the definition says, REST is being used to transport those resource representations over the network. The representation itself is being created via some media type. Media types can be different. Some examples of media types include JSON, XML, or RDF. The JSON media type is widely accepted and probably the most often used. In our examples, we will also use JSON to communicate with our service. Of course, REST is not the only option for microservices communication; there are others, such as Google's very good gRPC, for example, which brings a lot of advantages such as HTTP/2 and protobuff. In the REST architecture, resources are manipulated by components. In fact, these components are our microservices. Components request and manipulate resources via a standard uniform interface. REST is not tied to any specific protocol; however, REST calls are most often being made using the most popular HTTP or HTTPS protocol. In the case of HTTP, this uniform interface consists of standard HTTP methods such as GET, PUT, POST, and DELETE.
Before we start implementing our service that will respond to HTTP calls, it's worth knowing about the HTTP methods we are going to use. We are going to focus on them a little bit closer now.
- 密碼學原理與Java實現
- Access 數據庫應用教程
- Apex Design Patterns
- 軟件測試技術指南
- Advanced Oracle PL/SQL Developer's Guide(Second Edition)
- Nginx Lua開發實戰
- Go語言精進之路:從新手到高手的編程思想、方法和技巧(1)
- Python機器學習:預測分析核心算法
- “笨辦法”學C語言
- Learning Hadoop 2
- Clojure for Java Developers
- Deep Learning with R Cookbook
- 一步一步跟我學Scratch3.0案例
- Python網絡爬蟲實例教程(視頻講解版)
- Splunk Essentials