-
Notifications
You must be signed in to change notification settings - Fork 767
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
multithreaded access to properties is slower than serial access #1084
Comments
I did another test where I connect to 2 different hosts. # ruff: noqa
import ssl
from threading import Thread
import time
from pyVim.connect import SmartConnect
from pyVmomi import vim
NUM_VMNICS = 4
HOST = ""
HOST2 = ""
PASSWORD = ""
context = ssl._create_unverified_context()
start = time.time()
for host in [HOST, HOST2]:
con = SmartConnect(host=host, pwd=PASSWORD, sslContext=context)
host = con.content.viewManager.CreateContainerView(con.content.rootFolder, [vim.HostSystem], True).view[0]
for i in range(NUM_VMNICS + 1):
print(f"host {host.name} - {host.config.network.pnic[i].driver}")
end = time.time()
print(f"single threaded: {end - start}")
threads = []
for host in [HOST, HOST2]:
def print_driver(host):
con = SmartConnect(host=host, pwd=PASSWORD, sslContext=context)
host = con.content.viewManager.CreateContainerView(con.content.rootFolder, [vim.HostSystem], True).view[0]
for i in range(NUM_VMNICS + 1):
print(f"host {host.name} - {host.config.network.pnic[i].driver}")
t = Thread(target=print_driver, args=(host,))
threads.append(t)
start = time.time()
for t in threads:
t.start()
for t in threads:
t.join()
end = time.time()
print(f"multi threaded: {end - start}") My results are:
This tells me there is a bottleneck in pyvmomi itself and not in the esxi host. |
I did more tests and it looks like the performance issues are caused by python 3.7. |
Also you could consider using multiprocessing instead of threading, and create a service instance (i.e. SmartConnect) in each of them, so you aren't leveraging the same connection. |
I decided to reopen the issue after further testing. While the performance numbers with newer versions of python are better the trend is still the same.
Thanks but that's not an option in my codebase. |
Describe the bug
I noticed that accessing host properties from multiple threads is slower than doing so serialy.
I wrote a script to reproduce the issue:
On my host with 8 vmnics I get:
The single threaded performance is stable around 4 seconds but the multithreaded performance jumps around between 6-12 seconds each run.
The script can be changed to always access
pnic[0]
with the same result.The more threads run at the same time, the slower it gets.
Reproduction steps
Expected behavior
I expect multithreaded performance to be better or equal to serial performance.
Additional context
No response
The text was updated successfully, but these errors were encountered: