- Community Home
- >
- Servers and Operating Systems
- >
- Operating Systems
- >
- Operating System - Linux
- >
- Re: Why so many threads?
Categories
Company
Local Language
Forums
Discussions
Forums
- Data Protection and Retention
- Entry Storage Systems
- Legacy
- Midrange and Enterprise Storage
- Storage Networking
- HPE Nimble Storage
Discussions
Forums
Discussions
Discussions
Discussions
Forums
Discussions
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
- BladeSystem Infrastructure and Application Solutions
- Appliance Servers
- Alpha Servers
- BackOffice Products
- Internet Products
- HPE 9000 and HPE e3000 Servers
- Networking
- Netservers
- Secure OS Software for Linux
- Server Management (Insight Manager 7)
- Windows Server 2003
- Operating System - Tru64 Unix
- ProLiant Deployment and Provisioning
- Linux-Based Community / Regional
- Microsoft System Center Integration
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Discussion Boards
Community
Resources
Forums
Blogs
- Subscribe to RSS Feed
- Mark Topic as New
- Mark Topic as Read
- Float this Topic for Current User
- Bookmark
- Subscribe
- Printer Friendly Page
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
03-26-2007 08:23 AM
03-26-2007 08:23 AM
we are using a 3rd-party executable. After upgrading to its latest version, we notice it allocates now a lot of memory, just since the beginning.
By using tusc and glance we can see it is creating on startup as many threads as processors there are, each with a 8 Mb mmap() region. The previous version created only one.
According to its developers, they are not creating the threads expressly nor compiling the program with the +Oparallel switch but the matter is: setting the environment variable MP_NUMBER_OF_THREADS=1 does the trick and only one thread is created.
Questions:
1) How can this be? Is there another compiler option that can lead to the creation of parallel threads?
2) Given an executable, is there a way to know the options it was compiled with?
Thanks.
Regards.
Solved! Go to Solution.
- Tags:
- pthread
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
03-26-2007 08:45 AM
03-26-2007 08:45 AM
			
				
					
						
							Re: Why so many threads?
						
					
					
				
			
		
	
			
	
	
	
	
	
You don't say what the third party executable is.
You updated the program and its performance characteristics changed.
You did not patch your HP-UX system or make changes to it.
The developers are not accurate, they changed something.
Most of the time when something like this occurs its a result of the last thing you did, which was to update the executable.
It is possible you did so without following system prepartion guidelines, but you should have been notified of that, certainly when you contacted the application vendor.
If you mentioned the name of the third party product, you might find someone who has experienced this issue can provide assistance. Right now you've given us very little to go by.
SEP
Owner of ISN Corporation
http://isnamerica.com
http://hpuxconsulting.com
Sponsor: http://hpux.ws
Twitter: http://twitter.com/hpuxlinux
Founder http://newdatacloud.com
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
03-26-2007 02:37 PM
03-26-2007 02:37 PM
			
				
					
						
							Re: Why so many threads?
						
					
					
				
			
		
	
			
	
	
	
	
	
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
03-26-2007 05:51 PM
03-26-2007 05:51 PM
Solution+Oopenmp will also create threads.
>2) Given an executable, is there a way to know the options it was compiled with?
If you have a recent linker patch, use /usr/ccs/bin/footprints.
You can also use chatr(1) on the executable and look for libcps.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
03-27-2007 12:04 AM
03-27-2007 12:04 AM
			
				
					
						
							Re: Why so many threads?
						
					
					
				
			
		
	
			
	
	
	
	
	
Emil: in this case, the problem with having multiple threads is: a gsrvr is a dedicated server process, servicing a unique client connection. Our server has 16 CPUs so every gsrvr creates on startup +15 additional threads. Each thread has, among other regions, a 8 Mb MMAP region. That makes 15*8 Mb = 120 Mb per gsrvr. It is not uncommon for us to have 400 concurrent connections => 400 * 120 Mb = 48 Gb. Our swap space gets exhausted.
Dennis:
- chatr shows it was linked with libcps.2. Does this mean either +Oparallel or +Oopenmp were used?
- none of our servers have the footprints command. Do you know which product we should install?
Thanks to all of you.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
03-27-2007 12:12 AM
03-27-2007 12:12 AM
			
				
					
						
							Re: Why so many threads?
						
					
					
				
			
		
	
			
	
	
	
	
	
For 11.23 PHSS_34860 would bring you the 'footprint' binary. It's contained in the lastest linker patch as Dennis noted.
For 11.11 use patch PHSS_35381.
If you are running 11.31 you should already have it. The online manpages for 11.31 offer insight into its output.
Regards!
...JRF...
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
03-27-2007 01:02 AM
03-27-2007 01:02 AM
			
				
					
						
							Re: Why so many threads?
						
					
					
				
			
		
	
			
	
	
	
	
	
