服务端Swift - Vapor2.0介绍

Get started with Vapor 2 at [docs.vapor.codes](https://user-gold-cdn.xitu.io/2017/5/31/f1121a99d68c5429cf04d811b9640411)

近日,在Medium上看到Vapor出了2.0版本,而且出了新的文档,新的网站。因而忍不住试了一下,而且此次打算不在本地测试,想在Ubuntu系统上尝试。javascript

Intro

经过学习这篇文章,你将学习到:java

  • 在阿里云和腾讯云上搭载Ubuntu云服务器
  • 在Ubuntu上配置Vapor2.0以及Swift3.1运行环境
  • 了解编译Vapor2.0工程的速度
  • 掌握如何编写简单的JSON数据返回API

Get Start

阿里云、腾讯云搭载Ubuntu服务器端系统

由于绝大部分公司是不可能会用苹果系统来做服务器的,考虑到实用性,此次使用云服务器来运行咱们的服务端Swift代码。恰好做为学生可以以廉价买阿里云和腾讯云服务器,因此下手测试了两家云端服务器。git


腾讯云服务器CVM
阿里云服务器ECS
因为Swift暂时只支持Ubuntu运行环境,因此云服务器系统咱们选择安装Ubuntu16.04 64位版本,请肯定安装正确的系统。json

性能比较

对比两种服务器,阿里云的速度慢腾讯云可不止一两倍,并且,搞了好久,阿里云打开不了80窗口,这样咱们的服务端代码就起不了做用了,亲测腾讯云成功运行。ubuntu

配置Vapor2.0以及Swift3.1运行环境

经过ssh来登陆咱们的服务器

ssh [name]@公网iP而后输入密码便可登陆。name为管理员名,或者你也能够在腾讯云管理中心远程链接服务器。swift

运行脚本

eval "$(curl -sL https://apt.vapor.sh)"vim

安装Vapor

sudo apt-get install swift vapor安装Vapor2.0。
须要注意的是,这两行指令已经默认给咱们配置了Swift3.1的环境,咱们不须要手动下载Swift3.1,很是方便。api

最后

经过一行指令再次确认Vapor2.0是否安装成功
eval "$(curl -sL check.vapor.sh)"浏览器

若是安装成功,你会看到如下的效果

Success

新建一个Vapor工程

经过一行命令新建一个工程
vapor new HelloWorld服务器


第一次新建的时候,你可能会看到

image.png

是由于咱们尚未设置咱们的Git邮箱和名称,经过执行如下两行命令便可修复错误。
git config --global user.email "you@example.com"
git config --global user.name "Your Name"
这时候咱们能够从新新建一个工程 vapor new [name]


cd到咱们的工程文件中,运行vapor build

可怕的等待

而后就看云服务器的造诣了,在前面的文章里面,我写过一篇在苹果系统本地测试咱们的Vapor,当我运行 vapor build大约都要等个5到10分钟。在阿里云测试咱们的Vapor时,我大约也要等10来分钟,可是腾讯云我测试大约要3分钟,速度明显差别。

成功编译

成功编译

Vapor目录结构

Hello
├── Config
│   ├── app.json
│   ├── crypto.json
│   ├── droplet.json
│   ├── fluent.json
│   └── server.json
├── Package.pins
├── Package.swift
├── Public
├── README.md
├── Sources
│   ├── App
│   │   ├── Config+Setup.swift
│   │   ├── Controllers
│   │   │   └── PostController.swift
│   │   ├── Droplet+Setup.swift
│   │   ├── Models
│   │   │   └── Post.swift
│   │   └── Routes.swift
│   └── Run
│       └── main.swift
├── Tests
│   ├── AppTests
│   │   ├── PostControllerTests.swift
│   │   ├── RouteTests.swift
│   │   └── Utilities.swift
│   └── LinuxMain.swift
├── circle.yml
└── license复制代码

须要注意的是,Vapor2.0的文件结构和Vapor1稍有差异,确实是Less Code,More Power.
cd Sources/Appcd 到App目录下
运行vim Routes.swift查看该文件代码,咱们能够发现

import Vapor

final class Routes: RouteCollection {
    func build(_ builder: RouteBuilder) throws {
        builder.get("hello") { req in
            var json = JSON()
            try json.set("hello", "world")
            return json
        }

        builder.get("plaintext") { req in
            return "Hello, world!"
        }

        // response to requests to /info domain
        // with a description of the request
        builder.get("info") { req in
            return req.description
        }

       builder.get("*") { req in return req.description }

        try builder.resource("posts", PostController.self)
    }
}

/// Since Routes doesn't depend on anything
/// to be initialized, we can conform it to EmptyInitializable
///
/// This will allow it to be passed by type.
extension Routes: EmptyInitializable { }复制代码

对比上个版本,确实是简洁了不少。
补充:退出vim Routes.swift命令能够按Shift健+Q再输入wq!退出来。

最后,Run Server

先cd回工程根目录下,并执行
vapor run serve

vapor run serve

测试API数据返回

在浏览器上输入
[你的云服务器公网IP]:8080/hello

哇哈哈,成功啦

Vapor 2:Less code, more power.

Vapor2添加了不少新的库

Some of the new features in Vapor 2.

相比Vapor1.5,快速大概3倍,并且比PHP,Ruby快近乎100倍

Vapor 2 is 3x faster than Vapor 1 for plaintext responses.


写在最后

本次是Vapor2.0的开篇,你们能够上Vapor2.0新文档查看新版介绍。日后会详细讲Vapor2的功能介绍和应用,喜欢请给红心,也是对个人鼓励。

Write the code, change the world.

相关文章
相关标签/搜索