Andre_487
@Andre_487
Разработчик веб-сервисов

Twisted: сокет-сервер под высокой нагрузкой

Задача сделать сервер, который пересылает строки между определенными клиентами. В принципе, задача не слишком сложная, и для ее реализации почти что подходит принцип из примера чата из документации:
Код
from twisted.internet.protocol import Factory
from twisted.protocols.basic import LineReceiver
from twisted.internet import reactor

class Chat(LineReceiver):

    def __init__(self, users):
        self.users = users
        self.name = None
        self.state = "GETNAME"

    def connectionMade(self):
        self.sendLine("What's your name?")

    def connectionLost(self, reason):
        if self.users.has_key(self.name):
            del self.users[self.name]

    def lineReceived(self, line):
        if self.state == "GETNAME":
            self.handle_GETNAME(line)
        else:
            self.handle_CHAT(line)

    def handle_GETNAME(self, name):
        if self.users.has_key(name):
            self.sendLine("Name taken, please choose another.")
            return
        self.sendLine("Welcome, %s!" % (name,))
        self.name = name
        self.users[name] = self
        self.state = "CHAT"

    def handle_CHAT(self, message):
        message = "<%s> %s" % (self.name, message)
        for name, protocol in self.users.iteritems():
            if protocol != self:
                protocol.sendLine(message)


class ChatFactory(Factory):

    def __init__(self):
        self.users = {} # maps user names to Chat instances

    def buildProtocol(self, addr):
        return Chat(self.users)


reactor.listenTCP(8123, ChatFactory())
reactor.run()


Но я не нашел достаточное количество информации по поводу, как поведет себя такая программа, если нагрузка будет большой, несколько сотен или даже тысяч одновременных соединений. Хотелось бы узнать побольше информации от опытных в этой области товарищей.
  • Вопрос задан
  • 4185 просмотров
Решения вопроса 1
Хорошо поведет, если использовать более производительный пул (epoll, poll) — то все будет хорошо :)
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы