| 30 |
ashish |
1 |
#
|
|
|
2 |
# Licensed to the Apache Software Foundation (ASF) under one
|
|
|
3 |
# or more contributor license agreements. See the NOTICE file
|
|
|
4 |
# distributed with this work for additional information
|
|
|
5 |
# regarding copyright ownership. The ASF licenses this file
|
|
|
6 |
# to you under the Apache License, Version 2.0 (the
|
|
|
7 |
# "License"); you may not use this file except in compliance
|
|
|
8 |
# with the License. You may obtain a copy of the License at
|
|
|
9 |
#
|
|
|
10 |
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
11 |
#
|
|
|
12 |
# Unless required by applicable law or agreed to in writing,
|
|
|
13 |
# software distributed under the License is distributed on an
|
|
|
14 |
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
|
15 |
# KIND, either express or implied. See the License for the
|
|
|
16 |
# specific language governing permissions and limitations
|
|
|
17 |
# under the License.
|
|
|
18 |
#
|
|
|
19 |
|
|
|
20 |
require 'thread'
|
|
|
21 |
|
|
|
22 |
module Thrift
|
|
|
23 |
class ThreadedServer < BaseServer
|
|
|
24 |
def serve
|
|
|
25 |
begin
|
|
|
26 |
@server_transport.listen
|
|
|
27 |
loop do
|
|
|
28 |
client = @server_transport.accept
|
|
|
29 |
trans = @transport_factory.get_transport(client)
|
|
|
30 |
prot = @protocol_factory.get_protocol(trans)
|
|
|
31 |
Thread.new(prot, trans) do |p, t|
|
|
|
32 |
begin
|
|
|
33 |
loop do
|
|
|
34 |
@processor.process(p, p)
|
|
|
35 |
end
|
|
|
36 |
rescue Thrift::TransportException, Thrift::ProtocolException
|
|
|
37 |
ensure
|
|
|
38 |
t.close
|
|
|
39 |
end
|
|
|
40 |
end
|
|
|
41 |
end
|
|
|
42 |
ensure
|
|
|
43 |
@server_transport.close
|
|
|
44 |
end
|
|
|
45 |
end
|
|
|
46 |
end
|
|
|
47 |
end
|