前回の記事「Pythonを使った高パフォーマンステストツールの実装(1)」では、Pythonパーサーを変更することでパフォーマンスの最適化を行いましたが、まだまだ実際のニーズには程遠いです。この記事では、自動テスト用に最適化されたコードを紹介します。
オプション 2: コードを最適化する
作業者が仕事をうまくこなしたい場合は、まずツールを磨く必要があります。コードを最適化するには、まずコードのボトルネックを見つける必要があります。最も簡単な方法はログを追加するか出力することですが、デバッグが完了した後に削除する必要があり、これはさらに面倒です。 Python には、profile、cProfile、hotshot、pystats などの多くのプロファイル ツールも提供されていますが、これらのツールによって提供される結果はあまり読みにくく、どの関数または行が最も時間を費やしているかを一目で確認できるほど直観的ではありません。 python line_profiler はこのような機能を提供します どの行に最も時間がかかっているかが直感的に分かります 「速くて正確で容赦がない」と言えます ダウンロードアドレス: http://pythonhosted.org/line_profiler/
line_profiler をインストールした後、最後に、C:\Python27\Lib\site-packages ディレクトリに kernprof.py が作成されます。次の例のように、ボトルネックがある可能性のある関数に @profile を追加します。 ##このファイル kernprof.py -l -v D:\project\mp\src\protocols\libdiametermt.py を実行すると、次の結果が得られます。この図から、setAVPS メソッドが時間の 96.6% を占めていることが直感的にわかります。次に、この関数を見つけて @proflie 修飾子を再度追加します (プロファイルは一度に複数の関数に追加できます)。さらに setAVPS の比率を確認できます。関数内のコードの各行にかかる時間。
ステップバイステップの分析を通じて、オープンソースのプロトコル ライブラリの setAVPS メソッドで、 find avp の属性が次から検索されていることがわかります。 3000 のループでは、各 AVP を 3000 回サイクルする必要があり、Diameter メッセージには少なくとも 10 avp があり、エンコードのたびに avp を 30,000 回サイクルする必要があります。私たちの最初の解決策は、パフォーマンス テストで使用されなかった多くの AVPS を削除することでした (方法はありません。テスト開発リソースは限られており、適切な設計がない場合が多いため、まずニーズを満たすものを作成します)。改善されました 約 150 ですが、需要にはまだ程遠いです。そこで、AVP を辞書モードに変更して、名前に基づいて AVP の属性をすぐに見つけられるようにしました。
コードの最適化に加えて、エンコード AVP スレッドの数も増加します。次の章では、マルチスレッドとマルチプロセスがパフォーマンスに与える影響について説明します。つづく。 。 。 。
[おすすめコース:
Python ビデオコース以上がPython を使用して高性能テスト ツールを実装する (2)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于Seaborn的相关问题,包括了数据可视化处理的散点图、折线图、条形图等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于进程池与进程锁的相关问题,包括进程池的创建模块,进程池函数等等内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于简历筛选的相关问题,包括了定义 ReadDoc 类用以读取 word 文件以及定义 search_word 函数用以筛选的相关内容,下面一起来看一下,希望对大家有帮助。

本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于数据类型之字符串、数字的相关问题,下面一起来看一下,希望对大家有帮助。

VS Code的确是一款非常热门、有强大用户基础的一款开发工具。本文给大家介绍一下10款高效、好用的插件,能够让原本单薄的VS Code如虎添翼,开发效率顿时提升到一个新的阶段。

本篇文章给大家带来了关于Python的相关知识,其中主要介绍了关于numpy模块的相关问题,Numpy是Numerical Python extensions的缩写,字面意思是Python数值计算扩展,下面一起来看一下,希望对大家有帮助。

pythn的中文意思是巨蟒、蟒蛇。1989年圣诞节期间,Guido van Rossum在家闲的没事干,为了跟朋友庆祝圣诞节,决定发明一种全新的脚本语言。他很喜欢一个肥皂剧叫Monty Python,所以便把这门语言叫做python。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

Dreamweaver Mac版
ビジュアル Web 開発ツール

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

メモ帳++7.3.1
使いやすく無料のコードエディター

ホットトピック



