Since upgrading to s11b83a I noticed that gam_server processes eat significant amount of CPU cycles. So I decided to make some investigations.
# uname -a
SunOS xeon 5.11 snv_83 i86pc i386 i86pc
# pkginfo -l SUNWgamin
PKGINST: SUNWgamin
NAME: Library providing the FAM File Alteration Monitor API
CATEGORY: GNOME2,application,JDS4
ARCH: i386
VERSION: 0.1.9,REV=110.0.4.2008.01.28.02.48
. . .
# fgrep SUNWgamin /var/sadm/install/contents
/usr/lib/gam_server f ...
/usr/lib/libfam.so=libfam.so.0.0.0 s ...
/usr/lib/libfam.so.0=libfam.so.0.0.0 s ...
/usr/lib/libfam.so.0.0.0 f ...
/usr/lib/libgamin-1.so=libgamin-1.so.0.1.9 s ...
/usr/lib/libgamin-1.so.0=libgamin-1.so.0.1.9 s ...
/usr/lib/libgamin-1.so.0.1.9 f ...
/usr/lib/python2.4/vendor-packages/_gamin.so f ...
/usr/lib/python2.4/vendor-packages/gamin.py f ...
No manuals, no config files.
# strings /usr/lib/gam_server
. . .
/.gaminrc
/etc/gamin/mandatory_gaminrc
/etc/gamin/gaminrc
From Gamin project page:
Gamin is a file and directory monitoring system defined to be a subset of the FAM (File Alteration Monitor) system. This is a service provided by a library which allows to detect when a file or a directory has been modified.
This is the description of the config file: Gamin config
Now, how to fix the problem
- Create /etc/gamin directory:
# mkdir /etc/gamin
- Create file /etc/gamin/gaminrc. It may contain the following lines (this is just an example, you can set your own polling intervals):
fsset nfs poll 15
fsset ufs poll 15
fsset lofs poll 15
fsset zfs poll 15
- Restart gam_server (let me know if there is a better way):
# pkill gam_server; rm -rf /tmp/gam_*
Voila! That should be done in all zones.
Update 2008-07-07 @00:06:24: i did not see this behaviour in snv_92. However, do not install snv_92 because of otehr bugs. Try snv_93.