Groups | Search | Server Info | Keyboard shortcuts | Login | Register [http] [https] [nntp] [nntps]
Groups > comp.lang.python > #99393
| Path | csiph.com!fu-berlin.de!uni-berlin.de!not-for-mail |
|---|---|
| From | Marc Aymerich <glicerinu@gmail.com> |
| Newsgroups | comp.lang.python |
| Subject | Re: Futex hang when running event loop on a separated thread |
| Date | Tue, 24 Nov 2015 21:22:49 +0100 |
| Lines | 130 |
| Message-ID | <mailman.32.1448396592.20593.python-list@python.org> (permalink) |
| References | <CA+DCN_s77howCh5ptdGwtsF9Z3-r0nRhu-q2t43jdXKTdqSMGw@mail.gmail.com> <CA+DCN_vp8nFS-gOrQMYYefhVt2W0oAP+rFcKQbQ7K+hOHwvuuQ@mail.gmail.com> <CAKJDb-MY9W518kKhFf8vbZAfFad=uGXefDePf1KLpUJV9H3Rpg@mail.gmail.com> <CA+DCN_uC2k=rJxmtfEideAhGj1=2XVq8VHGU=OUkB9yHxV7bPw@mail.gmail.com> <CAKJDb-N5WD_cN2k0kd_aXXyj_2Bsjxye8Q34_3awtw7bGPRx5w@mail.gmail.com> <CA+DCN_uNHNHrBOSmd0JE58Ltt6HzrDWU_DhW_1N3dFMAVNpVOQ@mail.gmail.com> |
| Mime-Version | 1.0 |
| Content-Type | text/plain; charset=UTF-8 |
| X-Trace | news.uni-berlin.de MtTc7dYjCQ8H13wiwjWnQA07q4aM4eDxCbSHqOCeWodA== |
| Return-Path | <glicerinu@gmail.com> |
| X-Original-To | python-list@python.org |
| Delivered-To | python-list@mail.python.org |
| X-Spam-Status | OK 0.000 |
| X-Spam-Evidence | '*H*': 1.00; '*S*': 0.00; 'handler': 0.04; 'finally:': 0.05; 'sys': 0.05; '[],': 0.07; '__name__': 0.07; 'differently': 0.07; 'implements': 0.07; 'null,': 0.07; 'skip:/ 10': 0.07; 'works.': 0.07; 'cc:addr:python-list': 0.09; '0.1': 0.09; 'behave': 0.09; 'directions': 0.09; 'grep': 0.09; 'mkdir': 0.09; 'thread': 0.10; 'python': 0.10; 'def': 0.13; "'__main__':": 0.16; '24,': 0.16; 'aux': 0.16; 'enotconn': 0.16; 'fix,': 0.16; 'fuse': 0.16; 'osx': 0.16; 'received:io': 0.16; 'received:psf.io': 0.16; 'reproduce': 0.16; 'skip:{ 40': 0.16; 'stuff,': 0.16; 'subject:when': 0.16; 'sudo': 0.16; 'threading': 0.16; 'wrote:': 0.16; 'ssl': 0.18; 'try:': 0.18; 'python?': 0.18; '>>>': 0.20; '2015': 0.20; 'cc:2**0': 0.20; 'cc:addr:python.org': 0.20; 'null)': 0.22; 'appears': 0.23; 'bit': 0.23; 'tried': 0.24; 'import': 0.24; 'patch': 0.24; 'header:In-Reply-To:1': 0.24; 'install': 0.25; "i've": 0.25; 'command': 0.26; 'message- id:@mail.gmail.com': 0.27; 'idea': 0.28; 'skip:u 20': 0.28; '0.5': 0.29; 'marc': 0.29; "i'm": 0.30; 'url:mailman': 0.30; 'operations': 0.31; 'skip:s 30': 0.31; 'another': 0.32; "can't": 0.32; 'maybe': 0.33; 'url:python': 0.33; 'evolving': 0.33; 'null': 0.33; 'ubuntu': 0.33; 'url:listinfo': 0.34; "skip:' 20": 0.34; 'tue,': 0.34; 'server': 0.34; 'received:google.com': 0.35; 'could': 0.35; 'nov': 0.35; 'but': 0.36; 'url:org': 0.36; 'received:209.85': 0.36; 'skip:{ 10': 0.36; 'pm,': 0.36; 'subject:: ': 0.37; 'received:209.85.213': 0.37; 'version': 0.38; 'received:209': 0.38; 'thank': 0.38; 'why': 0.39; 'url:mail': 0.40; 'still': 0.40; 'some': 0.40; 'hang': 0.60; 'waiting': 0.60; 'your': 0.60; 'confirm': 0.62; 'fire': 0.63; 'more': 0.63; 'between': 0.65; 'here': 0.66; '12:37': 0.84; 'detached': 0.84; 'to:none': 0.91; 'interrupt': 0.91; 'ware': 0.91 |
| DKIM-Signature | v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20120113; h=mime-version:in-reply-to:references:from:date:message-id:subject:cc :content-type; bh=VCet48jOTOXmw4CS5MmpOvvxZsBAyI53ygURTqxX1Uo=; b=nXz16D1pKzvLckTMO8VWoGK/m8ZQqDk7dqFFTVnN6lE6yXZZ/kOEPn4vA4EctSJ4Xi AgNVkpZyELmGIRbLt988ROzBYbUN5oitlPrub+jia23oA8UDe6YKXyXa8Z3evrC54KkX Tda6MhwcH0CkV8Gb/iXx1BzzZx7Kh6287VoiY6u2lFfsFbxHCf/HwLcK0YhOpuAtZkwW FGtTdIl3lLnKgUOOEg76/Tq/hpx6OaQxEXYrHj0oF/8el0WNsKVZnaPT8ZOH43PJbSf+ QMBzZoFNDpc6jzZmL2sewNHCnE0KhJdhcHlrpsLN0qHvMj/HcQxdBxWkY8MDWpYhi1yb si2A== |
| X-Received | by 10.50.66.144 with SMTP id f16mr338850igt.22.1448396588707; Tue, 24 Nov 2015 12:23:08 -0800 (PST) |
| In-Reply-To | <CA+DCN_uNHNHrBOSmd0JE58Ltt6HzrDWU_DhW_1N3dFMAVNpVOQ@mail.gmail.com> |
| X-BeenThere | python-list@python.org |
| X-Mailman-Version | 2.1.20+ |
| Precedence | list |
| List-Id | General discussion list for the Python programming language <python-list.python.org> |
| List-Unsubscribe | <https://mail.python.org/mailman/options/python-list>, <mailto:python-list-request@python.org?subject=unsubscribe> |
| List-Archive | <http://mail.python.org/pipermail/python-list/> |
| List-Post | <mailto:python-list@python.org> |
| List-Help | <mailto:python-list-request@python.org?subject=help> |
| List-Subscribe | <https://mail.python.org/mailman/listinfo/python-list>, <mailto:python-list-request@python.org?subject=subscribe> |
| Xref | csiph.com comp.lang.python:99393 |
Show key headers only | View raw
On Tue, Nov 24, 2015 at 9:17 PM, Marc Aymerich <glicerinu@gmail.com> wrote:
> On Tue, Nov 24, 2015 at 8:41 PM, Zachary Ware
> <zachary.ware+pylist@gmail.com> wrote:
>> On Tue, Nov 24, 2015 at 12:37 PM, Marc Aymerich <glicerinu@gmail.com> wrote:
>>> still it appears to work only if the main thread is in the foreground
>>> (as of calling Thread() with deamon=True), I don't get why it behaves
>>> differently :( maybe it is waiting for other stuff, but no idea how to
>>> confirm this with strace of other means.. i always see the same
>>> 'futex(0x7f9a70000c10, FUTEX_WAIT_PRIVATE, 0, NULL'
>>
>> What's your exact version of Python? asyncio is still evolving
>> rapidly, and may behave differently between patch releases (say,
>> between 3.4.1 and 3.4.3).
>>
>> I have tried out your reproducer with my fix, and I can't provoke a
>> hang using Python 3.4.3 on either OSX or Ubuntu Trusty. Can you give
>> some more specific directions to reproduce?
>>
>> --
>> Zach
>> --
>> https://mail.python.org/mailman/listinfo/python-list
>
>
> Yep, I'm a bit lost about how fuse implements going into background...
> so the only way I have to reproduce this so far is by using fuse :(
>
> # pip3 install fusepy
> import asyncio
> import threading
> import time
> import os
> import sys
> from fuse import FUSE, Operations
>
> def run_loop(loop_container):
> loop = asyncio.new_event_loop()
> asyncio.set_event_loop(loop)
> coro = asyncio.start_server(lambda: 1, '0.0.0.0', 8888, loop=loop)
> server = loop.run_until_complete(coro)
> loop_container['loop'] = loop
> loop.run_forever()
>
> if __name__ == '__main__':
> mountpoint = sys.argv[1]
> loop_container = {}
> handler = threading.Thread(target=run_loop, args=(loop_container,))
> handler.start()
> try:
> # with foreground=True works
> FUSE(Operations(), mountpoint, foreground=False)
> finally:
> loop_container['loop'].call_soon_threadsafe(loop_container['loop'].stop)
>
>
> $ mkdir /tmp/7777
> $ python3.5 /tmp/eventtest.py /tmp/7777
>
> # Another terminal
> $ ps aux | grep python3.5
> glic3 19983 0.5 0.1 215540 10772 ? Ssl 21:05 0:00
> python3.5 me.py /tmp/7777
> $ sudo strace -p 19983
> Process 19983 attached - interrupt to quit
> futex(0x7fff42affca0, FUTEX_WAIT_PRIVATE, 0, NULL) = 0
>
> # Here i fire
> $ fusermount -u /tmp/7777
>
> tgkill(19983, 19985, SIGRTMIN) = 0
> futex(0x7fff42affc30, FUTEX_WAKE_PRIVATE, 1) = 0
> futex(0x7f9840afc9d0, FUTEX_WAIT, 19984, NULL
>
>
> I've just tried with python3.5 and the same behavior. The thing is
> that with foreground=True it just works.
> thank you for your time!
In case this could be of some use:
strace using foreground=True
$ sudo strace -p 20326
Process 20326 attached - interrupt to quit
futex(0x7fffd9b8e5a0, FUTEX_WAIT_PRIVATE, 0, NULL
# Here umount command
) = 0
tgkill(20326, 20334, SIGRTMIN) = 0
tgkill(20326, 20335, SIGRTMIN) = 0
futex(0x7fffd9b8e530, FUTEX_WAKE_PRIVATE, 1) = 0
rt_sigaction(SIGHUP, NULL, {0x7fb60d850540, [], SA_RESTORER,
0x7fb61106ccb0}, 8) = 0
rt_sigaction(SIGINT, NULL, {0x7fb60d850540, [], SA_RESTORER,
0x7fb61106ccb0}, 8) = 0
rt_sigaction(SIGTERM, NULL, {0x7fb60d850540, [], SA_RESTORER,
0x7fb61106ccb0}, 8) = 0
rt_sigaction(SIGPIPE, NULL, {SIG_IGN, [], SA_RESTORER, 0x7fb61106ccb0}, 8) = 0
poll([{fd=5, events=0}], 1, 0) = 1 ([{fd=5, revents=POLLERR}])
close(5) = 0
brk(0x126d000) = 0x126d000
rt_sigaction(SIGINT, {0x50b380, [], SA_RESTORER, 0x7fb61106ccb0},
{0x7fb60d850540, [], SA_RESTORER, 0x7fb61106ccb0}, 8) = 0
sendto(8, "\0", 1, 0, NULL, 0) = 1
futex(0x7fb600001740, FUTEX_WAKE_PRIVATE, 1) = 1
futex(0x9d3204, FUTEX_WAKE_OP_PRIVATE, 1, 1, 0x9d3200, {FUTEX_OP_SET,
0, FUTEX_OP_CMP_GT, 1}) = 1
futex(0x9d31c0, FUTEX_WAKE_PRIVATE, 1) = 1
futex(0x7fb600000c10, FUTEX_WAIT_PRIVATE, 0, NULL) = 0
rt_sigaction(SIGINT, {SIG_DFL, [], SA_RESTORER, 0x7fb61106ccb0},
{0x50b380, [], SA_RESTORER, 0x7fb61106ccb0}, 8) = 0
epoll_ctl(4, EPOLL_CTL_DEL, 7,
{EPOLLWRBAND|EPOLLMSG|EPOLLERR|0xdea9800, {u32=32694,
u64=23586238107778998}}) = 0
close(7) = 0
close(8) = 0
close(4) = 0
getsockname(6, {sa_family=AF_INET, sin_port=htons(8888),
sin_addr=inet_addr("0.0.0.0")}, [16]) = 0
getpeername(6, 0x7fffd9b8dc70, [16]) = -1 ENOTCONN (Transport
endpoint is not connected)
close(6) = 0
madvise(0x7fb600033000, 8192, MADV_DONTNEED) = 0
close(3) = 0
exit_group(0) = ?
Process 20326 detached
--
Marc
Back to comp.lang.python | Previous | Next | Find similar | Unroll thread
Re: Futex hang when running event loop on a separated thread Marc Aymerich <glicerinu@gmail.com> - 2015-11-24 21:22 +0100
csiph-web