使用ruby 自带的webrick 可以非常方便地实现一个web服务器。
webrick.rb 基本代码如下:
#!/usr/bin/env ruby
require 'webrick'
## prepare dirs
FileUtils.mkdir_p('html')
webroot = File.expand_path 'html'
server = WEBrick::HTTPServer.new :Port => 8000, :DocumentRoot => webroot
trap 'INT' do server.shutdown end
server.start
使用命令ruby webrick.rb 即可启动一个监听在8000端口的web服务器,
根目录在当前目录的子目录html里。代码中的web根目录也可以是一个绝对路径。
在web根目录中创建一个示例html文件,立马可以看到效果。比如:
echo "hello world" > html/index.html
上面的web 服务器在前台运行,也没有日志功能,所有输出直接打印在console上。
可以稍加润色一下,添加一些基本功能
1、简单的日志功能,
2、后台运行功能
代码如下:
#!/usr/bin/env ruby
require 'webrick'
## prepare dirs
FileUtils.mkdir_p('html')
FileUtils.mkdir_p('log')
## webroot
webroot = File.expand_path 'html'
## access log
logfile = File.open 'log/webrick.log', 'a+'
access_log = [ [logfile, WEBrick::AccessLog::COMBINED_LOG_FORMAT], ]
log = WEBrick::Log.new logfile
server = WEBrick::HTTPServer.new(
:Port => 8001,
:DocumentRoot => webroot,
:Logger => log,
:AccessLog => access_log
)
trap 'INT' do server.shutdown end
## run in daemon mode
WEBrick::Daemon.start
server.start
新学ruby,暂未解决的问题有
1、日志存在缓存buffer,不会立即写入日志文件
2、日志文件句柄似乎没有回收