1
0
python-billiard/python-billiard.changes

236 lines
10 KiB
Plaintext

-------------------------------------------------------------------
Wed Sep 25 18:26:02 UTC 2013 - p.drouand@gmail.com
- Update to version 2.7.3.32
+ Fixed compatibility with Python 3.3
+ Process boostrap: Now ignores errors while flushing stdout (Issue #16)
- Changes from version 2.7.3.31
+ Recent changes broke support for running without C extension (Issue #57)
- Changes from version 2.7.3.30
+ Fixed ImportError in billiard._ext
- Changes from version 2.7.3.29
+ Compilation: Fixed improper handling of HAVE_SEM_OPEN (Issue #55)
+ Process now releases logging locks after fork.
+ Pool.terminate_job now ignores No such process errors.
+ billiard.Pool entrypoint did not support new arguments to billiard.pool.Pool
+ Connection inbound buffer size increased from 1kb to 128kb.
+ C extension cleaned up by properly adding a namespace to symbols.
+_exit_function now works even if thread wakes up after gc collect.
-------------------------------------------------------------------
Fri Jun 28 09:13:02 UTC 2013 - speilicke@suse.com
- Update to version 2.7.3.28:
+ Pool: Fixed regression that disabled the deadlock fix in 2.7.3.24
+ Pool: RestartFreqExceeded could be raised prematurely.
+ Process: Include pid in startup and process INFO logs.
- Changes from version 2.7.3.27:
+ Manager now works again.
+ Python 3 fixes for billiard.connection.
+ Fixed invalid argument bug when running on Python 3.3
+ Ignore OSError when setting up signal handlers.
- Changes from version 2.7.3.26:
+ Pool: Child processes must ignore SIGINT.
- Changes from version 2.7.3.25:
+ Pool: 2.7.3.24 broke support for subprocesses (Issue #48).
- Changes from version 2.7.3.24:
+ Pool: Make sure finally blocks are called when process exits due to a signal.
+ Pool: Can now use GDB to debug pool child processes.
+ Fixes Python 3 compatibility problems.
-------------------------------------------------------------------
Fri Mar 22 16:17:18 UTC 2013 - alexandre@exatati.com.br
- Update to 2.7.3.23:
- Windows: Now catches SystemExit from setuptools while trying to
build the C extension (Issue #41).
- Aditional changes from 2.7.3.22:
- Pool: apply_async now supports a callbacks_propagate keyword
argument that can be a tuple of exceptions to propagate in
callbacks. (callback, errback, accept_callback, timeout_callback).
- Errors are no longer logged for OK and recycle exit codes.
This would cause normal maxtasksperchild recycled process
to log an error.
- Fixed Python 2.5 compatibility problem (Issue #33).
- FreeBSD: Compilation now disables semaphores if Python was built
without it (Issue #40).
Contributed by William Grzybowski
- Aditional changes from 2.7.3.21:
- Fixed typo EX_REUSE -> EX_RECYCLE
- Code now conforms to new pep8.py rules.
- Aditional changes from 2.7.3.20:
- Pool: Disable restart limit if maxR is not set.
- Pool: Now uses os.kill instead of signal.signal.
Contributed by Lukasz Langa
- Fixed name error in process.py
- Pool: ApplyResult.get now properly raises exceptions.
Fix contributed by xentac.
-------------------------------------------------------------------
Fri Jan 25 21:10:36 UTC 2013 - jfunk@funktronics.ca
- Update to 2.7.3.19:
* Fixes problem at shutdown when gc has collected symbols.
* Pool now always uses _kill for Py2.5 compatibility on Windows (Issue
#32).
* Fixes Python 3 compatibility issues
-------------------------------------------------------------------
Tue Nov 13 20:56:40 UTC 2012 - jfunk@funktronics.ca
- Update to 2.7.3.18:
* [Pool] Fix for check_timeouts if not set.
Fix contributed by Dmitry Sukhov
* Fixed pickle problem with Traceback.
Code.frame.__loader__ is now ignored as it may be set to an unpickleable
object.
* The Django old-layout warning was always showing.
2.7.3.17 - 2012-09-26
* Fixes typo
2.7.3.16 - 2012-09-26
* Windows: Fixes for SemLock._rebuild (Issue #24).
* Pool: Job terminated with terminate_job now raises
billiard.exceptions.Terminated.
2.7.3.15 - 2012-09-21
* Windows: Fixes unpickling of SemLock when using fallback.
* Windows: Fixes installation when no C compiler.
2.7.3.14 - 2012-09-20
* Installation now works again for Python 3.
2.7.3.13 - 2012-09-14
* Merged with Python trunk (many authors, many fixes: see Python changelog
in trunk).
* Using execv now also works with older Django projects using setup_environ
(Issue #10).
* Billiard now installs with a warning that the C extension could not be
built if a compiler is not installed or the build fails in some other way.
It really is recommended to have the C extension installed when running
with force execv, but this change also makes it easier to install.
* Pool: Hard timeouts now sends KILL shortly after TERM so that C extensions
cannot block the signal.
Python signal handlers are called in the interpreter, so they cannot be
called while a C extension is blocking the interpreter from running.
* Now uses a timeout value for Thread.join that doesn't exceed the maximum
on some platforms.
* Fixed bug in the SemLock fallback used when C extensions not installed.
Fix contributed by Mher Movsisyan.
* Pool: Now sets a Process.index attribute for every process in the pool.
This number will always be between 0 and concurrency-1, and can be used
to e.g. create a logfile for each process in the pool without creating a
new logfile whenever a process is replaced.
2.7.3.12 - 2012-08-05
* Fixed Python 2.5 compatibility issue.
* New Pool.terminate_job(pid) to terminate a job without raising
WorkerLostError
2.7.3.11 - 2012-08-01
* Adds support for FreeBSD 7+
Fix contributed by koobs.
* Pool: New argument allow_restart is now required to enable the pool
process sentinel that is required to restart the pool.
It's disabled by default, which reduces the number of file descriptors/
semaphores required to run the pool.
* Pool: Now emits a warning if a worker process exited with error-code.
But not if the error code is 155, which is now returned if the worker
process was recycled (maxtasksperchild).
* Python 3 compatibility fixes.
* Python 2.5 compatibility fixes.
2.7.3.10 - 2012-06-26
* The TimeLimitExceeded exception string representation only included the
seconds as a number, it now gives a more human friendly description.
* Fixed typo in LaxBoundedSemaphore.shrink.
* Pool: ResultHandler.handle_event no longer requires any arguments.
* setup.py bdist now works
2.7.3.9 - 2012-06-03
* Environment variable MP_MAIN_FILE envvar is now set to the path of the
__main__ module when execv is enabled.
* Pool: Errors occurring in the TaskHandler are now reported.
2.7.3.8 - 2012-06-01
* Can now be installed on Py 3.2
* Issue #12091: simplify ApplyResult and MapResult with threading.Event
Patch by Charles-Francois Natali
* Pool: Support running without TimeoutHandler thread.
* The with_*_thread arguments has also been replaced with a single
threads=True argument.
* Two new pool callbacks:
* on_timeout_set(job, soft, hard)
Applied when a task is executed with a timeout.
* on_timeout_cancel(job)
Applied when a timeout is cancelled (the job completed)
-------------------------------------------------------------------
Wed May 23 22:17:05 UTC 2012 - jfunk@funktronics.ca
- Update to 2.7.3.7
* Fixes Python 2.5 support.
- 2.7.3.6 - 2012-05-21
* Pool: Can now be used in an event loop, without starting the supporting
threads (TimeoutHandler still not supported)
* Pool: Process too frequent restart protection now only counts if the
process had a non-successful exitcode.
* Pool: New options max_restart + max_restart_freq
* Pool: The ``WorkerLostError`` message now includes the exitcode of the
process that disappeared.
- Build HTML docs
-------------------------------------------------------------------
Thu May 17 23:40:18 UTC 2012 - jfunk@funktronics.ca
- Update to 2.7.3.5
* Now always cleans up after sys.exc_info() to avoid cyclic references.
* ExceptionInfo without arguments now defaults to sys.exc_info.
* Forking can now be disabled using the MULTIPROCESSING_FORKING_DISABLE
environment variable.
Also this envvar is set so that the behavior is inherited after execv.
* The semaphore cleanup process started when execv is used now sets a useful
process name if the setproctitle module is installed.
* Sets the FORKED_BY_MULTIPROCESSING environment variable if forking is
disabled.
-------------------------------------------------------------------
Fri Apr 27 22:54:35 UTC 2012 - jfunk@funktronics.ca
- Update to 2.7.3.4
* Added billiard.ensure_multiprocessing() - Raises NotImplementedError if
the platform does not support multiprocessing (e.g. Jython).
-------------------------------------------------------------------
Wed Apr 25 19:09:15 UTC 2012 - jfunk@funktronics.ca
- Generate new spec
- Update to 2.7.3.3
* PyPy now falls back to using its internal _multiprocessing module, so
everything works except for forking_enable(False) (which silently degrades)
* Fixed Python 2.5 compat issues.
* Uses more with statements
* Merged some of the changes from the Python 3 branch.
- 2.7.3.2 - 2012-04-20
* Now installs on PyPy/Jython (but does not work).
- 2.7.3.1 - 2012-04-20
* Python 2.5 support added.
- 2.7.3.0 - 2012-04-20
* Updated from Python 2.7.3
* Python 2.4 support removed, now only supports 2.5, 2.6 and 2.7. (may
consider py3k support at some point).
* Pool improvments from Celery.
* no-execv patch added (http://bugs.python.org/issue8713)
-------------------------------------------------------------------
Fri Nov 25 07:55:37 UTC 2011 - jfunk@funktronics.ca
- Update to 0.3.1
* Fixed broken bool evaluation in supervisor. Thanks to jonozzz
The bug originated from a ``a if x else b`` vs. ``x and a or bz``
confusion when porting code to Python 2.4.
* ``ApplyResult._set`` can't delete the result if it's not been accepted.
This also means ``ApplyResult._ack`` needs to delete the result if the job
has been marked ready.
- 0.3.0
* Added support for accept callbacks.
- 0.2.3
* Python 2.4 support.
-------------------------------------------------------------------
Wed Apr 14 17:16:15 UTC 2010 - jfunk@funktronics.ca
- Initial import