Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
G
gevent
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Kirill Smelkov
gevent
Commits
7b491cea
Commit
7b491cea
authored
Dec 18, 2015
by
Jason Madden
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
docs about #704 [skip ci]
parent
2a2eb9de
Changes
5
Show whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
35 additions
and
20 deletions
+35
-20
changelog.rst
changelog.rst
+8
-0
doc/whatsnew_1_1.rst
doc/whatsnew_1_1.rst
+15
-16
gevent/resolver_ares.py
gevent/resolver_ares.py
+3
-2
greentest/test__semaphore.py
greentest/test__semaphore.py
+2
-1
greentest/test__threading_vs_settrace.py
greentest/test__threading_vs_settrace.py
+7
-1
No files found.
changelog.rst
View file @
7b491cea
...
@@ -12,6 +12,14 @@
...
@@ -12,6 +12,14 @@
shipped with. Some Linux distributions, including RedHat/CentOS and
shipped with. Some Linux distributions, including RedHat/CentOS and
Amazon have backported the changes to older versions. Reported in
Amazon have backported the changes to older versions. Reported in
:issue:`702`.
:issue:`702`.
- PyPy: An interaction between Cython compiled code and the garbage
collector caused PyPy to crash when a previously-allocated Semaphore
was used in a ``__del__`` method, something done in the popular
libraries ``requests`` and ``urllib3``. Due to this and other Cython
related issues, the Semaphore class is no longer compiled by Cython.
This means that it is now traceable and not exactly as atomic as the
Cython version, though the overall semantics should remain the same.
Reported in :issue:`704` by Shaun Crampton.
1.1rc2 (Dec 11, 2015)
1.1rc2 (Dec 11, 2015)
=====================
=====================
...
...
doc/whatsnew_1_1.rst
View file @
7b491cea
...
@@ -50,25 +50,24 @@ through 4.0.0 and 4.0.1.
...
@@ -50,25 +50,24 @@ through 4.0.0 and 4.0.1.
of PyPy. The benchmarks distributed with gevent typically perform as
of PyPy. The benchmarks distributed with gevent typically perform as
well or better on PyPy than on CPython at least on some platforms.
well or better on PyPy than on CPython at least on some platforms.
Things that are known or expected to be (relatively) slower under
Things that are known or expected to be (relatively) slower under
PyPy include the :mod:`c-ares resolver <gevent.resolver_ares>` and
PyPy include the :mod:`c-ares resolver <gevent.resolver_ares>`.
:class:`gevent.lock.Semaphore`. Whether or not these matter will
Whether or not these matter will depend on the workload of each
depend on the workload of each application.
application.
.. note:: Released versions of PyPy through at least 4.0.0 have `a
.. caution:: The ``c-ares`` resolver is not recommended for use under
bug`_ that can cause a memory leak when subclassing
PyPy. Released versions of PyPy through at least 4.0.1
objects that are implemented in Cython, as are the two
have `a bug`_ that can cause a memory leak when
things mentioned above. The `Semaphore` class is
subclassing objects that are implemented in Cython, as is
subclassed to become :class:`gevent.thread.LockType`,
the c-ares resolver. things mentioned above. The
which in turn is used as the basis for
:class:`threading.Lock`. The `Semaphore` object is coded
carefully to avoid this leak, assuming it is deallocated
when not acquired (which should be the typical case). The
``c-ares`` package has not been audited for this issue.
``c-ares`` package has not been audited for this issue.
In addition, thanks to reports like :issue:`704`, we know
that the PyPy garbage collector can interact badly with
Cython-compiled code, leading to crashes.
.. note:: PyPy 4.0.x on Linux is known to *rarely* (once per 24 hours)
.. note:: PyPy 4.0.x on Linux is known to *rarely* (once per 24 hours)
encounter crashes when running heavily loaded, heavily
encounter crashes when running heavily loaded, heavily
networked gevent programs
. The exact cause is unknown and is
networked gevent programs
(even without ``c-ares``). The
being tracked in :issue:`677`.
exact cause is unknown and is
being tracked in :issue:`677`.
.. _cffi 1.3.0: https://bitbucket.org/cffi/cffi/src/ad3140a30a7b0ca912185ef500546a9fb5525ece/doc/source/whatsnew.rst?at=default
.. _cffi 1.3.0: https://bitbucket.org/cffi/cffi/src/ad3140a30a7b0ca912185ef500546a9fb5525ece/doc/source/whatsnew.rst?at=default
.. _1.2.0: https://cffi.readthedocs.org/en/latest/whatsnew.html#v1-2-0
.. _1.2.0: https://cffi.readthedocs.org/en/latest/whatsnew.html#v1-2-0
...
...
gevent/resolver_ares.py
View file @
7b491cea
...
@@ -27,8 +27,9 @@ class Resolver(object):
...
@@ -27,8 +27,9 @@ class Resolver(object):
reports of it not properly honoring certain system configurations.
reports of it not properly honoring certain system configurations.
However, because it does not use threads, it may scale better.
However, because it does not use threads, it may scale better.
.. note:: This module is considered experimental on PyPy, and
.. caution:: This module is considered extremely experimental on PyPy, and
due to its implementation in cython, it may be slower.
due to its implementation in cython, it may be slower. It may also lead to
interpreter crashes.
.. _c-ares: http://c-ares.haxx.se
.. _c-ares: http://c-ares.haxx.se
"""
"""
...
...
greentest/test__semaphore.py
View file @
7b491cea
...
@@ -34,7 +34,8 @@ class TestSemaphore(greentest.TestCase):
...
@@ -34,7 +34,8 @@ class TestSemaphore(greentest.TestCase):
def
test_semaphore_in_class_with_del
(
self
):
def
test_semaphore_in_class_with_del
(
self
):
# Issue #704. This used to crash the process
# Issue #704. This used to crash the process
# under PyPy through at least 4.0.1
# under PyPy through at least 4.0.1 if the Semaphore
# was implemented with Cython.
class
X
(
object
):
class
X
(
object
):
def
__init__
(
self
):
def
__init__
(
self
):
self
.
s
=
Semaphore
()
self
.
s
=
Semaphore
()
...
...
greentest/test__threading_vs_settrace.py
View file @
7b491cea
...
@@ -48,6 +48,12 @@ sys.stdout.write("..finishing..")
...
@@ -48,6 +48,12 @@ sys.stdout.write("..finishing..")
class
TestTrace
(
unittest
.
TestCase
):
class
TestTrace
(
unittest
.
TestCase
):
def
test_untraceable_lock
(
self
):
def
test_untraceable_lock
(
self
):
# Untraceable locks were part of the solution to https://bugs.python.org/issue1733757
# which details a deadlock that could happen if a trace function invoked
# threading.currentThread at shutdown time---the cleanup lock would be held
# by the VM, and calling currentThread would try to acquire it again. The interpreter
# changed in 2.6 to use the `with` statement (https://hg.python.org/cpython/rev/76f577a9ec03/),
# which apparently doesn't trace in quite the same way.
if
hasattr
(
sys
,
'gettrace'
):
if
hasattr
(
sys
,
'gettrace'
):
old
=
sys
.
gettrace
()
old
=
sys
.
gettrace
()
else
:
else
:
...
@@ -57,7 +63,7 @@ class TestTrace(unittest.TestCase):
...
@@ -57,7 +63,7 @@ class TestTrace(unittest.TestCase):
try
:
try
:
def
trace
(
frame
,
ev
,
arg
):
def
trace
(
frame
,
ev
,
arg
):
lst
.
append
((
frame
.
f_code
.
co_filename
,
frame
.
f_lineno
,
ev
))
lst
.
append
((
frame
.
f_code
.
co_filename
,
frame
.
f_lineno
,
ev
))
if
not
PYPY
:
if
not
PYPY
:
# because we expect to trace on PyPy
print
(
"TRACE: %s:%s %s"
%
lst
[
-
1
])
print
(
"TRACE: %s:%s %s"
%
lst
[
-
1
])
return
trace
return
trace
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment