第4章 服务器裸奔

优质
小牛编辑
128浏览
2023-12-01

在 go 语言下要跑起一个HTTP服务器是很容易的.

  1. package main
  2. import "net/http"
  3. func main() {
  4. http.ListenAndServe(":8080", http.FileServer(http.Dir("/usr/share/doc")))
  5. }

这就行了,一个静态文件服务器就跑起来了. TypePress 下的代码是这样的

  1. package main
  2. import "github.com/typepress/server"
  3. func main() {
  4. server.Simple()
  5. }

这个服务器没有设置任何 Route, 只返回 404, 裸奔的服务器. 这只是表面, 下面来列举下这个 Simple Server 背后都做了哪些工作

配置基本参数

有三种方法设置服务器基本参数:

  • 通过命令行参数 —help 可以获得帮助列表
  • os.Getenv 获取 应用通过 os.Setenv 设置参数
  • 从 TOML 文件读取 TOML 文件支持已经默认加入

基本功能

有些基本的功能是一个框架需要提供的

  • 安全关闭机制 shutdown 总用 kill 是不安全的. 得益于 manners
  • i18n 接口 i18n 接口非常轻量, 当 fmt.Sprintf 使就行
  • 自定义信号 完全采用 os.Signal 接口, 安全关闭信号就是基于这个
  • 延迟初始化 有些初始化工作需要在 main 执行时调用
  • 子路由 按 http method 划分的子路由, 主路由只能由 main 函数调用
  • 角色控制 字符串角色命名, 自动转化为 accessflags 支持的 interger
  • 日志支持 引入 typepress/log, 支持 file 分割, email发送
  • 数据库接口支持 引入typepress/db, 即便不需要也不必担心, 这是个轻量接口
  • core 全局可访问的对象和 types 类型
  • 基于 Martini Injector 的设计 这是最最重要的

这样列举起来, 貌似这个 Simple Server 貌似已经不轻量了. 不! 他依然是轻量的, 因为这些接口设计的很轻量, 当你不用他们的时候, 他们不会产生过多的消耗. 这些接口的代码都很短, 引入他们, 怎加不了多少代码空间.
应该可以看出仅仅是这些基础的功能已经形成了一个服务器框架.

这些都已经准备好了. 哦还有模板, 这个东西不打算默认引入, 各种口味难调.

模块化

这些很多都是独立的 package, 可以单独使用. 从 typepress org 可以看出, 模块以独立的 rep 出现.
typepress 特别注意降低依赖, 写成独立 rep 是最基本的方法.