Project Perfect让Swift在服务器端跑起来-在Linux上创建你的Perfect项

编者语: 对于一个新事物,如果你花点心机还是有很多收获的。

前两篇,分别讲述了入门和在Linux下部署,现在得说说如何在Linux下开发了。在Linux下开发,相对比在Mac下开发更灵活。
我们先来看看构建基于Perfect的网站服务的编译方式

如图通过引用基础库PerfectLib和数据链接,中间件模块创建你的网页文件,并用makefile打包生成你的网站动态库。所以如果你只是在Linux下构建项目,你只需要先创建好你的Handlers.Swift即可。对比起在Xcode通过模版或者Framework的方式简洁不少。这里大家会想能否用Swift Package Manager引用PerfectLib的方式对Handlers.swift进行编译?现阶段是不可以的,由于Perfect是用动态库的方式打包PerfectLib而Package Manager不支持动态库的引用,所以如果你想整合Package Manager直接编译你的Handlers.swift是不可以的。(你只能寄望苹果尽快支持)。现在你只能用makefile动态编译。

根据上面的方式我们开始在Linux下创建我们的Perfect项目。

1. 关于创建的路径,个人建议放在Github下载的Perfect目录下,因为你需要引用对应的基础库,比较容易管理和调用。这里我在Perfect文件夹创建了一个Demo文件夹,作为新项目的目录。

2. 在Demo文件夹下创建一个PerfectHandlers.swift 和 makefile。建议大家使用IDE进行编辑,这里我建议使用Visual Studio Code,虽然是微软的产品,但是胜在对swift支持较好,对比起atom更稳定。

看看我们的PerfectHandlers.swift,和前面说的一样,代码如下:

[plain]view plaincopy

print?

  1. importPerfectLib
  2. publicfuncPerfectServerModuleInit(){
  3. Routing.Handler.registerGlobally();
  4. Routing.Routes["GET",["/","index.html"]]={(_:WebResponse)inreturnIndexHandler()}
  5. }
  6. classIndexHandler:RequestHandler{
  7. funchandleRequest(request:WebRequest,response:WebResponse){
  8. response.appendBodyString("helloswift")
  9. response.requestCompletedCallback()
  10. }
  11. }

而makefile就是我们把Demo编译成动态库的关键文件了,先看看代码

[plain]view plaincopy

print?

  1. #MakefileforPerfectServer
  2. TARGET=Demo
  3. OS=$(shelluname)
  4. DEMO_SRC="PerfectHandlers.swift"
  5. PERFECT_ROOT=../PerfectLib
  6. SWIFTC=swift
  7. SWIFTC_FLAGS=-frontend-c-module-cache-path$(MODULE_CACHE_PATH)-emit-module-I/usr/local/lib-I$(PERFECT_ROOT)/linked/LibEvent\
  8. -I$(PERFECT_ROOT)/linked/OpenSSL_Linux-I$(PERFECT_ROOT)/linked/ICU-I$(PERFECT_ROOT)/linked/sqlite3-I$(PERFECT_ROOT)/linked/LinuxBridge
  9. MODULE_CACHE_PATH=/tmp/modulecache
  10. Linux_SHLIB_PATH=$(shelldirname$(shelldirname$(shellwhichswiftc)))/lib/swift/linux
  11. SHLIB_PATH=-L$($(OS)_SHLIB_PATH)
  12. LFLAGS=$(SHLIB_PATH)-lFoundation-lswiftCore-lswiftGlibc/usr/local/lib/PerfectLib.so-Xlinker-rpath-Xlinker$($(OS)_SHLIB_PATH)-shared
  13. all:$(TARGET)
  14. modulecache:
  15. @mkdir-p$(MODULE_CACHE_PATH)
  16. $(TARGET):modulecache
  17. $(SWIFTC)$(SWIFTC_FLAGS)$(DEMO_SRC)-o$@.o-module-name$@-emit-module-path$@.swiftmodule
  18. clang++$(LFLAGS)$@.o-o$@.so
  19. clean:
  20. @rm*.o

makefile 这里有几个关键的地方需要注意,

a. TARGET是编译目标和你的项目名保持一致,这里就是TARGET = Demo

b. DEMO_SRC 这个是需要把你的所有swift文件包含进去,因为要一起打包到静态库内,你可以参考Examples/Authenticator内的makefile

3. 在终端,编译即可,执行sudo make编译成功如下图

4. 把生成的Demo.so迁移到Perfect/var/www/PerfectLibraries中(改目录的创建和使用请参考http://www.jb51.cc/article/p-yfemoxvn-bac.html

5. 执行sudo ./perfectServerHttp.sh start 即可
在Linux下创建Perfect项目,让Perfect项目的维护和升级更有保障了,而且比在Xcode下创建项目更加简单直接,建议大家上手使用

相关文章

软件简介:蓝湖辅助工具,减少移动端开发中控件属性的复制和粘...
现实生活中,我们听到的声音都是时间连续的,我们称为这种信...
前言最近在B站上看到一个漂亮的仙女姐姐跳舞视频,循环看了亿...
【Android App】实战项目之仿抖音的短视频分享App(附源码和...
前言这一篇博客应该是我花时间最多的一次了,从2022年1月底至...
因为我既对接过session、cookie,也对接过JWT,今年因为工作...