深入探索 Ruby 网络编程与实用库
多客户端 TCP 服务器
在互联网中,大多数服务器都需要同时处理大量客户端的请求。如果一个 Web 服务器一次只能处理一个文件请求,随着用户排队等待服务,它很快就会成为世界上最慢的网站。之前提到的 TCP 服务器就是以这种单线程或顺序的方式运行的。
Ruby 的 Thread 类让创建多线程服务器变得轻而易举。多线程服务器在接受请求后,会立即创建一个新的执行线程来处理连接,同时主程序可以继续等待更多的连接。以下是一个示例代码:
require 'socket'
server = TCPServer.new(1234)
loop do
Thread.start(server.accept) do |connection|
while line = connection.gets
break if line =~ /quit/
puts line
connection.puts "Received!"
end
connection.puts "Closing the connection. Bye!"
connection.close
end
end
在这个例子中,程序有一个永久循环。当 server.accept 响应时,会立即创建并启动一个新线程来处理刚接受的连接,使用传递给线程的 connection 对象。而主程序会立即回到循环,等待新的连接。
超级会员免费看
订阅专栏 解锁全文
11

被折叠的 条评论
为什么被折叠?



