清华大佬耗费三个月吐血整理的几百G的资源,免费分享!....>>>
#!/usr/bin/env python
#coding:utf8
# Author : tuxpy
# Email : q8886888@qq.com
# Last modified : 2014-10-03 19:22:22
# Filename : client.py
# Description :
from xmlrpclib import ServerProxy, Fault
from cmd import Cmd
from random import choice
from string import lowercase
from core.server import Node, UNHANDLED
from core.data import get_port, get_host
from threading import Thread
from time import sleep
import sys
HEAD_START = 0.1
SECRET_LENGTH = 100
def randomString(length):
chars = []
for i in range(length):
chars.append(choice(lowercase))
return ''.join(chars)
class Client(Cmd):
prompt = '> '
def __init__(self, url , dirname):
Cmd.__init__(self)
self.url = url
self.port = get_port(url) # 这个要当信息广播出去
self.secret = randomString(SECRET_LENGTH)
node = Node(url, dirname, self.secret)
t_node = Thread(target = node._start)
t_node.setDaemon(True)
t_node.start()
sleep(HEAD_START)
self.server = ServerProxy(url)
t_update_known = Thread(target = self.update_known)
t_update_known.setDaemon(True)
t_update_known.start()
def do_fetch(self, arg):
try:
self.server.fetch(arg, self.secret)
except Fault, f:
if f.faultCode != UNHANDLED:raise
print "Couldn't find the file", arg
def do_ls(self, path):
for url,files in self.server.ls().items():
print '%s\n\t%s' % (get_host(url), '\n\t'.join(files))
def update_known(self):
from core.sock import sock
sock = sock()
sock.broadcast(str(self.port)) # 把自己的xml-rpc端口广播给别人
while True:
url = sock.recv_url()
self.server.hello(url, self.secret) # 当收到节点信息时,更新节点
def do_exit(self, arg):
print
sys.exit()
do_EOR = do_exit
def main():
import os
cwd = os.path.dirname(os.path.abspath(sys.argv[0]))
os.chdir(cwd) # 切换成程序所在目录
from core.config import config
cfg = config()
directory = cfg.get('global', 'share_dir')
if not os.path.isdir(directory):
sys.stderr.write("%s not is exist\n" % directory)
sys.exit(1)
url = 'http://localhost:' + cfg.get('global', 'data_port')
client = Client(url, directory)
client.cmdloop()
if __name__ == "__main__":
main()