Yes.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
03-27-2007 04:01 AM
03-27-2007 04:01 AM
			
				
					
						
							Re: Why so many threads?
						
					
					
				
			
		
	
			
	
	
	
	
	
It's incredible how useful this forum can be :-)
Here is footprint's output.
According to the man page, I guess the fact that it can't find any compilation unit is because the program was not compiled with an HP compiler? Or maybe some compiler switch disabled footprint in the object file?
It seems elfdump can't find compilation units either.
ensnada6:/arcsde/sdeexe91/bin#/usr/ccs/bin/footprints -v gsrvr.shared
Scanning gsrvr.shared ...
Shared library: /usr/lib/pa20_64/libCsup.2 (system library - not scanned)
Shared library: /usr/lib/pa20_64/libstream.2 (system library - not scanned)
Shared library: /usr/lib/pa20_64/libcl.2 (system library - not scanned)
Shared library: /usr/lib/pa20_64/libnsl.1 (system library - not scanned)
Shared library: /usr/lib/pa20_64/libdl.1 (system library - not scanned)
Shared library: /usr/lib/pa20_64/libm.2 (system library - not scanned)
Shared library: /usr/lib/pa20_64/librt.2 (system library - not scanned)
Shared library: /usr/lib/pa20_64/libF90.1 (system library - not scanned)
Shared library: /usr/lib/pa20_64/libcps.2 (system library - not scanned)
Shared library: /usr/lib/pa20_64/libpthread.1 (system library - not scanned)
Shared library: /usr/lib/pa20_64/libnss_dns.1 (system library - not scanned)
Shared library: /usr/lib/pa20_64/libstd.2 (system library - not scanned)
Shared library: /usr/lib/pa20_64/libc.2 (system library - not scanned)
Compiler footprint summary
Number of compilation units: 0
Earliest compiler timestamp: N/A
Latest compiler timestamp: N/A
Linker timestamp: N/A
Total size: 520.9K (text) 19.3K (data)
ensnada6:/arcsde/sdeexe91/bin#elfdump -dc gsrvr.shared
gsrvr.shared:
Compilation Unit Dictionary from gsrvr.shared:
Language Name
Product_id ; Version_id
Compile time; Source time
[not present]
Regards.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
03-27-2007 02:53 PM
03-27-2007 02:53 PM
			
				
					
						
							Re: Why so many threads?
						
					
					
				
			
		
	
			
	
	
	
	
	
The executable has probably been stripped. Since you do have libCsup, it was compiled with aC++.
- Tags:
- strip
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
03-27-2007 02:56 PM
03-27-2007 02:56 PM
			
				
					
						
							Re: Why so many threads?
						
					
					
				
			
		
	
			
	
	
	
	
	
Hmm, my strip won't work on ELF files. While I've filed a bug report on that, I wasn't aware it was fixed yet.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
03-27-2007 07:57 PM
03-27-2007 07:57 PM
			
				
					
						
							Re: Why so many threads?
						
					
					
				
			
		
	
			
	
	
	
	
	
Regards.
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
03-27-2007 08:13 PM
03-27-2007 08:13 PM
			
				
					
						
							Re: Why so many threads?
						
					
					
				
			
		
	
			
	
	
	
	
	
Good question. For PA32, you can use strip(1) on an executable. This will remove the compunit/notes sections that footprints/odump/elfdump use.
If you use file(1) on gsrvr.shared, does it say it is stripped?
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
03-27-2007 08:35 PM
03-27-2007 08:35 PM
			
				
					
						
							Re: Why so many threads?
						
					
					
				
			
		
	
			
	
	
	
	
	
Here is the output from file:
ensnada6:/arcsde/sdeexe91/bin#file gsrvr.shared
gsrvr.shared: ELF-64 executable object file - PA-RISC 2.0 (LP64)
ensnada6:/arcsde/sdeexe91/bin#
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
03-27-2007 09:09 PM
03-27-2007 09:09 PM
			
				
					
						
							Re: Why so many threads?
						
					
					
				
			
		
	
			
	
	
	
	
	
This isn't stripped so perhaps you were right about not being compiled with a HP compiler.
Unless they know about an ELF tool that can do selective stripping of sections?
It seem strange that it is using libCsup and libstd but that may be for the benefit of any shlibs they dynamically load?
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
03-27-2007 09:21 PM
03-27-2007 09:21 PM
			
				
					
						
							Re: Why so many threads?
						
					
					
				
			
		
	
			
	
	
	
	
	
It's up to them to clarify why they are including CPSlib.
Thank you very much for your help.
I've learnt a lot.
