當前位置: 首頁>>代碼示例>>Python>>正文


Python greenio.GreenSocket方法代碼示例

本文整理匯總了Python中eventlet.greenio.GreenSocket方法的典型用法代碼示例。如果您正苦於以下問題:Python greenio.GreenSocket方法的具體用法?Python greenio.GreenSocket怎麽用?Python greenio.GreenSocket使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在eventlet.greenio的用法示例。


在下文中一共展示了greenio.GreenSocket方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: run

# 需要導入模塊: from eventlet import greenio [as 別名]
# 或者: from eventlet.greenio import GreenSocket [as 別名]
def run(self):
        acceptors = []
        for sock in self.sockets:
            gsock = GreenSocket(sock)
            gsock.setblocking(1)
            hfun = partial(self.handle, gsock)
            acceptor = eventlet.spawn(_eventlet_serve, gsock, hfun,
                                      self.worker_connections)

            acceptors.append(acceptor)
            eventlet.sleep(0.0)

        while self.alive:
            self.notify()
            eventlet.sleep(1.0)

        self.notify()
        try:
            with eventlet.Timeout(self.cfg.graceful_timeout) as t:
                [a.kill(eventlet.StopServe()) for a in acceptors]
                [a.wait() for a in acceptors]
        except eventlet.Timeout as te:
            if te != t:
                raise
            [a.kill() for a in acceptors] 
開發者ID:yelongyu,項目名稱:chihu,代碼行數:27,代碼來源:geventlet.py

示例2: _init_events_pipe

# 需要導入模塊: from eventlet import greenio [as 別名]
# 或者: from eventlet.greenio import GreenSocket [as 別名]
def _init_events_pipe(self):
        """Create a self-pipe for the native thread to synchronize on.

        This code is taken from the eventlet tpool module, under terms
        of the Apache License v2.0.
        """

        self._event_queue = native_Queue.Queue()
        try:
            rpipe, wpipe = os.pipe()
            self._event_notify_send = greenio.GreenPipe(wpipe, 'wb', 0)
            self._event_notify_recv = greenio.GreenPipe(rpipe, 'rb', 0)
        except (ImportError, NotImplementedError):
            # This is Windows compatibility -- use a socket instead
            #  of a pipe because pipes don't really exist on Windows.
            sock = native_socket.socket(socket.AF_INET, socket.SOCK_STREAM)
            sock.bind(('localhost', 0))
            sock.listen(50)
            csock = native_socket.socket(socket.AF_INET, socket.SOCK_STREAM)
            csock.connect(('localhost', sock.getsockname()[1]))
            nsock, addr = sock.accept()
            self._event_notify_send = nsock.makefile('wb', 0)
            gsock = greenio.GreenSocket(csock)
            self._event_notify_recv = gsock.makefile('rb', 0) 
開發者ID:BU-NU-CLOUD-SP16,項目名稱:Trusted-Platform-Module-nova,代碼行數:26,代碼來源:host.py

示例3: run

# 需要導入模塊: from eventlet import greenio [as 別名]
# 或者: from eventlet.greenio import GreenSocket [as 別名]
def run(self):
        acceptors = []
        for sock in self.sockets:
            gsock = GreenSocket(sock)
            gsock.setblocking(1)
            hfun = partial(self.handle, gsock)
            acceptor = eventlet.spawn(_eventlet_serve, gsock, hfun,
                                      self.worker_connections)

            acceptors.append(acceptor)
            eventlet.sleep(0.0)

        while self.alive:
            self.notify()
            try:
                eventlet.sleep(1.0)
            except AssertionError:
                self.alive = False
                break

        self.notify()
        try:
            with eventlet.Timeout(self.cfg.graceful_timeout) as t:
                [a.kill(eventlet.StopServe()) for a in acceptors]
                [a.wait() for a in acceptors]
        except eventlet.Timeout as te:
            if te != t:
                raise
            [a.kill() for a in acceptors] 
開發者ID:RoseOu,項目名稱:flasky,代碼行數:31,代碼來源:geventlet.py

示例4: setup

