Path: csiph.com!fu-berlin.de!uni-berlin.de!not-for-mail From: Stefan Schwarzer Newsgroups: de.comp.lang.python Subject: Re: [Python-de] Flaschenhals erkennen Date: Fri, 23 Aug 2019 13:18:43 +0200 Lines: 27 Message-ID: References: Mime-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Transfer-Encoding: 8bit X-Trace: news.uni-berlin.de 6R46cEyhjWXn2fSChOmO+QyEa0qs7jxAlYPL/2Y7hPVQ== Return-Path: X-Original-To: python-de@python.org Delivered-To: python-de@mail.python.org Openpgp: preference=signencrypt Autocrypt: addr=sschwarzer@sschwarzer.net; prefer-encrypt=mutual; keydata= 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 WdtUokwYRxk= User-Agent: Mozilla/5.0 (X11; U; Linux i686; en-US; rv:1.8.1.24) Gecko/20100411 Thunderbird/2.0.0.24 Mnenhy/0.7.6.666 In-Reply-To: Content-Language: de-DE X-Provags-ID: V03:K1:38jO3fizKmszXQk7+Iqpq+gv/HW0m7nbqZQmE6EzEVZD7R2vEZ9 ogh6RL1jSWvlr1v8pfk6t7KOv10Gnu4YHLobphE+I7E+yIz8c7181WAcMiIek+qj/HHmJp3 Ly6WVVS4+nab8lyebl3kUr7hPgGZHKSosgqKxfM4LaWN7eO/JNdcOTv8DLEHfYG/lZCyNIQ xfEMd/beRJgOjNXsVGpjw== X-Spam-Flag: NO X-UI-Out-Filterresults: notjunk:1;V03:K0:bAlux3smFjk=:5Zoe6bJHO/0/FTOZ84Gu0Z 4x8gymRtoM5m468SwXNok4sheH43BIDoRtLayybg7dAcDIMzndyzrpGxfbHkyiJFvz26PuO8a whJxssxnEMljvwmQwBm1Z1qF+mQLwfOUChgXrEU0dFMatzOTSOiJZqz7IUgis9AS4DWw4EYjn 4RJ9lyuiReoMXh2am+fzyvG3dGuE9UOYN1wHP8/PQqZXn+PYRWCVm4vvA3AENjpnI/s54tVMa r18uMWKUqCWnLrGCVUnQqsQBILk6ruc+fy/sdpgRFFi5MB21PI4A9GDOTc6kQNFYyh8QwI16c Hpmva+rZce+iVXzcxMnzTKo8wK8XtBqjtS6FyLFIuorwWElIhu3qUYtmXN1AYlw3/EdZKJPF0 NWbf1rbgf+HOv191mgocL+9TgR11yUUqh7yqVEH8XO4RnzuNr3XCivwREdTEy5OqKqcPWjbCA EKRqbp/HCYFR2epKXV6jMkh49zy3ag/jsYy+yPR6Uqxbv3rII0gmU0j3qBsofFDJSWVJyovJX 5Wr75ihGMJnUb2hxbFKP0e9fLnqcWq3oGR0sio9JN9ufV9MhOuNCrWcAXDA+m4SwA+zD0q0D1 jUUilBAvqEQGlUttOsGG6AZsZ3jdVoVGh+N6Q/BmXli/AdQA/RByar5zTSD/9esEl92MyzmsT oMildiOcooU9lNtssTVV54uKCJ3Mz158j6Pp3AYvs4ibagSUFtZLKSOTMIfVnLz6XDbQaiIiM QTsOWKFB2/jNE4eXOEMkVRcC1JTrqpX21viTKdSqqVQWVnuM6frv5a+xVFha/pUXT9S6dBUJH X2y+z/I X-BeenThere: python-de@python.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Die Deutsche Python Mailingliste List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-Mailman-Original-Message-ID: X-Mailman-Original-References: Xref: csiph.com de.comp.lang.python:5526 On 2019-08-23 11:18, Thomas Güttler wrote: > wir haben Code mit recht 2000 Tests. > Die Ausführung der Tests dauert eine halbe Stunde, > und es wäre schön, wenn das schneller gehen würde. > > Vor kurzem wurde durch Zufall erkannt, dass ständig ein Test-User > erstellt wird und dabei bcrypt verwendet wird. > > Diese eine Stelle wurde optimiert, und es wurden 5 Minuten Zeit gespart. > > Super .... aber ich will solche Erkenntnisse ungern dem Zufall überlassen. > > Ich suche nun ein Tool, mit dem man erkennen kann, ob es noch weitere > Flaschenhälse/Bottlenecks im Code gibt. Abgesehen vom Hinweis von Hans auf pytests `--durations`-Option, möchte ich auch noch an die "normalen" Python-Profiler erinnern, zum Beispiel den in der Standard-Bibliothek: https://docs.python.org/3/library/profile.html Vor allem, wenn man noch nicht so vertraut damit ist, ist die Verwendung etwas hakelig, aber ich habe den Profiler schon öfter erfolgreich eingesetzt. :-) Viele Grüße Stefan