search
HomeBackend DevelopmentPython TutorialUsing python to implement high-performance testing tools (2)

In the previous article "Using python to implement high-performance testing tools (1)" we optimized performance by changing the python parser, but it is still far from actual needs. This article introduces optimized code for automated testing.

Option 2: Optimize the code

          If a worker wants to do his job well, he must first sharpen his tools. To optimize the code, you must first find the bottleneck of the code. The easiest way is to add log or print. It needs to be deleted after debugging is completed, which is more troublesome. Python also provides many profile tools: profile, cProfile, hotshot, pystats, but the results provided by these tools are not very readable. It is not intuitive enough to see which function or line takes up the most time at a glance. python line_profiler provides such a function. You can intuitively see which line takes up the most time. It can be said to be "fast, accurate and ruthless". Download address: http://pythonhosted.org/line_profiler/

After installing line_profiler Finally, there will be a kernprof.py in the C:\Python27\Lib\site-packages directory. Add @profile on the functions that may have bottlenecks, such as the following example:

    @profile
    def create_msg2(self,H,msg):
        li = msg.keys()
        msg_type=li[0]
        ULR_avps=[]
        ULR=HDRItem()
        ULR.cmd=self.dia.dictCOMMANDname2code(self.dia.MSG_TERM[msg_type])

        if msg_type[-1]=='A':
            msg=msg[msg_type]
            self.dia.setAVPs_by_dic(msg_type,msg,ULR_avps)
            ULR.appId=H.appId
            ULR.EndToEnd=H.EndToEnd
            ULR.HopByHop=H.HopByHop
            msg=self.dia.createRes(ULR,ULR_avps)

        else:
            self.dia.setAVPs(msg_type,msg,ULR_avps)
            ULR.appId=self.dia.APPID
            self.dia.initializeHops(ULR)
            msg=self.dia.createReq(ULR,ULR_avps)

        return msg

Run this file: kernprof. py -l -v D:\project\mp\src\protocols\libdiametermt.py, get the following results. From this picture, you can intuitively see that the setAVPS method takes up 96.6% of the time. Then locate this function and add the @proflie modifier again (Profile can be added to multiple functions at once). You can further see setAVPS The ratio of time taken by each line of code in the function.


Through step-by-step analysis, we can see that in the open source protocol library, in the setAVPS method, the attribute of finding avp is searched from a loop of 3000 , each AVP needs to be cycled 3000 times, there are at least 10 avps in a diameter message, and each time encoding an avp needs to be cycled 30,000 times. Our initial solution was to delete many avps that were not used in our performance testing (there is no way, test development resources are limited, and many times there is no good design, first make something that meets the needs.), but it only improved At about 150, it is still far from the demand. So we changed AVP to dictionary mode, so that we can quickly find the attributes of AVP based on the name.

In addition to code optimization, the number of encoding avp threads is also increased. The following chapters will talk about the impact of multi-threading and multi-process on performance. to be continued. . . .

[Recommended course: Python video course]

The above is the detailed content of Using python to implement high-performance testing tools (2). For more information, please follow other related articles on the PHP Chinese website!

Statement
This article is reproduced at:CSDN. If there is any infringement, please contact admin@php.cn delete
Refactoring Python Code EffectivelyRefactoring Python Code EffectivelyJul 24, 2025 am 03:38 AM

Refactoring is not rewriting, but improving the code structure and readability without changing the function. Common reconstruction situations include too large functions or classes, many repetitive codes, fuzzy variable naming, and complex control processes. Refactoring should start with details, such as splitting large functions, extracting duplicate code, simplifying conditional judgment, and improving variable naming. Tools and testing are the key. Using pytest, black, isort, flake8, mypy and other tools to cooperate with unit testing can ensure that the changes are safe. Refactoring should be continuously optimized from a small way, rather than rewriting it all at once.

Python Memory Management ExplainedPython Memory Management ExplainedJul 24, 2025 am 03:38 AM

Python's memory management consists of automatic allocation and recycling mechanisms. When creating variables, memory will be allocated from the memory pool or system malloc according to the object size. Small objects preferentially use memory pools to improve efficiency. Memory recycling mainly relies on reference counting and garbage collector (gc module). Reference counting is zeroed and memory is released, while circular references are processed by garbage collector. To reduce memory usage, array, NumPy array, generator, and \_\_slots\_\_\_ can be used. The memory is not released immediately at the end of the del or function, which may be caused by garbage collection delay, external memory usage or object cache. You can use tracemalloc or memory\_profiler tools to analyze the memory situation.