# 需要導入模塊: from eventlet import greenio [as 別名]
# 或者: from eventlet.greenio import GreenSocket [as 別名]
def setup():
    global _rsock, _wsock, _coro, _setup_already, _rspq, _reqq
    if _setup_already:
        return
    else:
        _setup_already = True

    assert _nthreads >= 0, "Can't specify negative number of threads"
    if _nthreads == 0:
        import warnings
        warnings.warn("Zero threads in tpool.  All tpool.execute calls will\
            execute in main thread.  Check the value of the environment \
            variable EVENTLET_THREADPOOL_SIZE.", RuntimeWarning)
    _reqq = Queue(maxsize=-1)
    _rspq = Queue(maxsize=-1)

    # connected socket pair
    sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    sock.bind(('127.0.0.1', 0))
    sock.listen(1)
    csock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    csock.connect(sock.getsockname())
    csock.setsockopt(socket.IPPROTO_TCP, socket.TCP_NODELAY, True)
    _wsock, _addr = sock.accept()
    _wsock.setsockopt(socket.IPPROTO_TCP, socket.TCP_NODELAY, True)
    sock.close()
    _rsock = greenio.GreenSocket(csock)

    for i in six.moves.range(_nthreads):
        t = threading.Thread(target=tworker,
                             name="tpool_thread_%s" % i)
        t.setDaemon(True)
        t.start()
        _threads.append(t)

    _coro = greenthread.spawn_n(tpool_trampoline)
    # This yield fixes subtle error with GreenSocket.__del__
    eventlet.sleep(0)


# Avoid ResourceWarning unclosed socket on Python3.2+ 
開發者ID:htwenning,項目名稱:remoteControlPPT,代碼行數:43,代碼來源:tpool.py

示例5: fromfd

# 需要導入模塊: from eventlet import greenio [as 別名]
# 或者: from eventlet.greenio import GreenSocket [as 別名]
def fromfd(*args):
        return socket(__original_fromfd__(*args)) 
開發者ID:htwenning,項目名稱:remoteControlPPT,代碼行數:4,代碼來源:_socket_nodns.py

示例6: socketpair

# 需要導入模塊: from eventlet import greenio [as 別名]
# 或者: from eventlet.greenio import GreenSocket [as 別名]
def socketpair(*args):
        one, two = __original_socketpair__(*args)
        return socket(one), socket(two) 
開發者ID:htwenning,項目名稱:remoteControlPPT,代碼行數:5,代碼來源:_socket_nodns.py

示例7: test_connect_timeout

# 需要導入模塊: from eventlet import greenio [as 別名]
# 或者: from eventlet.greenio import GreenSocket [as 別名]
def test_connect_timeout(self):
        s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        s.settimeout(0.1)
        gs = greenio.GreenSocket(s)

        try:
            expect_socket_timeout(gs.connect, ('192.0.2.1', 80))
        except socket.error as e:
            # unreachable is also a valid outcome
            if not get_errno(e) in (errno.EHOSTUNREACH, errno.ENETUNREACH):
                raise 
開發者ID:openstack,項目名稱:deb-python-eventlet,代碼行數:13,代碼來源:greenio_test.py

示例8: test_accept_timeout

# 需要導入模塊: from eventlet import greenio [as 別名]
# 或者: from eventlet.greenio import GreenSocket [as 別名]
def test_accept_timeout(self):
        s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        s.bind(('', 0))
        s.listen(50)

        s.settimeout(0.1)
        gs = greenio.GreenSocket(s)
        expect_socket_timeout(gs.accept) 
開發者ID:openstack,項目名稱:deb-python-eventlet,代碼行數:10,代碼來源:greenio_test.py

示例9: test_connect_ex_timeout

# 需要導入模塊: from eventlet import greenio [as 別名]
# 或者: from eventlet.greenio import GreenSocket [as 別名]
def test_connect_ex_timeout(self):
        s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
        s.settimeout(0.1)
        gs = greenio.GreenSocket(s)
        e = gs.connect_ex(('192.0.2.1', 80))
        if e not in (errno.EHOSTUNREACH, errno.ENETUNREACH):
            self.assertEqual(e, errno.EAGAIN) 
開發者ID:openstack,項目名稱:deb-python-eventlet,代碼行數:9,代碼來源:greenio_test.py

示例10: test_recv_timeout

# 需要導入模塊: from eventlet import greenio [as 別名]
# 或者: from eventlet.greenio import GreenSocket [as 別名]
def test_recv_timeout(self):
        listener = greenio.GreenSocket(socket.socket())
        listener.bind(('', 0))
        listener.listen(50)

        evt = event.Event()

        def server():
            # accept the connection in another greenlet
            sock, addr = listener.accept()
            evt.wait()

        gt = eventlet.spawn(server)

        addr = listener.getsockname()

        client = greenio.GreenSocket(socket.socket())
        client.settimeout(0.1)

        client.connect(addr)

        expect_socket_timeout(client.recv, 0)
        expect_socket_timeout(client.recv, 8192)

        evt.send()
        gt.wait() 
開發者ID:openstack,項目名稱:deb-python-eventlet,代碼行數:28,代碼來源:greenio_test.py

