Hello,
Need some thoughts on the use of pthread_rwlock in Ganesha with zfs as
backend filesystem on el8
We see regression with specfs swbuild workload on el8 with same Ganesha
code that was performing better on el7.
To triage the issue we captured perf stats and using flamegraph found that
Ganesha is spending a lot of cpu cycles in pthread_rwlock on el8 as
compared to el7.
If we convert the pthread_rwlock that shows up in perf stats to
pthread_mutex, we no longer see this issue.
Locks that we converted to pthread_mutex are fsm_lock, attr_lock, obj_lock,
cih_lock and mdc_exp_lock
This issue gets more severe as the number of threads grows in Ganesha, more
threads, higher CPU utilization and impact on IOPs.
Has anyone faced this issue on el8?
This is patch for reference that is working for us
https://review.gerrithub.io/c/ffilz/nfs-ganesha/+/1191904
Regards,
Gaurav Gangalwar