Browse Source

more log

auth
clowwindy 11 years ago
parent
commit
46d23bf0d4
  1. 3
      shadowsocks/eventloop.py
  2. 6
      shadowsocks/tcprelay.py
  3. 12
      shadowsocks/udprelay.py

3
shadowsocks/eventloop.py

@ -199,9 +199,10 @@ class EventLoop(object):
except (OSError, IOError) as e: except (OSError, IOError) as e:
if errno_from_exception(e) == errno.EPIPE: if errno_from_exception(e) == errno.EPIPE:
# Happens when the client closes the connection # Happens when the client closes the connection
logging.error('poll:%s', e)
continue continue
else: else:
logging.error(e) logging.error('poll:%s', e)
import traceback import traceback
traceback.print_exc() traceback.print_exc()
continue continue

6
shadowsocks/tcprelay.py

@ -589,9 +589,9 @@ class TCPRelay(object):
def _handle_events(self, events): def _handle_events(self, events):
for sock, fd, event in events: for sock, fd, event in events:
# if sock: if sock:
# logging.debug('fd %d %s', fd, logging.debug('fd %d %s', fd,
# eventloop.EVENT_NAMES.get(event, event)) eventloop.EVENT_NAMES.get(event, event))
if sock == self._server_socket: if sock == self._server_socket:
if event & eventloop.POLL_ERR: if event & eventloop.POLL_ERR:
# TODO # TODO

12
shadowsocks/udprelay.py

@ -133,6 +133,8 @@ class UDPRelay(object):
def _handle_server(self): def _handle_server(self):
server = self._server_socket server = self._server_socket
data, r_addr = server.recvfrom(BUF_SIZE) data, r_addr = server.recvfrom(BUF_SIZE)
if not data:
logging.debug('UDP handle_server: data is empty')
if self._is_local: if self._is_local:
frag = ord(data[2]) frag = ord(data[2])
if frag != 0: if frag != 0:
@ -141,9 +143,10 @@ class UDPRelay(object):
else: else:
data = data[3:] data = data[3:]
else: else:
# decrypt data
data = encrypt.encrypt_all(self._password, self._method, 0, data) data = encrypt.encrypt_all(self._password, self._method, 0, data)
# decrypt data
if not data: if not data:
logging.debug('UDP handle_server: data is empty after decrypt')
return return
header_result = parse_header(data) header_result = parse_header(data)
if header_result is None: if header_result is None:
@ -191,6 +194,9 @@ class UDPRelay(object):
def _handle_client(self, sock): def _handle_client(self, sock):
data, r_addr = sock.recvfrom(BUF_SIZE) data, r_addr = sock.recvfrom(BUF_SIZE)
if not data:
logging.debug('UDP handle_client: data is empty')
return
if not self._is_local: if not self._is_local:
addrlen = len(r_addr[0]) addrlen = len(r_addr[0])
if addrlen > 255: if addrlen > 255:
@ -235,8 +241,12 @@ class UDPRelay(object):
def _handle_events(self, events): def _handle_events(self, events):
for sock, fd, event in events: for sock, fd, event in events:
if sock == self._server_socket: if sock == self._server_socket:
if event & eventloop.POLL_ERR:
logging.error('UDP server_socket err')
self._handle_server() self._handle_server()
elif sock and (fd in self._sockets): elif sock and (fd in self._sockets):
if event & eventloop.POLL_ERR:
logging.error('UDP client_socket err')
self._handle_client(sock) self._handle_client(sock)
now = time.time() now = time.time()
if now - self._last_time > 3.5: if now - self._last_time > 3.5:

Loading…
Cancel
Save