示例11: test_recvfrom_timeout

# 需要導入模塊: from eventlet import greenio [as 別名]
# 或者: from eventlet.greenio import GreenSocket [as 別名]
def test_recvfrom_timeout(self):
        gs = greenio.GreenSocket(
            socket.socket(socket.AF_INET, socket.SOCK_DGRAM))
        gs.settimeout(.1)
        gs.bind(('', 0))

        expect_socket_timeout(gs.recvfrom, 0)
        expect_socket_timeout(gs.recvfrom, 8192) 
開發者ID:openstack,項目名稱:deb-python-eventlet,代碼行數:10,代碼來源:greenio_test.py

示例12: test_recv_into_timeout

# 需要導入模塊: from eventlet import greenio [as 別名]
# 或者: from eventlet.greenio import GreenSocket [as 別名]
def test_recv_into_timeout(self):
        buf = array.array('B')

        listener = greenio.GreenSocket(socket.socket())
        listener.bind(('', 0))
        listener.listen(50)

        evt = event.Event()

        def server():
            # accept the connection in another greenlet
            sock, addr = listener.accept()
            evt.wait()

        gt = eventlet.spawn(server)

        addr = listener.getsockname()

        client = greenio.GreenSocket(socket.socket())
        client.settimeout(0.1)

        client.connect(addr)

        expect_socket_timeout(client.recv_into, buf)

        evt.send()
        gt.wait() 
開發者ID:openstack,項目名稱:deb-python-eventlet,代碼行數:29,代碼來源:greenio_test.py

示例13: test_send_timeout

# 需要導入模塊: from eventlet import greenio [as 別名]
# 或者: from eventlet.greenio import GreenSocket [as 別名]
def test_send_timeout(self):
        self.reset_timeout(2)
        listener = bufsized(eventlet.listen(('', 0)))

        evt = event.Event()

        def server():
            # accept the connection in another greenlet
            sock, addr = listener.accept()
            sock = bufsized(sock)
            evt.wait()

        gt = eventlet.spawn(server)

        addr = listener.getsockname()

        client = bufsized(greenio.GreenSocket(socket.socket()))
        client.connect(addr)

        client.settimeout(0.00001)
        msg = b"A" * 100000  # large enough number to overwhelm most buffers

        # want to exceed the size of the OS buffer so it'll block in a
        # single send
        def send():
            for x in range(10):
                client.send(msg)

        expect_socket_timeout(send)

        evt.send()
        gt.wait() 
開發者ID:openstack,項目名稱:deb-python-eventlet,代碼行數:34,代碼來源:greenio_test.py

示例14: test_sendall_timeout

# 需要導入模塊: from eventlet import greenio [as 別名]
# 或者: from eventlet.greenio import GreenSocket [as 別名]
def test_sendall_timeout(self):
        listener = greenio.GreenSocket(socket.socket())
        listener.bind(('', 0))
        listener.listen(50)

        evt = event.Event()

        def server():
            # accept the connection in another greenlet
            sock, addr = listener.accept()
            evt.wait()

        gt = eventlet.spawn(server)

        addr = listener.getsockname()

        client = greenio.GreenSocket(socket.socket())
        client.settimeout(0.1)
        client.connect(addr)

        # want to exceed the size of the OS buffer so it'll block
        msg = b"A" * (8 << 20)
        expect_socket_timeout(client.sendall, msg)

        evt.send()
        gt.wait() 
開發者ID:openstack,項目名稱:deb-python-eventlet,代碼行數:28,代碼來源:greenio_test.py

示例15: test_datagram_socket_operations_work

# 需要導入模塊: from eventlet import greenio [as 別名]
# 或者: from eventlet.greenio import GreenSocket [as 別名]
def test_datagram_socket_operations_work(self):
        receiver = greenio.GreenSocket(socket.AF_INET, socket.SOCK_DGRAM)
        receiver.bind(('127.0.0.1', 0))
        address = receiver.getsockname()

        sender = greenio.GreenSocket(socket.AF_INET, socket.SOCK_DGRAM)

        # Two ways sendto can be called
        sender.sendto(b'first', address)
        sender.sendto(b'second', 0, address)

        sender_address = ('127.0.0.1', sender.getsockname()[1])
        eq_(receiver.recvfrom(1024), (b'first', sender_address))
        eq_(receiver.recvfrom(1024), (b'second', sender_address)) 
開發者ID:openstack,項目名稱:deb-python-eventlet,代碼行數:16,代碼來源:greenio_test.py


注:本文中的eventlet.greenio.GreenSocket方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。