python recursion examplepython recursion exampleJul 24, 2025 am 03:36 AM

Recursion is a method for function calls to solve problems in Python, and is suitable for scenarios such as factorial, Fibonacci sequence, nested list traversal and binary search. 1. Factorial is recursively calculated by n*factorial(n-1), and the basic situation is n==0 or 1, and the basic situation is n==0 or 1; 2. The Fibonacci sequence defines f(n)=f(n-1) f(n-2), and the basic situation is f(0)=0, f(1)=1, but the naive recursive efficiency is low, and it is recommended to use lru_cache to optimize; 3. When traversing the nested list, if the elements are lists, they will be processed recursively, otherwise they will be printed; 4. The binary search recursive version looks for the target value in an ordered array, and determines the recursive left and right intervals based on the comparison between the intermediate value and the target. The basic situation is low>hig

Customizing Logging Handlers in PythonCustomizing Logging Handlers in PythonJul 24, 2025 am 03:33 AM

The core of custom loggingHandler is to inherit logging.Handler and implement the emit() method, which is suitable for scenarios such as sending logs to emails, writing to databases, or pushing remote servers. 1. The situations that need to be customized include: pushing logs to Slack or DingTalk, recording to database or API, processing by level, and adding additional information; 2. The implementation method is to inherit logging.Handler and rewriting emit(), where you write custom logic such as sending HTTP requests; 3. When using it, you need to pay attention to exception handling, formatting output, setting appropriate levels and formatters, and avoid duplicate output and propagation problems.

What is the difference between python `break` and `continue`?What is the difference between python `break` and `continue`?Jul 24, 2025 am 03:33 AM

In Python, the difference between break and continue is that: 1.break is used to terminate the entire loop immediately, which is often used to exit the loop early or complete the search task; 2.continue only skips the current iteration and continues to execute the next loop, which is suitable for ignoring specific elements or filtering data. For example, use break after finding a match when searching a list, and skip invalid entries with continue when cleaning data. Although both control the cycle flow, their functions are completely different.

How to flatten a list of lists in PythonHow to flatten a list of lists in PythonJul 24, 2025 am 03:32 AM

There are three ways to tile nested lists in Python: First, use list comprehension, the syntax is [itemforsublistinlist_of_listsforiteminsublist], which is suitable for two-dimensional lists; Second, use itertools.chain, which includes itertools.chain.from_iterable(list_of_lists) or itertools.chain(*list_of_lists), which has better performance; Third, when dealing with irregular nesting, judgment statements need to be added, for example, using isinstance(sublist, list) to distinguish lists from non-

python threading lock examplepython threading lock exampleJul 24, 2025 am 03:29 AM

Threading.Lock is needed to prevent race conditions for shared resources in multi-threading environments. 1. Create lock object lock=threading.Lock(); 2. Use withlock: Ensure the operation atomicity of shared variables; 3. Multiple threads accumulate 100,000 times for counters, and the final result is correct 500,000; 4. It is recommended to use the with statement to automatically manage the acquisition and release of locks; 5. Avoid nested acquisition of locks, and use threading.RLock() if necessary; 6. The scope of the lock should be as small as possible to improve performance; 7. Pay attention to avoid deadlocks due to inconsistent locking order.

Scientific Computing with PythonScientific Computing with PythonJul 24, 2025 am 03:25 AM

Python is widely used in scientific computing because its mature libraries and tool chains can handle various tasks. Key points include: 1. Install core libraries such as NumPy (efficient arrays and mathematical functions), SciPy (advanced mathematical operations), Matplotlib (data visualization) and Pandas (table data processing), which can be installed through pip or conda; 2. Replace native lists with NumPy to improve performance, and support vectorized operations, broadcast mechanisms and linear algebra functions; 3. SciPy provides complex mathematical tools such as integral, optimization, and Fourier transform, such as using quad function to calculate definite integrals; 4. Matplotlib and its encapsulation library Seaborn are used for graph display, supporting style settings and professionalism

See all articles

Hot AI Tools

Undress AI Tool

Undress AI Tool

Undress images for free

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

SublimeText3 English version

SublimeText3 English version

Recommended: Win version, supports code prompts!

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment