在 Ubuntu16.04上安装并使用Docker

前言:如今两年很激烈的互联网框架Retrofit,使用它的时候,查看文档会告诉你,要求后台的服务器男士必须符合REST规范给你安插接口,作为安卓开发工程师来说,我就很意外了,REST规范到底是啥?本着极客精神,我就查了资料,写了这样一篇文章,即使有不规则的地点,欢迎提意见。

介绍

Docker是一个绽放源代码软件项目,让应用程序布署在软件容器下的行事可以自动化举行,借此在Linux操作系统上,提供3个附加的软件抽象层,以及操作系统层虚拟化的全自动管理机制[\[1\]](https://zh.wikipedia.org/wiki/Docker_(%E8%BB%9F%E9%AB%94)#cite_note-SYS-CON_Media-1)。Docker利用Linux核心中的财富分脱机制,例如cgroups,以及Linux核心名字空间(name
space),来成立独立的软件容器(containers)。那可以在单一Linux实体下运转,防止指导三个虚拟机致使的额外负担[\[2\]](https://zh.wikipedia.org/wiki/Docker_(%E8%BB%9F%E9%AB%94)#cite_note-2)。Linux宗旨对名字空间的支撑完全切断了办事环境中应用程序的视野,包蕴进程树网络、用户ID与挂载文件系统,而基本的cgroup提供能源隔离,包罗CPU内存、block

一、理解RESTful架构

越多的人开头发现到,网站即软件,而且是一种新型的软件。
  那种”互连网软件”选用客户端/服务器形式,建立在分布式序列上,通过网络通信,具有高延时(high
latency)、高并发等特色。
  网站开发,完全可以运用软件开发的方式。可是传统上,软件和网络是七个例外的园地,很少有混合;软件开发主要针对单机环境,互连网则根本讨论连串里面的通讯。互连网的兴起,使得那五个世界早先融合,**
以往大家无法不考虑,如何开发在网络环境中运用的软件。**

RESTful架构,就是眼下最风靡的一种互连网软件架构。它结构清晰、符合标准、易于精晓、增加方便,所以正得到更进一步多网站的采用。
  然则,到底哪些是RESTful架构,并不是3个简单说知道的难题。下边,作者就商讨自个儿驾驭的RESTful架构。

一、起源

REST这个词,是Roy Thomas
Fielding
在他2000年的博士散文中提议的。

  Fielding是一个尤其关键的人,他是HTTP协议(1.0版和1.1版)的紧要性设计者、Apache服务器软件的我之一、Apache基金会的首先任主席。所以,他的那篇杂谈一经刊载,就引起了关爱,并且立刻对网络支付暴发了博大精深的影响。
  他如此介绍散文的编著目的:

正文商量统计机科学两大前沿—-软件和互连网—-的交叉点。长时间以来,软件商量重大关心软件设计的归类、设计方式的嬗变,很少客观地评估差别的宏图选用对系统行为的熏陶。而相反地,网络商讨重点关注系统之间通讯行为的底细、如何改正特定通讯机制的突显,平日忽略了3个真相,那就是改变应用程序的竞相风格比变更互动协议,对完全展现有更大的熏陶。自家那篇小说的写作目的,就是想在适合架构原理的前提下,领会和评估以网络为底蕴的拔取软件的架构设计,得到二个成效强、品质好、适宜通信的架构。

二、名称

菲尔德ing将她对互连网软件的架构原则,定名为REST,即Representational
State Transfer的缩写。小编对这么些短语的翻译是”表现层状态转化”。

万一二个架构符合REST原则,就称它为RESTful架构。

要精晓RESTful架构,最好的章程就是去明白Representational State
Transfer那个短语到底是何许看头,它的每2个词代表了什么样涵义。
比方您把这些名称搞懂了,也就简单体会REST是一种何等的安排。

三、资源(Resources)

REST的名目”表现层状态转化”中,省略了主语。”表现层”其实指的是”财富”(Resources)的”表现层”。

所谓”财富”,就是互连网上的2个实体,或许说是互联网上的二个现实新闻。它可以是一段文本、一张图纸、一首歌曲、一种服务,同理可得就是2个切实的实际。你可以用三个ULANDI(统一能源定位符)指向它,逐个财富对应一个一定的U奥德赛I。要博得这些财富,访问它的U陆风X8I就足以,因而U君越I就成了每一种财富的地点或独一无二的识别符。

所谓”上网”,就是与网络上一层层的”财富”互动,调用它的USportageI。

四、表现层(Representation)

“能源”是一种新闻实体,它可以有四种外在表现格局。作者们把”能源”具体表现出来的格局,叫做它的”表现层”(Representation)。

譬如,文本可以用txt格式表现,也可以用HTML格式、XML格式、JSON格式表现,甚至足以行使二进制格式;图片能够用JPG格式表现,也得以用PNG格式表现。

U智跑I只代表能源的实业,不代表它的款型。严峻地说,有个别网址最终的”.html”后缀名是不必要的,因为那一个后缀名表示格式,属于”表现层”范畴,而U陆风X8I应该只表示”能源”的职位。它的具体表现格局,应该在HTTP请求的头消息中用Accept和Content-Type字段指定,那七个字段才是对”表现层”的叙述。

五、状态转化(State Transfer)

访问壹个网站,就表示了客户端和服务器的3个相互进度。在那一个进度中,势必涉及到数码和情况的变通。

互连网通讯协议HTTP协议,是三个无状态协议。那表示,全体的情事都封存在服务器端。由此,假诺客户端想要操作服务器,必须通过某种手段,让服务器端发生”状态转化”(State
Transfer)。而那种转化是确立在显示层以上的,所以就是”表现层状态转化”。

客户端用到的手腕,只可以是HTTP协议。具体来说,就是HTTP协议里面,七个代表操作方法的动词:GET、POST、PUT、DELETE。它们各自对应多种基本操作:GET用来拿到财富,POST用来新建财富(也得以用来更新财富),PUT用来更新能源,DELETE用来删除能源。

六、综述

回顾上面的诠释,我们总计一下怎么着是RESTful架构:
    (1)每贰个U卡宴I代表一种资源;
    (2)客户端和服务器之间,传递那种财富的某种表现层;
    (3)客户端通过七个HTTP动词,对服务器端能源拓展操作,完结”表现层状态转化”。

七、误区

RESTful架构有一些名列三甲的筹划误区。
  最常见的一种设计不当,就是ULANDI包含动词。因为”财富”表示一种实体,所以理应是名词,U宝马X5I不该有动词,动词应该放在HTTP协议中。
  举例来说,某些ULacrosseI是/posts/show/1,其中show是动词,那几个UKugaI就统筹错了,正确的写法应该是/posts/1,然后用GET方法表示show。
  如果某个动作是HTTP动词表示不了的,你就活该把动作做成一种财富。比如网上汇款,从账户1向账户2汇款500元,错误的U途睿欧I是:

POST /accounts/1/transfer/500/to/2

不错的写法是把动词transfer改成名词transaction,能源无法是动词,不过足以是一种服务:

POST /transaction HTTP/1.1
Host: 127.0.0.1
from=1&to=2&amount=500.00

另多少个规划误区,就是在ULacrosseI中投入版本号

http://www.example.com/app/1.0/foo
http://www.example.com/app/1.1/foo
http://www.example.com/app/2.0/foo

因为不相同的版本,可以领会成同一种财富的两样表现格局,所以应该使用同三个U昂科雷I。版本号可以在HTTP请求头音信的Accept字段中举行区分(参见Versioning
REST
Services
):

Accept: vnd.example-com.foo+json; version=1.0
Accept: vnd.example-com.foo+json; version=1.1
Accept: vnd.example-com.foo+json; version=2.0

I/O与互连网。从0.9版本起,Dockers在动用抽象虚拟是历经libvirt的 LXC与systemd

nspawn提供界面的根基上,先河席卷libcontainer库做为以本人的主意开首平素使用由Linux宗旨提供的虚拟化的设备,

据悉行业分析集团“451商讨”:“Dockers是有力量打包应用程序及其虚拟容器,可以在任何Linux服务器上运转的器重工具,那促进完成灵活性和便携性,应用程序在任何地方都得以运转,无论是公有云、私有云、单机等。”


 

二、RESTful API 设计指南

网络应用程序,分为前端和后端三个部分。当前的发展趋势,就是前者设备见惯司空(手机、平板、桌面电脑、其余专用设备……)。
  由此,必须有一种统一的体制,方便区其余前端设备与后端进行通讯。这造成API构架的风靡,甚至出现“API
First”
的安插思想。RESTful
API
是时下可比早熟的一套网络应用程序的API设计理论。作者原先写过一篇《精通RESTful架构》,商讨怎么样明白那些定义。
  今日,小编将介绍RESTful
API的统筹细节,商量怎么样统筹一套合理、好用的API。我的紧要参照了两篇小说(12)。

RESTful API

一、协议

API与用户的通讯协议,总是利用HTTPs协议

二、域名

应当尽大概将API安插在专用域名之下。

    https://api.example.com

只要显然API很不难,不会有更进一步增添,能够考虑放在主域名下。

     https://example.org/api/

三、版本(Versioning)

应当将API的版本号放入U本田UR-VL。

  https://api.example.com/v1/

另一种做法是,将版本号放在HTTP头音信中,但不如放入UHavalL方便和直观。Github使用那种做法。

四、路径(Endpoint)

途径又称”终点”(endpoint),表示API的现实网址。

在RESTful架构中,每一个网址代表一种能源(resource),所以网址中无法有动词,只好出名词,而且所用的名词往往与数据库的表格名对应。一般的话,数据库中的表都是同种记录的”集合”(collection),所以API中的名词也理应利用复数。

举例来说来说,有三个API提供动物园(zoo)的音信,还包含各样动物和雇员的新闻,则它的不二法门应该设计成下边那样。

https://api.example.com/v1/zoos
https://api.example.com/v1/animals
https://api.example.com/v1/employees

五、HTTP动词

对于能源的具体操作类型,由HTTP动词表示。
常用的HTTP动词有下边多少个(括号里是对应的SQL命令)。

GET(SELECT):从服务器取出资源(一项或多项)。
POST(CREATE):在服务器新建一个资源。
PUT(UPDATE):在服务器更新资源(客户端提供改变后的完整资源)。
PATCH(UPDATE):在服务器更新资源(客户端提供改变的属性)。
DELETE(DELETE):从服务器删除资源。

再有八个不常用的HTTP动词。

HEAD:获取资源的元数据。
OPTIONS:获取信息,关于资源的哪些属性是客户端可以改变的。

上面是一些例证。

GET /zoos:列出所有动物园
POST /zoos:新建一个动物园
GET /zoos/ID:获取某个指定动物园的信息
PUT /zoos/ID:更新某个指定动物园的信息(提供该动物园的全部信息)
PATCH /zoos/ID:更新某个指定动物园的信息(提供该动物园的部分信息)
DELETE /zoos/ID:删除某个动物园
GET /zoos/ID/animals:列出某个指定动物园的所有动物
DELETE /zoos/ID/animals/ID:删除某个指定动物园的指定动物

六、过滤新闻(Filtering)

假诺记录数据很多,服务器不容许都将它们再次回到给用户。API应该提供参数,过滤重返结果。
上面是有的大面积的参数。

?limit=10:指定返回记录的数量
?offset=10:指定返回记录的开始位置。
?page=2&per_page=100:指定第几页,以及每页的记录数。
?sortby=name&order=asc:指定返回结果按照哪个属性排序,以及排序顺序。
?animal_type_id=1:指定筛选条件

参数的设计允许存在冗余,即允许API路径和UTiggoL参数偶尔有再次。比如,GET
/zoo/ID/animals 与 GET /animals?zoo_id=ID 的意义是一样的。

七、状态码(Status Codes)

服务器向用户重返的状态码和指示音讯,常见的有以下部分(方括号中是该状态码对应的HTTP动词)。

200 OK - [GET]:服务器成功返回用户请求的数据,该操作是幂等的(Idempotent)。
201 CREATED - [POST/PUT/PATCH]:用户新建或修改数据成功。
202 Accepted - [*]:表示一个请求已经进入后台排队(异步任务)
204 NO CONTENT - [DELETE]:用户删除数据成功。
400 INVALID REQUEST - [POST/PUT/PATCH]:用户发出的请求有错误,服务器没有进行新建或修改数据的操作,该操作是幂等的。
401 Unauthorized - [*]:表示用户没有权限(令牌、用户名、密码错误)。
403 Forbidden - [*] 表示用户得到授权(与401错误相对),但是访问是被禁止的。
404 NOT FOUND - [*]:用户发出的请求针对的是不存在的记录,服务器没有进行操作,该操作是幂等的。
406 Not Acceptable - [GET]:用户请求的格式不可得(比如用户请求JSON格式,但是只有XML格式)。
410 Gone -[GET]:用户请求的资源被永久删除,且不会再得到的。
422 Unprocesable entity - [POST/PUT/PATCH] 当创建一个对象时,发生一个验证错误。
500 INTERNAL SERVER ERROR - [*]:服务器发生错误,用户将无法判断发出的请求是否成功。

状态码的一心列表参见这里

八、错误处理(Error handling)

一经状态码是4xx,就应当向用户重临出错信息。一般的话,再次回到的新闻中校error作为键名,出错音信作为键值即可。

{
error: “Invalid API key”
}

九、重回结果

针对不一样操作,服务器向用户重回的结果应该符合以下标准。

GET /collection:返回资源对象的列表(数组)
GET /collection/resource:返回单个资源对象
POST /collection:返回新生成的资源对象
PUT /collection/resource:返回完整的资源对象
PATCH /collection/resource:返回完整的资源对象
DELETE /collection/resource:返回一个空文档

十、Hypermedia API

RESTful
API最好完结Hypermedia,即重返结果中提供链接,连向其余API方法,使得用户不查文档,也知道下一步应该做哪些。
  比如,当用户向api.example.com的根目录发出请求,会得到如此3个文档。

{"link": { 
  "rel":   "collection https://www.example.com/zoos",
  "href":  "https://api.example.com/zoos",
  "title": "List of zoos",
  "type":  "application/vnd.yourformat+json"
}}

地点代码表示,文档中有一个link属性,用户读取那个性子就知道下一步该调用什么API了。rel代表那一个API与眼下网址的关系(collection关系,并交付该collection的网址),href表示API的途径,title表示API的题目,type表示回去类型。
  Hypermedia
API的布署被称作HATEOAS。Github的API就是那种规划,访问api.github.com会收获3个兼有可用API的网址列表。

{
  "current_user_url": "https://api.github.com/user",
  "authorizations_url": "https://api.github.com/authorizations",
  // ...
}

从地方可以见见,即便想博得当前用户的新闻,应该去拜谒api.github.com/user,然后就收获了下边结果。

  {
    "message": "Requires authentication",
    "documentation_url": "https://developer.github.com/v3"
}

上面代码表示,服务器交由了指示消息,以及文档的网址。

十一、其他

(1)API的地位认证应该使用OAuth
2.0
框架。
(2)服务器重返的数据格式,应该尽恐怕选择JSON,防止拔取XML。
(完)


**
原文:http://www.ruanyifeng.com/blog/2014/05/restful\_api.html\*\*

安装需求条件

6二位的种类

可以运用sudo的用户


 安装

先是步:设置包管理器仓库

在Ubuntu上设置Docker仓库。 lsb_release -cs 可以突显你的 Ubuntu
版本,比如 xenial 恐怕 trusty。

安装达成后,更新包管理器。

sudo  apt-get -y install apt-transport-https ca-certificates
curl  -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add - 
sudo apt-get install software-properties-common 
sudo  add-apt-repository "deb [arch=amd64] https://download.docker.com/linux/ubuntu $(lsb_release -cs) stable"
sudo apt-get udate

第二步:安装Docker

sudo apt-get -y install docker-ce

第三步:测试

sudo docker run hello-world

第四部:无需sudo执行Docker命令(非必要)

sudo usermod -aG docker '你的用户名'

 

发表评论

电子邮件地址不会被公开。 必填项已用*标注