<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>Unwinding the Stack &#187; opensolaris</title>
	<atom:link href="http://thestaticvoid.com/tag/opensolaris/feed/" rel="self" type="application/rss+xml" />
	<link>http://thestaticvoid.com</link>
	<description>Explorations in Computing</description>
	<lastBuildDate>Wed, 07 Dec 2011 16:15:58 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.1</generator>
		<item>
		<title>Fun With vpnc</title>
		<link>http://thestaticvoid.com/post/2010/07/22/fun-with-vpnc/</link>
		<comments>http://thestaticvoid.com/post/2010/07/22/fun-with-vpnc/#comments</comments>
		<pubDate>Thu, 22 Jul 2010 20:20:20 +0000</pubDate>
		<dc:creator>James Lee</dc:creator>
				<category><![CDATA[Desktop]]></category>
		<category><![CDATA[System Administration]]></category>
		<category><![CDATA[network]]></category>
		<category><![CDATA[opensolaris]]></category>
		<category><![CDATA[packages]]></category>
		<category><![CDATA[snoop]]></category>
		<category><![CDATA[vpnc]]></category>

		<guid isPermaLink="false">http://thestaticvoid.com/?p=337</guid>
		<description><![CDATA[I recently got a new laptop at work and I decided to put OpenSolaris on it. This meant I had to setup vpnc in order to access the server networks and wireless here. I installed my vpnc package, copied the profile from my Ubuntu workstation, and started it up. It connected, but no packets flowed. [...]]]></description>
			<content:encoded><![CDATA[<p>I recently got a new laptop at work and I decided to put OpenSolaris on it.  This meant I had to setup vpnc in order to access the server networks and wireless here.  I installed <a href="http://thestaticvoid.com/post/2010/02/26/vpnc-for-opensolaris/">my vpnc package</a>, copied the profile from my Ubuntu workstation, and started it up.  It connected, but no packets flowed.  I didn&#8217;t have time to investigate, so I decided to work on it some more at home.</p>
<p>The strange thing is that it connected from home with the very same profile and everything worked fine.  I immediately suspected something was wrong with the routing tables, like maybe some of the routes installed by <tt>vpnc-script</tt> were conflicting with the routes necessary to talk to the VPN concentrator.  I endlessly compared the routing tables between work and home and my working Ubuntu workstation, removing routes, adding routes, and manually constructing the routing table until I was positive it could not be that.</p>
<p>Everything I pinged worked.  I could ping the concentrator.  I could ping the gateway.  I could ping the tunnel device.  I could ping the physical interface&#8212;or so I thought.</p>
<p>As I was preparing to write a message to the <a href="http://news.gmane.org/gmane.network.vpnc.devel">vpnc-devel mailing list</a> requesting help, I did some pings to post the output in the email.  I ran</p>
<pre class="terminal">
$ <kbd>ping &lt;concentrator ip&gt;</kbd>
&lt;concentrator ip&gt; is alive
</pre>
<p>which looked good, but I wanted the full ping output, so I ran</p>
<pre class="terminal">
$ <kbd>ping -s &lt;concentrator ip&gt;</kbd>
PING &lt;concentrator ip&gt;: 56 data bytes
^C
----&lt;concentrator ip&gt; PING Statistics----
4 packets transmitted, 1 packets received, 75% packet loss
round-trip (ms)  min/avg/max/stddev = 9223372036854776.000/0.000/0.000/-NaN
</pre>
<p>For some reason, only the first ping was getting through.  The rest were getting hung up somewhere.  The really strange thing was that I saw the same behavior on the local physical interface:</p>
<pre class="terminal">
$ <kbd>ifconfig bge0</kbd>
bge0: flags=1004843<UP,BROADCAST,RUNNING,MULTICAST,DHCP,IPv4> mtu 1500 index 3
        inet 161.253.143.151 netmask ffffff00 broadcast 161.253.143.255
$ <kbd>ping -s 161.253.143.151</kbd>
PING 161.253.143.151: 56 data bytes
^C
----161.253.143.151 PING Statistics----
5 packets transmitted, 1 packets received, 80% packet loss
round-trip (ms)  min/avg/max/stddev = 9223372036854776.000/0.000/0.000/-NaN
</pre>
<p>I have never seen a situation where you couldn&#8217;t even ping a local physical interface!  I checked and double checked that IPFilter wasn&#8217;t running.  Finally I started a packet capture of the physical interface to see what was happening to my pings:</p>
<pre class="terminal">
# <kbd>snoop -d bge0 icmp</kbd>
Using device bge0 (promiscuous mode)
161.253.143.151 -> &lt;concentrator ip&gt; ICMP Destination unreachable (Bad protocol 50)
161.253.143.151 -> &lt;concentrator ip&gt; ICMP Destination unreachable (Bad protocol 50)
161.253.143.151 -> &lt;concentrator ip&gt; ICMP Destination unreachable (Bad protocol 50)
^C
</pre>
<p>That&#8217;s when by chance I saw messages being sent to the VPN concentrator saying &#8220;bad protocol 50.&#8221;  <a href="http://www.iana.org/assignments/protocol-numbers/protocol-numbers.xml">IP protocol</a> 50 represents &#8220;ESP&#8221;, commonly used for IPsec.  Apparently Solaris eats these packets.  Haven&#8217;t figured out why.</p>
<p>I remembered seeing something in the vpnc manpage about ESP packets:</p>
<div class="codecolorer-container text default" style="overflow:auto;white-space:nowrap;border:1px solid #9F9F9F;width:435px;"><div class="text codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap">--natt-mode &lt;natt/none/force-natt/cisco-udp&gt;<br />
<br />
&nbsp; &nbsp; &nbsp; Which NAT-Traversal Method to use:<br />
&nbsp; &nbsp; &nbsp; o &nbsp; &nbsp;natt -- NAT-T as defined in RFC3947<br />
&nbsp; &nbsp; &nbsp; o &nbsp; &nbsp;none -- disable use of any NAT-T method<br />
&nbsp; &nbsp; &nbsp; o &nbsp; &nbsp;force-natt -- always use NAT-T encapsulation &nbsp;even<br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;without presence of a NAT device (useful if the OS<br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;captures all ESP traffic)<br />
&nbsp; &nbsp; &nbsp; o &nbsp; &nbsp;cisco-udp -- Cisco proprietary UDP &nbsp;encapsulation,<br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;commonly over Port 10000</div></div>
<p>I enabled <tt>force-natt</tt> mode, which encapsulates the ESP packet in a UDP packet, normally to get past NAT, and it started working!  In retrospect, I should have been able to figure that out much easier.  First, it pretty much says it on the <a href="http://www.unix-ag.uni-kl.de/~massar/vpnc/">vpnc homepage</a>: &#8220;Solaris (7 works, 9 only with &#8211;natt-mode forced).&#8221;  I didn&#8217;t even notice that.  Second, I should have realized that I was behind a NAT at home and not at work, so they would be using a different NAT-traversal mode by default.  Oh well, it was a good diagnostic exercise, hence the post to share the experience.</p>
<p>In other vpnc related news, I&#8217;ve ported <a href="http://www.whiteboard.ne.jp/~admin2/tuntap/">Kazuyoshi&#8217;s</a> <a href="http://www.whiteboard.ne.jp/~admin2/tuntap/source/openvpn/patch.openvpn-2.1.1.tun.c">patch</a> to the <tt>open_tun</tt> and <tt>solaris_close_tun</tt> functions of OpenVPN to the <tt>tun_open</tt> and <tt>tun_close</tt> functions of vpnc.  His sets up the tunnel interface a little bit differently and adds TAP support.  It solves the random problems vpnc had with bringing up the tunnel interface such as:</p>
<pre class="terminal">
# <kbd>ifconfig tun0</kbd>
tun0: flags=10010008d0&lt;POINTOPOINT,RUNNING,NOARP,MULTICAST,IPv4,FIXEDMTU&gt; mtu 1412 index 8
        inet 128.164.xxx.yy --> 128.164.xxx.yy netmask ffffffff
        ether f:ea:1:ff:ff:ff
# <kbd>ifconfig tun0 up</kbd>
ifconfig: setifflags: SIOCSLIFFLAGS: tun0: no such interface
# <kbd>dmesg | grep tun0</kbd>
Jul 23 14:56:05 swan ip: [ID 728316 kern.error] tun0: DL_BIND_REQ failed: DL_OUTSTATE
</pre>
<p>The changes are in the latest vpnc package available from my <a href="http://pkg.thestaticvoid.org:10000/">package repository</a>.</p>
]]></content:encoded>
			<wfw:commentRss>http://thestaticvoid.com/post/2010/07/22/fun-with-vpnc/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>A Professional Photo Workflow for OpenSolaris</title>
		<link>http://thestaticvoid.com/post/2010/05/02/a-professional-photo-workflow-for-opensolaris/</link>
		<comments>http://thestaticvoid.com/post/2010/05/02/a-professional-photo-workflow-for-opensolaris/#comments</comments>
		<pubDate>Sun, 02 May 2010 05:05:17 +0000</pubDate>
		<dc:creator>James Lee</dc:creator>
				<category><![CDATA[Desktop]]></category>
		<category><![CDATA[Photography]]></category>
		<category><![CDATA[argyll]]></category>
		<category><![CDATA[opensolaris]]></category>
		<category><![CDATA[raw]]></category>
		<category><![CDATA[ufraw]]></category>

		<guid isPermaLink="false">http://thestaticvoid.com/?p=327</guid>
		<description><![CDATA[I am not a professional by any means, but I like to know I can get the most out of my tools if the need arises. That means shooting in RAW along side JPEG so I can take control of image processing settings or correct little mistakes such as under-exposure or incorrect white balance. RAW [...]]]></description>
			<content:encoded><![CDATA[<p>I am not a professional by any means, but I like to know I can get the most out of my tools if the need arises.  That means shooting in RAW along side JPEG so I can take control of image processing settings or correct little mistakes such as under-exposure or incorrect white balance.  RAW files contain raw sensor data from the camera (duh) and must be processed by special programs before they can be printed or shared.  My camera came with the Canon Digital Photo Professional software which I&#8217;ve heard is pretty good.  There are other (expensive) commercial options such as <a href="http://www.adobe.com/products/photoshoplightroom/">Adobe Lightroom</a>.  Obviously none of these work in Solaris (though they might work in Wine), so I decided to explore the open-source offerings.</p>
<p>Fortunately, this is a good time in the open-source world for RAW processing.  Tools like <a href="http://ufraw.sourceforge.net/">UFRaw</a> and <a href="http://lensfun.berlios.de/">LensFun</a> are maturing rapidly and beginning to give their commercial counterparts a run for their money.  I spent the past week porting them, and the color management software, <a href="http://www.argyllcms.com/">Argyll</a>, to OpenSolaris.</p>
<h3>Argyll</h3>
<p>Argyll is a suite of color management tools for Unix and Windows.  It can be used to calibrate displays, cameras, scanners, and printers.  When all of your equipment is properly calibrated, then colors should appear the same on all devices.  So if I were to photograph a stop sign, it would appear to be the same red on my monitor as in real life.</p>
<div style="text-align: center"><a href="http://www.flickr.com/photos/mrstaticvoid/4570201472/" title="Color Calibration Tools by MrStaticVoid, on Flickr"><img src="http://farm4.static.flickr.com/3439/4570201472_a5e2bdf5ea.jpg" width="500" height="333" alt="Color Calibration Tools" /></a></div>
<p>Color calibration requires special equipment.  For your monitor, you need a colorimeter.  I already had an <a href="http://www.google.com/products/catalog?hl=en&#038;safe=off&#038;client=firefox-a&#038;hs=zt6&#038;rls=org.mozilla:en-US:official&#038;resnum=0&#038;q=x+rite+display+lt&#038;um=1&#038;ie=UTF-8&#038;cid=2978199230474206625&#038;ei=8AHdS5XYCJHU8ASOm6HKBw&#038;sa=X&#038;oi=product_catalog_result&#038;ct=result&#038;resnum=4&#038;ved=0CCsQ8wIwAw#ps-sellers">X-rite i1Display</a> to calibrate my TVs, and it works just fine with Argyll and Solaris (using libusb).  Following <a href="http://www.marcelpatek.com/argyll.html">these instructions</a> I was able to calibrate my monitors in a few minutes.  It was so easy I did my work monitors and laptop too!</p>
<p>Camera calibration was just as easy following <a href="http://blog.pcode.nl/2008/11/15/color-profiling-your-own-dslr-redux/">Pascal de Bruijn&#8217;s instructions</a>.  I picked up a very affordable IT8.7 target from <a href="http://www.targets.coloraid.de/">Wolf Faust</a>.  It arrived from Germany in about a week.</p>
<p>Argyll can be installed from my <a href="http://pkg.thestaticvoid.com/sfe/">software repository</a> by typing <tt>pfexec pkg install SFEargyll</tt>.</p>
<h3>UFRaw</h3>
<div class="text-align: center"><a href="http://www.flickr.com/photos/mrstaticvoid/4570241734/" title="UFRaw by MrStaticVoid, on Flickr"><img src="http://farm5.static.flickr.com/4051/4570241734_1375b53ab0.jpg" width="500" height="285" alt="UFRaw" /></a></div>
<p>UFRaw with lens correction support using LensFun can be installed from my repository by typing <tt>pfexec pkg install ufraw</tt>.  I went through hell trying to port this and its dependencies.  LensFun was particularly terrible with its crazy Makefiles (please use Autotools!) and non-standard C++ which Sun Studio choked on.</p>
<p>I don&#8217;t have much else to say about this yet, I&#8217;m still playing around with it.</p>
]]></content:encoded>
			<wfw:commentRss>http://thestaticvoid.com/post/2010/05/02/a-professional-photo-workflow-for-opensolaris/feed/</wfw:commentRss>
		<slash:comments>7</slash:comments>
		</item>
		<item>
		<title>VPNC for OpenSolaris</title>
		<link>http://thestaticvoid.com/post/2010/02/26/vpnc-for-opensolaris/</link>
		<comments>http://thestaticvoid.com/post/2010/02/26/vpnc-for-opensolaris/#comments</comments>
		<pubDate>Fri, 26 Feb 2010 20:02:16 +0000</pubDate>
		<dc:creator>James Lee</dc:creator>
				<category><![CDATA[System Administration]]></category>
		<category><![CDATA[opensolaris]]></category>
		<category><![CDATA[packages]]></category>
		<category><![CDATA[vpnc]]></category>

		<guid isPermaLink="false">http://thestaticvoid.com/?p=260</guid>
		<description><![CDATA[I&#8217;ve compiled VPNC and the requisite TUN/TAP driver for OpenSolaris so that I can access my work network from home. Kazuyoshi&#8217;s driver adds TAP functionality to the original TUN driver which hasn&#8217;t been updated in nine years. It&#8217;s a real testament to the stability of the OpenSolaris kernel ABI that the module still compiles, loads, [...]]]></description>
			<content:encoded><![CDATA[<p>I&#8217;ve compiled <a href="http://www.unix-ag.uni-kl.de/~massar/vpnc/">VPNC</a> and the requisite <a href="http://www.whiteboard.ne.jp/~admin2/tuntap/">TUN/TAP driver</a> for OpenSolaris so that I can access my work network from home.  Kazuyoshi&#8217;s driver adds TAP functionality to the original <a href="http://vtun.sourceforge.net/tun/">TUN driver</a> which hasn&#8217;t been updated in nine years.  It&#8217;s a real testament to the stability of the OpenSolaris kernel ABI that the module still compiles, loads, and works properly.</p>
<p>All of the software can be installed from my repository onto build 111 or higher:</p>
<pre class="terminal">
$ <kbd>pfexec pkg set-publisher -O http://pkg.thestaticvoid.com/ thestaticvoid</kbd>
$ <kbd>pfexec pkg install vpnc</kbd>
</pre>
<p>The tun driver should load automatically and create <tt>/dev/tun</tt>.  Now create a VPN profile configuration in <tt>/etc/vpnc/</tt>.  The configuration contains a lot of private information so I&#8217;m not going to share mine here, but <tt>/etc/vpnc/default.conf</tt> is a good start.</p>
<p>One thing I do like to do is make sure only certain subnets are tunneled through the VPN.  That way connecting to the VPN doesn&#8217;t interrupt any connections that are already established (for example, AIM).  To do that I create a script <tt>/etc/vpnc/gwu-networks-script</tt> containing</p>
<div class="codecolorer-container bash default" style="overflow:auto;white-space:nowrap;border:1px solid #9F9F9F;width:435px;"><div class="bash codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #666666; font-style: italic;">#!/bin/sh</span><br />
<br />
<span style="color: #666666; font-style: italic;"># Only tunnel GWU networks through VPN</span><br />
<span style="color: #007800;">CISCO_SPLIT_INC</span>=<span style="color: #000000;">2</span><br />
<span style="color: #007800;">CISCO_SPLIT_INC_0_ADDR</span>=161.253.0.0<br />
<span style="color: #007800;">CISCO_SPLIT_INC_0_MASK</span>=255.255.0.0<br />
<span style="color: #007800;">CISCO_SPLIT_INC_0_MASKLEN</span>=<span style="color: #000000;">16</span><br />
<span style="color: #007800;">CISCO_SPLIT_INC_0_PROTOCOL</span>=<span style="color: #000000;">0</span><br />
<span style="color: #007800;">CISCO_SPLIT_INC_0_SPORT</span>=<span style="color: #000000;">0</span><br />
<span style="color: #007800;">CISCO_SPLIT_INC_0_DPORT</span>=<span style="color: #000000;">0</span><br />
<span style="color: #007800;">CISCO_SPLIT_INC_1_ADDR</span>=128.164.0.0<br />
<span style="color: #007800;">CISCO_SPLIT_INC_1_MASK</span>=255.255.0.0<br />
<span style="color: #007800;">CISCO_SPLIT_INC_1_MASKLEN</span>=<span style="color: #000000;">16</span><br />
<span style="color: #007800;">CISCO_SPLIT_INC_1_PROTOCOL</span>=<span style="color: #000000;">0</span><br />
<span style="color: #007800;">CISCO_SPLIT_INC_1_SPORT</span>=<span style="color: #000000;">0</span><br />
<span style="color: #007800;">CISCO_SPLIT_INC_1_DPORT</span>=<span style="color: #000000;">0</span><br />
<br />
. <span style="color: #000000; font-weight: bold;">/</span>etc<span style="color: #000000; font-weight: bold;">/</span>vpnc<span style="color: #000000; font-weight: bold;">/</span>vpnc-script</div></div>
<p>then add <tt>Script /etc/vpnc/gwu-networks-script</tt> to the end of my VPN profile configuration.</p>
<p>Connecting to the VPN you should see messages like:</p>
<pre class="terminal">
$ <kbd>pfexec vpnc gwu</kbd>
Enter password for jameslee@&lt;no&gt;:
which: no ip in (/sbin:/usr/sbin:/usr/gnu/bin:/usr/bin:/usr/sbin:/sbin)
which: no ip in (/sbin:/usr/sbin:/usr/gnu/bin:/usr/bin:/usr/sbin:/sbin)
add net 128.164.&lt;no&gt;: gateway 128.164.&lt;no&gt;
add host 128.164.&lt;no&gt;: gateway 161.253.&lt;no&gt;
add net 161.253.0.0: gateway 128.164.&lt;no&gt;
add net 128.164.0.0: gateway 128.164.&lt;no&gt;
add net 128.164.&lt;no&gt;: gateway 128.164.&lt;no&gt;
add net 128.164.&lt;no&gt;: gateway 128.164.&lt;no&gt;
VPNC started in background (pid: 594)...
</pre>
<p>The <tt>vpnc-script</tt> will modify your <tt>/etc/resolv.conf</tt> and routing tables so be sure to run <tt>vpnc-disconnect</tt> when you are done with the connection to restore the original configuration.</p>
<p>Thanks to the good folks at <a href="http://www.infradead.org/openconnect.html">OpenConnect</a> for a well-maintained <a href="http://git.infradead.org/users/dwmw2/vpnc-scripts.git/blob/HEAD:/vpnc-script"><tt>vpnc-script</tt></a> which works on Solaris.  Spec files for these packages are available from my <a href="https://github.com/MrStaticVoid/specs/blob/master/vpnc.spec">GitHub</a> <a href="https://github.com/MrStaticVoid/specs/blob/master/tuntap.spec">repository</a> if you want to roll your own.</p>
]]></content:encoded>
			<wfw:commentRss>http://thestaticvoid.com/post/2010/02/26/vpnc-for-opensolaris/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>MusicBrainz Picard</title>
		<link>http://thestaticvoid.com/post/2010/02/14/musicbrainz-picard/</link>
		<comments>http://thestaticvoid.com/post/2010/02/14/musicbrainz-picard/#comments</comments>
		<pubDate>Sun, 14 Feb 2010 09:54:17 +0000</pubDate>
		<dc:creator>James Lee</dc:creator>
				<category><![CDATA[Desktop]]></category>
		<category><![CDATA[ffmpeg]]></category>
		<category><![CDATA[opensolaris]]></category>
		<category><![CDATA[packages]]></category>
		<category><![CDATA[picard]]></category>
		<category><![CDATA[qt]]></category>

		<guid isPermaLink="false">http://thestaticvoid.com/?p=241</guid>
		<description><![CDATA[MusicBrainz along with the Picard tagger is without a doubt the best way to organize and manage large collections of music. The tagger will fingerprint audio files and automatically correct their metadata and filenames. I&#8217;ve been using MusicBrainz since 2005, and even attempted to write my own tagger for it in Java back when Picard [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://musicbrainz.org/">MusicBrainz</a> along with the <a href="http://musicbrainz.org/doc/PicardTagger">Picard tagger</a> is without a doubt the best way to organize and manage large collections of music.  The tagger will fingerprint audio files and automatically correct their metadata and filenames.</p>
<p><a href="http://thestaticvoid.com/wordpress/wp-content/uploads/2010/02/picard.png"><img src="http://thestaticvoid.com/wordpress/wp-content/uploads/2010/02/picard-300x206.png" alt="" title="MusicBrainz Picard" width="300" height="206" class="aligncenter size-medium wp-image-244" /></a></p>
<p>I&#8217;ve been using MusicBrainz since 2005, and even attempted to write <a href="http://thestaticvoid.com/wsvn/junepimp/trunk/">my own tagger</a> for it in Java back when Picard didn&#8217;t exist.  When I switched to OpenSolaris, it was one of the programs I missed the most.  So I went about building a package for it.</p>
<p>Unfortunately, the software has a lot of complicated dependencies such as <a href="http://qt.nokia.com/">Qt</a> and <a href="http://www.ffmpeg.org/">FFmpeg</a> which aren&#8217;t included in OpenSolaris either.  FFmpeg I can understand; it infringes on countless software patents &lt;insert rant here&gt;.  But Qt?  There&#8217;s no reason for that.  It is easily the second most popular graphics toolkit for Unix.  Sure, the <a href="http://techbase.kde.org/Projects/KDE_on_Solaris/OpenSolaris">Solaris KDE</a> guys have a build of it, but it installs to a non-standard prefix and doesn&#8217;t include 64-bit libs.  No thank you.</p>
<p>Anyway, the package and its dependencies are up on my <a href="http://pkg.thestaticvoid.com/">package repository</a> for b132 and later.  You know the deal&#8230;<tt>pfexec pkg install picard</tt>.  Spec files are, as always, available from my <a href="https://github.com/MrStaticVoid/specs">GitHub repository</a>.</p>
<p>Now that I have a good start on the FFmpeg package, I&#8217;m going to keep working on it, adding support for more codecs and eventually build <a href="http://www.mplayerhq.hu/design7/news.html">MPlayer</a> so I can stop using <a href="http://solaris.homeunix.com/?q=node/24">this guy&#8217;s</a> less-than-ideal build.</p>
<p><strong>EDIT:</strong> Just FYI, in order to get nice antialiased fonts in Qt applications, I had to modify the fontconfig settings.  This is not necessary for GTK+ applications because they get their settings from the <tt>gnome-appearance-properties</tt> dialog.  So in <tt>~/.fonts.conf</tt> add:</p>
<div class="codecolorer-container xml default" style="overflow:auto;white-space:nowrap;border:1px solid #9F9F9F;width:435px;"><div class="xml codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;?xml</span> <span style="color: #000066;">version</span>=<span style="color: #ff0000;">&quot;1.0&quot;</span><span style="color: #000000; font-weight: bold;">?&gt;</span></span><br />
<span style="color: #00bbdd;">&lt;!DOCTYPE fontconfig SYSTEM &quot;fonts.dtd&quot;&gt;</span><br />
<span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;fontconfig<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
<span style="color: #808080; font-style: italic;">&lt;!-- &nbsp;Use the Antialiasing --&gt;</span> <br />
&nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;match</span> <span style="color: #000066;">target</span>=<span style="color: #ff0000;">&quot;font&quot;</span><span style="color: #000000; font-weight: bold;">&gt;</span></span><br />
&nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;edit</span> <span style="color: #000066;">name</span>=<span style="color: #ff0000;">&quot;antialias&quot;</span> <span style="color: #000066;">mode</span>=<span style="color: #ff0000;">&quot;assign&quot;</span><span style="color: #000000; font-weight: bold;">&gt;</span><span style="color: #000000; font-weight: bold;">&lt;bool<span style="color: #000000; font-weight: bold;">&gt;</span></span></span>true<span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/bool<span style="color: #000000; font-weight: bold;">&gt;</span></span><span style="color: #000000; font-weight: bold;">&lt;/edit<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
&nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/match<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
<span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/fontconfig<span style="color: #000000; font-weight: bold;">&gt;</span></span></span></div></div>
<p>Other Qt appearance settings can be changed from the <tt>qtconfig</tt> dialog.</p>
]]></content:encoded>
			<wfw:commentRss>http://thestaticvoid.com/post/2010/02/14/musicbrainz-picard/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Start Virtual NICs on OpenSolaris Boot</title>
		<link>http://thestaticvoid.com/post/2009/12/23/start-virtual-nics-on-opensolaris-boot/</link>
		<comments>http://thestaticvoid.com/post/2009/12/23/start-virtual-nics-on-opensolaris-boot/#comments</comments>
		<pubDate>Wed, 23 Dec 2009 16:12:51 +0000</pubDate>
		<dc:creator>James Lee</dc:creator>
				<category><![CDATA[System Administration]]></category>
		<category><![CDATA[crossbow]]></category>
		<category><![CDATA[opensolaris]]></category>
		<category><![CDATA[smf]]></category>
		<category><![CDATA[zones]]></category>

		<guid isPermaLink="false">http://thestaticvoid.com/?p=230</guid>
		<description><![CDATA[One of the more frustrating things I deal with on OpenSolaris is that every time I reboot, I have to manually bring up each virtual network interface in order to start all of my zones. There is a bug report for this problem that says a fix will be integrated into b132, which is just [...]]]></description>
			<content:encoded><![CDATA[<p>One of the more frustrating things I deal with on OpenSolaris is that every time I reboot, I have to manually bring up each virtual network interface in order to start all of my zones.  There is a <a href="http://bugs.opensolaris.org/view_bug.do?bug_id=6776009">bug report</a> for this problem that says a fix will be integrated into b132, which is just a few weeks away, but in the mean time, I&#8217;ve whipped up an SMF service to handle this for me.  Create a file <tt>vnic.xml</tt>:</p>
<div class="codecolorer-container xml default" style="overflow:auto;white-space:nowrap;border:1px solid #9F9F9F;width:435px;height:300px;"><div class="xml codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;?xml</span> <span style="color: #000066;">version</span>=<span style="color: #ff0000;">&quot;1.0&quot;</span><span style="color: #000000; font-weight: bold;">?&gt;</span></span><br />
<span style="color: #00bbdd;">&lt;!DOCTYPE service_bundle SYSTEM &quot;/usr/share/lib/xml/dtd/service_bundle.dtd.1&quot;&gt;</span><br />
<br />
<span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;service_bundle</span> <span style="color: #000066;">type</span>=<span style="color: #ff0000;">'manifest'</span> <span style="color: #000066;">name</span>=<span style="color: #ff0000;">'vnic'</span><span style="color: #000000; font-weight: bold;">&gt;</span></span><br />
<br />
<span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;service</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; <span style="color: #000066;">name</span>=<span style="color: #ff0000;">'network/vnic'</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; <span style="color: #000066;">type</span>=<span style="color: #ff0000;">'service'</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; <span style="color: #000066;">version</span>=<span style="color: #ff0000;">'1'</span><span style="color: #000000; font-weight: bold;">&gt;</span></span><br />
<br />
&nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;dependency</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000066;">name</span>=<span style="color: #ff0000;">'network_service'</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000066;">grouping</span>=<span style="color: #ff0000;">'require_all'</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000066;">restart_on</span>=<span style="color: #ff0000;">'none'</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000066;">type</span>=<span style="color: #ff0000;">'service'</span><span style="color: #000000; font-weight: bold;">&gt;</span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;service_fmri</span> <span style="color: #000066;">value</span>=<span style="color: #ff0000;">'svc:/network/service'</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
&nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/dependency<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
<br />
&nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;dependent</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000066;">name</span>=<span style="color: #ff0000;">'network_vnic'</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000066;">grouping</span>=<span style="color: #ff0000;">'optional_all'</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000066;">restart_on</span>=<span style="color: #ff0000;">'none'</span><span style="color: #000000; font-weight: bold;">&gt;</span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;service_fmri</span> <span style="color: #000066;">value</span>=<span style="color: #ff0000;">'svc:/system/zones'</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
&nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/dependent<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
<br />
&nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;exec_method</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000066;">type</span>=<span style="color: #ff0000;">'method'</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000066;">name</span>=<span style="color: #ff0000;">'start'</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000066;">exec</span>=<span style="color: #ff0000;">'/usr/sbin/dladm up-vnic ${SMF_FMRI/*:/}'</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000066;">timeout_seconds</span>=<span style="color: #ff0000;">'60'</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
<br />
&nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;exec_method</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000066;">type</span>=<span style="color: #ff0000;">'method'</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000066;">name</span>=<span style="color: #ff0000;">'stop'</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000066;">exec</span>=<span style="color: #ff0000;">':true'</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000066;">timeout_seconds</span>=<span style="color: #ff0000;">'60'</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
<br />
&nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;property_group</span> <span style="color: #000066;">name</span>=<span style="color: #ff0000;">'startd'</span> <span style="color: #000066;">type</span>=<span style="color: #ff0000;">'framework'</span><span style="color: #000000; font-weight: bold;">&gt;</span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;propval</span> <span style="color: #000066;">name</span>=<span style="color: #ff0000;">'duration'</span> <span style="color: #000066;">type</span>=<span style="color: #ff0000;">'astring'</span> <span style="color: #000066;">value</span>=<span style="color: #ff0000;">'transient'</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
&nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/property_group<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
<br />
&nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;stability</span> <span style="color: #000066;">value</span>=<span style="color: #ff0000;">'Unstable'</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
<br />
&nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;template<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;common_name<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;loctext</span> <span style="color: #000066;">xml:lang</span>=<span style="color: #ff0000;">'C'</span><span style="color: #000000; font-weight: bold;">&gt;</span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; Virtual Network Interface<br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/loctext<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/common_name<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;documentation<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;manpage</span> <span style="color: #000066;">title</span>=<span style="color: #ff0000;">'dladm'</span> <span style="color: #000066;">section</span>=<span style="color: #ff0000;">'1M'</span></span><br />
<span style="color: #009900;">&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000066;">manpath</span>=<span style="color: #ff0000;">'/usr/share/man'</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/documentation<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
&nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/template<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
<span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/service<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
<br />
<span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/service_bundle<span style="color: #000000; font-weight: bold;">&gt;</span></span></span></div></div>
<p>This service should run sometime after the network is started but before the zones are started.  Load it in with <tt>svccfg -v import vnic.xml</tt> and create an instance of the service for each of the VNICs that you want to start.  For example, if you want to start <tt>vnic0</tt> on boot:</p>
<pre class="terminal">
# <kbd>svccfg -s vnic add vnic0</kbd>
# <kbd>svcadm refresh vnic0</kbd>
# <kbd>svcadm enable vnic0</kbd>
</pre>
<p><strong>UPDATE:</strong> Build 132 is out an this functionality has been integrated as the <tt>svc:/network/datalink-management:default</tt> service.  The services that were added above can be removed by running <tt>svccfg delete vnic</tt>.</p>
]]></content:encoded>
			<wfw:commentRss>http://thestaticvoid.com/post/2009/12/23/start-virtual-nics-on-opensolaris-boot/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Music Player Daemon on OpenSolaris</title>
		<link>http://thestaticvoid.com/post/2009/12/04/music-player-daemon-on-opensolaris/</link>
		<comments>http://thestaticvoid.com/post/2009/12/04/music-player-daemon-on-opensolaris/#comments</comments>
		<pubDate>Sat, 05 Dec 2009 01:44:36 +0000</pubDate>
		<dc:creator>James Lee</dc:creator>
				<category><![CDATA[Desktop]]></category>
		<category><![CDATA[mpd]]></category>
		<category><![CDATA[opensolaris]]></category>
		<category><![CDATA[packages]]></category>

		<guid isPermaLink="false">http://thestaticvoid.com/?p=188</guid>
		<description><![CDATA[MPD is essential software for me. It&#8217;s one of the few music players out there for Unix that does gapless playback and ReplayGain. It&#8217;s also nice that, because it&#8217;s a daemon, I&#8217;m not bound to any particular interface. Fortunately, there is a really good one in the form of Sonata. MPD is not included in [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://mpd.wikia.com/wiki/Music_Player_Daemon_Wiki">MPD</a> is essential software for me.  It&#8217;s one of the few music players out there for Unix that does gapless playback and ReplayGain.  It&#8217;s also nice that, because it&#8217;s a daemon, I&#8217;m not bound to any particular interface.  Fortunately, there is a really good one in the form of <a href="http://sonata.berlios.de/">Sonata</a>.</p>
<p>MPD is not included in OpenSolaris yet, so last weekend I built some packages for it.  The build has been stable for me and I&#8217;m happy with the state of the packages so I thought I&#8217;d share them.  First add my <a href="http://pkg.thestaticvoid.com/">package repository</a>:</p>
<pre class="terminal">
$ <kbd>pfexec pkg set-authority -O http://pkg.thestaticvoid.com/ thestaticvoid</kbd>
</pre>
<h3>MPD</h3>
<p>This package and its dependencies require OpenSolaris 2009.06 or newer.  Install it by typing <tt>pfexec pkg install mpd</tt>.  The following formats are supported:</p>
<pre class="terminal">
$ <kbd>mpd -V</kbd>
...
Supported decoders:
[mad] mp3 mp2
[vorbis] ogg oga
[oggflac] ogg oga
[flac] flac
[audiofile] wav au aiff aif
[faad] aac
[mp4] m4a mp4
[mpcdec] mpc
[wavpack] wv

Supported outputs:
shout null fifo ao solaris httpd 

Supported protocols:
file:// http://
</pre>
<p>I plan on adding ffmpeg support soon which will add support for even more codecs.</p>
<p>To run MPD, create a configuration file in your home directory like</p>
<div class="codecolorer-container text default" style="overflow:auto;white-space:nowrap;border:1px solid #9F9F9F;width:435px;"><div class="text codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap">port&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &quot;6600&quot;<br />
music_directory &nbsp; &nbsp; &nbsp; &nbsp; &quot;~/music&quot;<br />
playlist_directory &nbsp; &nbsp; &nbsp;&quot;~/.mpd/playlists&quot;<br />
db_file &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &quot;~/.mpd/mpd.db&quot;<br />
log_file &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;&quot;~/.mpd/mpd.log&quot;</div></div>
<p>Create any directories from the configuration file that don&#8217;t exist, such as <tt>~/.mpd/playlists</tt> and start the daemon by running <tt>mpd ~/.mpdconf</tt> as your user.  It will immediately build a library of your music.</p>
<p>Alternatively, mpd can be run system-wide, which just seems more appropriate to me for whatever reason.  The only complicated part about this is that you have to give MPD permission to write to the audio device.  Edit <tt>/etc/logindevperms</tt>, find the <tt>/dev/sound/*</tt> lines and change the mode to 0666 so that they look like:</p>
<div class="codecolorer-container text default" style="overflow:auto;white-space:nowrap;border:1px solid #9F9F9F;width:435px;"><div class="text codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap">/dev/console&nbsp; &nbsp; 0666&nbsp; &nbsp; /dev/sound/*&nbsp; &nbsp; &nbsp; &nbsp; # audio devices<br />
/dev/vt/active&nbsp; 0666&nbsp; &nbsp; /dev/sound/*&nbsp; &nbsp; &nbsp; &nbsp; # audio devices</div></div>
<p>Logout and log back in for the settings to take effect.  Then modify <tt>/etc/mpd.conf</tt> to your liking and start the daemon by typing <tt>svcadm enable mpd</tt>.  You may have to <tt>svcadm refresh manifest-import</tt> for SMF to load the mpd manifest.</p>
<h3>mpdscribble</h3>
<p>I also built a package for <a href="http://mpd.wikia.com/wiki/Client:Mpdscribble">mpdscribble</a> which is a mature, well-maintained scrobbler for <a href="http://www.last.fm/">Last.fm</a>.  Install it by typing <tt>pfexec pkg install mpdscribble</tt>.  Set your Last.fm or Libre.fm username and password in <tt>/etc/mpdscribble.conf</tt> and start the daemon with <tt>svcadm enable mpdscribble</tt>.  That&#8217;s all there is to it.</p>
<h3>Sonata</h3>
<p>Sonata is a lightweight cilent for MPD.  Looks pretty nice too:</p>
<p><img src="http://thestaticvoid.com/wordpress/wp-content/uploads/2009/12/sonata.png" alt="Sonata" title="Sonata" width="408" height="326" class="aligncenter size-full wp-image-201" /></p>
<p>Because Sonata requires Python 2.5, and OpenSolaris 2009.06 only really supports Python 2.3, this package requires build 127 or newer.  Install it by typing <tt>pfexec pkg install sonata</tt>.  It can be launched from the Applications->Sound &#038; Video menu.</p>
]]></content:encoded>
			<wfw:commentRss>http://thestaticvoid.com/post/2009/12/04/music-player-daemon-on-opensolaris/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Mixer State in OpenSolaris</title>
		<link>http://thestaticvoid.com/post/2009/11/25/mixer-state-in-opensolaris/</link>
		<comments>http://thestaticvoid.com/post/2009/11/25/mixer-state-in-opensolaris/#comments</comments>
		<pubDate>Wed, 25 Nov 2009 18:32:48 +0000</pubDate>
		<dc:creator>James Lee</dc:creator>
				<category><![CDATA[Desktop]]></category>
		<category><![CDATA[mixer]]></category>
		<category><![CDATA[opensolaris]]></category>
		<category><![CDATA[oss]]></category>
		<category><![CDATA[smf]]></category>

		<guid isPermaLink="false">http://thestaticvoid.com/?p=174</guid>
		<description><![CDATA[I&#8217;ve recently installed OpenSolaris on my desktop and noticed that my volume settings do not persist between reboots. A quick search revealed that that functionality hasn&#8217;t been implemented yet. The thread suggested using the mixerctl command to save and restore the mixer state so I&#8217;ve thrown together an SMF service to do it automatically on [...]]]></description>
			<content:encoded><![CDATA[<p>I&#8217;ve recently installed OpenSolaris on my desktop and noticed that my volume settings do not persist between reboots.  A quick search revealed that <a href="http://opensolaris.org/jive/thread.jspa?threadID=118058&#038;tstart=0">that functionality hasn&#8217;t been implemented yet</a>.  The thread suggested using the <tt>mixerctl</tt> command to save and restore the mixer state so I&#8217;ve thrown together an SMF service to do it automatically on boot and shutdown.</p>
<p>First, the script which should go into <tt>/lib/svc/method/sound-mixer</tt>:</p>
<div class="codecolorer-container bash default" style="overflow:auto;white-space:nowrap;border:1px solid #9F9F9F;width:435px;height:300px;"><div class="bash codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #666666; font-style: italic;">#!/sbin/sh</span><br />
<br />
. <span style="color: #000000; font-weight: bold;">/</span>lib<span style="color: #000000; font-weight: bold;">/</span>svc<span style="color: #000000; font-weight: bold;">/</span>share<span style="color: #000000; font-weight: bold;">/</span>smf_include.sh<br />
smf_is_globalzone <span style="color: #000000; font-weight: bold;">||</span> <span style="color: #7a0874; font-weight: bold;">exit</span> <span style="color: #007800;">$SMF_EXIT_OK</span><br />
<br />
<span style="color: #007800;">ctl_file</span>=$<span style="color: #7a0874; font-weight: bold;">&#40;</span>svcprop <span style="color: #660033;">-p</span> options<span style="color: #000000; font-weight: bold;">/</span>ctl_file <span style="color: #007800;">$SMF_FMRI</span><span style="color: #7a0874; font-weight: bold;">&#41;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">case</span> <span style="color: #ff0000;">&quot;$1&quot;</span> <span style="color: #000000; font-weight: bold;">in</span><br />
<span style="color: #ff0000;">'start'</span><span style="color: #7a0874; font-weight: bold;">&#41;</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000000; font-weight: bold;">if</span> <span style="color: #7a0874; font-weight: bold;">&#91;</span> <span style="color: #000000; font-weight: bold;">!</span> <span style="color: #660033;">-f</span> <span style="color: #007800;">$ctl_file</span> <span style="color: #7a0874; font-weight: bold;">&#93;</span>; <span style="color: #000000; font-weight: bold;">then</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #7a0874; font-weight: bold;">echo</span> <span style="color: #ff0000;">&quot;Mixer control file <span style="color: #007800;">$ctl_file</span> does not exist.&quot;</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #7a0874; font-weight: bold;">exit</span> <span style="color: #007800;">$SMF_EXIT_OK</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000000; font-weight: bold;">fi</span><br />
<br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000000; font-weight: bold;">if</span> <span style="color: #000000; font-weight: bold;">!</span> <span style="color: #000000; font-weight: bold;">/</span>usr<span style="color: #000000; font-weight: bold;">/</span>sbin<span style="color: #000000; font-weight: bold;">/</span>mixerctl <span style="color: #660033;">-r</span> <span style="color: #007800;">$ctl_file</span>; <span style="color: #000000; font-weight: bold;">then</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #7a0874; font-weight: bold;">echo</span> <span style="color: #ff0000;">&quot;Error restoring mixer state.&quot;</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #7a0874; font-weight: bold;">exit</span> <span style="color: #007800;">$SMF_EXIT_OK</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000000; font-weight: bold;">fi</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000000; font-weight: bold;">;;</span><br />
<br />
<span style="color: #ff0000;">'stop'</span><span style="color: #7a0874; font-weight: bold;">&#41;</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000000; font-weight: bold;">if</span> <span style="color: #000000; font-weight: bold;">!</span> <span style="color: #000000; font-weight: bold;">/</span>usr<span style="color: #000000; font-weight: bold;">/</span>sbin<span style="color: #000000; font-weight: bold;">/</span>mixerctl <span style="color: #660033;">-f</span> <span style="color: #660033;">-s</span> <span style="color: #007800;">$ctl_file</span>; <span style="color: #000000; font-weight: bold;">then</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #7a0874; font-weight: bold;">echo</span> <span style="color: #ff0000;">&quot;Error saving mixer state.&quot;</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #7a0874; font-weight: bold;">exit</span> <span style="color: #007800;">$SMF_EXIT_OK</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000000; font-weight: bold;">fi</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000000; font-weight: bold;">;;</span><br />
<br />
<span style="color: #000000; font-weight: bold;">*</span><span style="color: #7a0874; font-weight: bold;">&#41;</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #7a0874; font-weight: bold;">echo</span> <span style="color: #ff0000;">&quot;Usage: $0 { start | stop }&quot;</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #7a0874; font-weight: bold;">exit</span> <span style="color: #007800;">$SMF_EXIT_ERR_CONFIG</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #000000; font-weight: bold;">;;</span><br />
<span style="color: #000000; font-weight: bold;">esac</span><br />
<br />
<span style="color: #7a0874; font-weight: bold;">exit</span> <span style="color: #007800;">$SMF_EXIT_OK</span></div></div>
<p>Second, the manifest which can be saved anywhere and loaded with <tt>svccfg -v import &lt;manifest&gt;</tt>:</p>
<div class="codecolorer-container xml default" style="overflow:auto;white-space:nowrap;border:1px solid #9F9F9F;width:435px;height:300px;"><div class="xml codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;?xml</span> <span style="color: #000066;">version</span>=<span style="color: #ff0000;">&quot;1.0&quot;</span><span style="color: #000000; font-weight: bold;">?&gt;</span></span><br />
<span style="color: #00bbdd;">&lt;!DOCTYPE service_bundle SYSTEM &quot;/usr/share/lib/xml/dtd/service_bundle.dtd.1&quot;&gt;</span><br />
<br />
<span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;service_bundle</span> <span style="color: #000066;">type</span>=<span style="color: #ff0000;">'manifest'</span> <span style="color: #000066;">name</span>=<span style="color: #ff0000;">'mixer'</span><span style="color: #000000; font-weight: bold;">&gt;</span></span><br />
<br />
<span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;service</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">name</span>=<span style="color: #ff0000;">'system/sound/mixer'</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">type</span>=<span style="color: #ff0000;">'service'</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">version</span>=<span style="color: #ff0000;">'1'</span><span style="color: #000000; font-weight: bold;">&gt;</span></span><br />
<br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;create_default_instance</span> <span style="color: #000066;">enabled</span>=<span style="color: #ff0000;">'true'</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;single_instance</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
<br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;dependency</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">name</span>=<span style="color: #ff0000;">'fs-local'</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">grouping</span>=<span style="color: #ff0000;">'require_all'</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">restart_on</span>=<span style="color: #ff0000;">'none'</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">type</span>=<span style="color: #ff0000;">'service'</span><span style="color: #000000; font-weight: bold;">&gt;</span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;service_fmri</span> <span style="color: #000066;">value</span>=<span style="color: #ff0000;">'svc:/system/filesystem/local'</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/dependency<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;dependency</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">name</span>=<span style="color: #ff0000;">'device-audio'</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">grouping</span>=<span style="color: #ff0000;">'require_all'</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">restart_on</span>=<span style="color: #ff0000;">'none'</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">type</span>=<span style="color: #ff0000;">'service'</span><span style="color: #000000; font-weight: bold;">&gt;</span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;service_fmri</span> <span style="color: #000066;">value</span>=<span style="color: #ff0000;">'svc:/system/device/audio'</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/dependency<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
<br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;exec_method</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">type</span>=<span style="color: #ff0000;">'method'</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">name</span>=<span style="color: #ff0000;">'start'</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">exec</span>=<span style="color: #ff0000;">'/lib/svc/method/sound-mixer start'</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">timeout_seconds</span>=<span style="color: #ff0000;">'60'</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
<br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;exec_method</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">type</span>=<span style="color: #ff0000;">'method'</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">name</span>=<span style="color: #ff0000;">'stop'</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">exec</span>=<span style="color: #ff0000;">'/lib/svc/method/sound-mixer stop'</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">timeout_seconds</span>=<span style="color: #ff0000;">'60'</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
<br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;property_group</span> <span style="color: #000066;">name</span>=<span style="color: #ff0000;">'options'</span> <span style="color: #000066;">type</span>=<span style="color: #ff0000;">'application'</span><span style="color: #000000; font-weight: bold;">&gt;</span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;propval</span> <span style="color: #000066;">name</span>=<span style="color: #ff0000;">'ctl_file'</span> <span style="color: #000066;">type</span>=<span style="color: #ff0000;">'astring'</span> <span style="color: #000066;">value</span>=<span style="color: #ff0000;">'/etc/sound/mixer.state'</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/property_group<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
<br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;property_group</span> <span style="color: #000066;">name</span>=<span style="color: #ff0000;">'startd'</span> <span style="color: #000066;">type</span>=<span style="color: #ff0000;">'framework'</span><span style="color: #000000; font-weight: bold;">&gt;</span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;propval</span> <span style="color: #000066;">name</span>=<span style="color: #ff0000;">'duration'</span> <span style="color: #000066;">type</span>=<span style="color: #ff0000;">'astring'</span> <span style="color: #000066;">value</span>=<span style="color: #ff0000;">'transient'</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/property_group<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
<br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;stability</span> <span style="color: #000066;">value</span>=<span style="color: #ff0000;">'Unstable'</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
<br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;template<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;common_name<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;loctext</span> <span style="color: #000066;">xml:lang</span>=<span style="color: #ff0000;">'C'</span><span style="color: #000000; font-weight: bold;">&gt;</span></span>Mixer State Saver<span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/loctext<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/common_name<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;documentation<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;manpage</span> <span style="color: #000066;">title</span>=<span style="color: #ff0000;">'mixerctl'</span> <span style="color: #000066;">section</span>=<span style="color: #ff0000;">'1M'</span></span><br />
<span style="color: #009900;"> &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp;<span style="color: #000066;">manpath</span>=<span style="color: #ff0000;">'/usr/share/man'</span> <span style="color: #000000; font-weight: bold;">/&gt;</span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/documentation<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/template<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
<br />
<span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/service<span style="color: #000000; font-weight: bold;">&gt;</span></span></span><br />
<br />
<span style="color: #009900;"><span style="color: #000000; font-weight: bold;">&lt;/service_bundle<span style="color: #000000; font-weight: bold;">&gt;</span></span></span></div></div>
<p><strong>UPDATE:</strong> In b130, the <tt>audioctl</tt> command replaces <tt>mixerctl</tt>.  In the <tt>sound-mixer</tt> script above, change <tt>/usr/sbin/mixerctl -r $ctl_file</tt> to <tt>/usr/bin/audioctl load-controls $ctl_file</tt> and <tt>/usr/sbin/mixerctl -f -s $ctl_file</tt> to <tt>/usr/bin/audioctl save-controls -f $ctl_file</tt>.</p>
]]></content:encoded>
			<wfw:commentRss>http://thestaticvoid.com/post/2009/11/25/mixer-state-in-opensolaris/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>suEXEC on OpenSolaris</title>
		<link>http://thestaticvoid.com/post/2009/07/27/suexec-on-opensolaris/</link>
		<comments>http://thestaticvoid.com/post/2009/07/27/suexec-on-opensolaris/#comments</comments>
		<pubDate>Tue, 28 Jul 2009 03:24:59 +0000</pubDate>
		<dc:creator>James Lee</dc:creator>
				<category><![CDATA[System Administration]]></category>
		<category><![CDATA[apache]]></category>
		<category><![CDATA[cgi]]></category>
		<category><![CDATA[opensolaris]]></category>
		<category><![CDATA[php]]></category>
		<category><![CDATA[suexec]]></category>

		<guid isPermaLink="false">http://thestaticvoid.com/?p=96</guid>
		<description><![CDATA[One nice thing about having all dynamic content being generated by CGI is that you can use suEXEC to run the scripts as a different user. This is primarily used for systems where you have multiple untrusted users who run sites in one HTTP server. Then no one can interfere with anyone else. It can [...]]]></description>
			<content:encoded><![CDATA[<p>One nice thing about having all dynamic content being generated by CGI is that you can use <a href="http://httpd.apache.org/docs/2.2/suexec.html">suEXEC</a> to run the scripts as a different user.  This is primarily used for systems where you have multiple untrusted users who run sites in one HTTP server.  Then no one can interfere with anyone else.  It can also be used simply for separating the application from the server.</p>
<p>I&#8217;m the only user on my server so I don&#8217;t necessarily have any of these security concerns, but I have enabled suEXEC for convenience.  For example, WordPress will allow you to modify the stylesheets from the admin interface as long as it can write to them.  With suEXEC, the admin interface can run as my Unix user, so I can edit the files from both the web interface and the command line without having wide-open permissions or switching to root.</p>
<p>Same applies for <a href="http://iriverter.thestaticvoid.com/">Trac</a> where I can manage the project with the web interface or <tt>trac-admin</tt> on the command line.  The same effect could pretty much be obtained by using Unix groups properly:</p>
<pre class="terminal"># <kbd>groupadd wordpress</kbd>
# <kbd>usermod -G wordpress webservd</kbd>
# <kbd>usermod -G wordpress jlee</kbd>  <span class="comment"># my username</span>
# <kbd>chgrp -R wordpress /docs/thestaticvoid.com</kbd>  <span class="comment"># virtualhost document root</span>
# <kbd>chmod -R g+ws /docs/thestaticvoid.com</kbd>  <span class="comment"># make directory writable and always owned by
                                           the wordpress group</pre>
<p>Then <tt>umask 002</tt> would have to be set in Apache&#8217;s and my profile so any files that get created can be written to by the other users in the group.  That&#8217;s all well and good, but it seems like a bit of work and I don&#8217;t like the idea of messing with the default umask.</p>
<p>On to suEXEC.  First, let&#8217;s show the current user that PHP executes as.  Create a file <tt>test.php</tt> containing <code class="codecolorer php default"><span class="php"><span style="color: #000000; font-weight: bold;">&lt;?php</span> <span style="color: #b1b100;">echo</span> <span style="color: #990000;">exec</span><span style="color: #009900;">&#40;</span><span style="color: #0000ff;">&quot;id&quot;</span><span style="color: #009900;">&#41;</span><span style="color: #339933;">;</span> <span style="color: #000000; font-weight: bold;">?&gt;</span></span></code>.  Accessing the script from your web browser should show something like <tt>uid=80(webservd) gid=80(webservd)</tt>.</p>
<p>Next, in OpenSolaris, the <tt>suexec</tt> binary must be enabled:</p>
<pre class="terminal"># <kbd>cd /usr/apache2/2.2/bin/</kbd>  <span class="comment"># go one directory further into the amd64 dir
                              if you're running 64-bit</span>
# <kbd>mv suexec.disabled suexec</kbd>
# <kbd>chown root:webservd suexec</kbd>
# <kbd>chmod 4750 suexec</kbd>
# <kbd>./suexec -V</kbd>
 -D AP_DOC_ROOT="/var/apache2/2.2/htdocs"
 -D AP_GID_MIN=100
 -D AP_HTTPD_USER="webservd"
 -D AP_LOG_EXEC="/var/apache2/2.2/logs/suexec_log"
 -D AP_SAFE_PATH="/usr/local/bin:/usr/bin:/bin"
 -D AP_UID_MIN=100
 -D AP_USERDIR_SUFFIX="public_html"
</pre>
<p>These variables were set at compile time and cannot be changed.  They ensure that certain conditions must be met in order to use the binary.  That&#8217;s very important because it&#8217;s setuid root.  The first thing I had to do was move everything from my old document root to the one specified above in <tt>AP_DOC_ROOT</tt>.  Then you can add <code class="codecolorer apache default"><span class="apache"><span style="color: #00007f;">SuexecUserGroup</span> jlee jlee</span></code> (with whatever username and group you want the scripts to run as) to your <code class="codecolorer apache default"><span class="apache">&lt;<span style="color: #000000; font-weight:bold;">VirtualHost</span>&gt;</span></code> section of the Apache configuration.  At this point if you try to execute <tt>test.php</tt> you&#8217;ll probably see one of a couple errors in the suEXEC log (<tt>/var/apache2/2.2/logs/suexec_log</tt>):</p>
<ul>
<li><tt>[2009-07-27 11:08:02]: uid: (1000/jlee) gid: (1000/jlee) cmd: php-cgi<br />
[2009-07-27 11:08:02]: command not in docroot (/usr/php/bin/php-cgi)</tt><br />
In this case, <tt>php-cgi</tt> is going to have to be moved to the document root:</p>
<pre class="terminal">$ <kbd>cp /usr/php/bin/php-cgi /var/apache2/2.2/htdocs/</kbd>
$ <kbd>pfexec vi /etc/apache2/2.2/conf.d/php-cgi.conf</kbd>  <span class="comment"># modify the ScriptAlias appropriately</span>
$ <kbd>svcadm restart http</kbd></pre>
</li>
<li><tt>[2009-07-27 11:11:07]: uid: (1000/jlee) gid: (1000/jlee) cmd: php-cgi<br />
[2009-07-27 11:11:07]: target uid/gid (1000/1000) mismatch with directory (0/2) or program (0/0)</tt><br />
Make sure everything that <tt>suexec</tt> is to execute is owned by the same user and group as specified in the <code class="codecolorer apache default"><span class="apache"><span style="color: #00007f;">SuexecUserGroup</span></span></code> line of your Apache configuration.</li>
</ul>
<p>Now, running <tt>test.php</tt> should give the correct results: <tt>uid=1000(jlee) gid=1000(jlee)</tt>.  Done!</p>
<p>As a side note, I lose all frame of reference while I write so I can&#8217;t remember if I&#8217;m writing this for <strong>you</strong> or <strong>me</strong>, explaining what I&#8217;ve <strong>done</strong> or what you <strong>should do</strong>.  Sorry <img src='http://thestaticvoid.com/wordpress/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> </p>
]]></content:encoded>
			<wfw:commentRss>http://thestaticvoid.com/post/2009/07/27/suexec-on-opensolaris/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Reducing Memory Footprint of Apache Services</title>
		<link>http://thestaticvoid.com/post/2009/07/27/reducing-memory-footprint-of-apache-services/</link>
		<comments>http://thestaticvoid.com/post/2009/07/27/reducing-memory-footprint-of-apache-services/#comments</comments>
		<pubDate>Mon, 27 Jul 2009 23:34:57 +0000</pubDate>
		<dc:creator>James Lee</dc:creator>
				<category><![CDATA[System Administration]]></category>
		<category><![CDATA[apache]]></category>
		<category><![CDATA[cgi]]></category>
		<category><![CDATA[opensolaris]]></category>
		<category><![CDATA[php]]></category>

		<guid isPermaLink="false">http://thestaticvoid.com/?p=57</guid>
		<description><![CDATA[An interesting thing happened when I set up this blog. It first manifested itself as a heap of junk mail in my inbox. Then no mail at all. I had run out of memory. WordPress requires me to run MySQL and that extra 12M pushed me over the 256M cap in my OpenSolaris 2009.06 zone. [...]]]></description>
			<content:encoded><![CDATA[<p>An interesting thing happened when I set up this blog.  It first manifested itself as a heap of junk mail in my inbox.  Then no mail at all.  I had run out of memory.  WordPress requires me to run MySQL and that extra 12M pushed me over the 256M cap in my <a href="http://entic.net/">OpenSolaris 2009.06 zone</a>.  As a result SpamAssassin could not spawn, and ultimately Postfix died.  So I sought out to try to reduce my memory footprint.</p>
<p>Let&#8217;s take a look at where things were when I got started:</p>
<pre class="terminal">$ <kbd>prstat -s rss -Z 1 1 | cat</kbd>
   PID USERNAME  SIZE   RSS STATE  PRI NICE      TIME  CPU PROCESS/NLWP
 13488 webservd  183M   92M sleep   59    0   0:00:28 0.0% trac.fcgi/1
 13479 webservd   59M   41M sleep   59    0   0:00:14 0.0% trac.fcgi/1
 13489 webservd   59M   41M sleep   59    0   0:00:14 0.0% trac.fcgi/1
  4463 mysql      64M   12M sleep   59    0   0:02:39 0.0% mysqld/10
 19296 root       13M 8444K sleep   59    0   0:00:25 0.0% svc.configd/16
 19619 named      11M 5824K sleep   59    0   0:03:51 0.0% named/7
 13473 root       64M 4352K sleep   59    0   0:00:00 0.0% httpd/1
 19358 root       12M 3688K sleep   59    0   0:00:54 0.0% nscd/31
 19294 root       12M 3180K sleep   59    0 244:37:22 0.0% svc.startd/13
 13476 webservd   64M 2940K sleep   59    0   0:00:00 0.0% httpd/1
 13486 webservd   64M 2924K sleep   59    0   0:00:00 0.0% httpd/1
 13745 root     6248K 2832K cpu1    59    0   0:00:00 0.0% prstat/1
 13721 root     5940K 2368K sleep   39    0   0:00:00 0.0% bash/1
 13485 webservd   64M 2252K sleep   59    0   0:00:00 0.0% httpd/1
 13482 webservd   64M 2168K sleep   59    0   0:00:00 0.0% httpd/1
ZONEID    NPROC  SWAP   RSS MEMORY      TIME  CPU ZONE
    39       60  494M  246M    96% 244:47:13 0.1% case
Total: 60 processes, 149 lwps, load averages: 0.61, 0.62, 0.52</pre>
<p>First thing I noticed is the 174M that <a href="http://iriverter.thestaticvoid.com/">Trac</a> was taking up.  I was running it as a FastCGI service for speed.  The problem with that is it remains resident even when it&#8217;s not processing any requests, which is most of the time.  One option I tried was setting <tt>DefaultMaxClassProcessCount 1</tt> in my <tt>/etc/apache2/2.2/conf.d/fcgid.conf</tt> file.  This effectively limits Trac to only one process at a time, which greatly reduces the memory utilization, but means it can only service one request at a time.  That&#8217;s not an option.</p>
<p>Fortunately, my zone seems to have good, fast processors and disks, so I can put up with running it as standard CGI service.  Easy enough to make the switch, just move some things around in my Apache configuration:</p>
<div class="codecolorer-container apache default" style="overflow:auto;white-space:nowrap;border:1px solid #9F9F9F;width:435px;"><div class="apache codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap"><span style="color: #00007f;">ScriptAlias</span> /trac /usr/share/trac/cgi-bin/trac.cgi<br />
<span style="color: #adadad; font-style: italic;">#ScriptAlias /trac /usr/share/trac/cgi-bin/trac.fcgi</span><br />
<span style="color: #adadad; font-style: italic;">#DefaultInitEnv TRAC_ENV &quot;/trac/iriverter&quot;</span><br />
<br />
&lt;<span style="color: #000000; font-weight:bold;">Location</span> <span style="color: #7f007f;">&quot;/trac&quot;</span>&gt;<br />
&nbsp; &nbsp; <span style="color: #00007f;">SetEnv</span> TRAC_ENV <span style="color: #7f007f;">&quot;/trac/iriverter&quot;</span><br />
&nbsp; &nbsp; <span style="color: #00007f;">Order</span> <span style="color: #00007f;">allow</span>,<span style="color: #00007f;">deny</span><br />
&nbsp; &nbsp; <span style="color: #00007f;">Allow</span> from <span style="color: #0000ff;">all</span><br />
&lt;/<span style="color: #000000; font-weight:bold;">Location</span>&gt;</div></div>
<p>So things are looking much better, but I&#8217;m still not happy with it:</p>
<pre class="terminal">$ <kbd>prstat -s rss -Z 1 1 | cat</kbd>
   PID USERNAME  SIZE   RSS STATE  PRI NICE      TIME  CPU PROCESS/NLWP
 15362 webservd   74M   31M sleep   59    0   0:00:00 0.0% httpd/1
 15388 webservd   69M   30M sleep   59    0   0:00:00 0.0% httpd/1
 15366 webservd   66M   22M sleep   59    0   0:00:00 0.0% httpd/1
...
ZONEID    NPROC  SWAP   RSS MEMORY      TIME  CPU ZONE
    39       58  254M  113M    44% 244:46:20 0.2% case </pre>
<p>Now Apache is being a hog, and that&#8217;s only a few of the <tt>httpd</tt> processes.  By default on Unix, Apache uses the <a href="http://httpd.apache.org/docs/2.2/mod/prefork.html">prefork MPM</a> which serves each request from its own process. It likes to keep around a handful of children for performance, so it doesn&#8217;t have to swawn a new one each time.  The problem is if your request involves PHP, each <tt>httpd</tt> process will load its own instance of the PHP module and it doesn&#8217;t let it go when it&#8217;s finished.  I get this.  It&#8217;s all for performance.  My initial reaction was: wouldn&#8217;t be nice if Apache was threaded so requests can all share the same PHP code.  That&#8217;s when I was introduced to the <a href="http://httpd.apache.org/docs/2.2/mod/worker.html">worker MPM</a>.  It serves requests from threads so it&#8217;s efficient, but also has a couple of children for fault tolerance.  This is easy to switch to in OpenSolaris:</p>
<pre class="terminal"># <kbd>svcadm disable http</kbd>
# <kbd>svccfg -s http:apache22 setprop httpd/server_type=worker</kbd>
# <kbd>svcadm refresh http</kbd>
# <kbd>svcadm enable http</kbd></pre>
<p>I also copied <tt>/etc/apache2/2.2/samples-conf.d/mpm.conf</tt> into <tt>/etc/apache2/2.2/conf.d/</tt> which includes some sane defaults like only spawning two servers to start with.  This was good:</p>
<pre class="terminal">$ <kbd>prstat -s rss -Z 1 1 | cat</kbd>
...
ZONEID    NPROC  SWAP   RSS MEMORY      TIME  CPU ZONE
    39       50  125M   75M    29% 244:46:23 0.3% case</pre>
<p>75M makes me feel safe, like I could take the occasional spam bomb.  What I forgot to mention is that mod_php <a href="http://www.php.net/manual/en/faq.installation.php#faq.installation.apache2">isn&#8217;t supported</a> with the worker MPM since any of its extensions might not be thread-safe.  This is okay, because PHP can be run as a CGI program which has the additional benefit of being memory efficient (at the cost of speed) since it&#8217;s only loaded when it&#8217;s executed.  All I had to do was create a file <tt>/etc/apache2/2.2/conf.d/php-cgi.conf</tt> containing:</p>
<div class="codecolorer-container apache default" style="overflow:auto;white-space:nowrap;border:1px solid #9F9F9F;width:435px;"><div class="apache codecolorer" style="padding:5px;font:normal 12px/1.4em Monaco, Lucida Console, monospace;white-space:nowrap">&lt;<span style="color: #000000; font-weight:bold;">IfModule</span> worker.c&gt;<br />
&nbsp; &nbsp; <span style="color: #00007f;">ScriptAlias</span> /php-cgi /usr/php/bin/php-cgi<br />
<br />
&nbsp; &nbsp; &lt;<span style="color: #000000; font-weight:bold;">Location</span> <span style="color: #7f007f;">&quot;/php-cgi&quot;</span>&gt;<br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #00007f;">Order</span> <span style="color: #00007f;">allow</span>,<span style="color: #00007f;">deny</span><br />
&nbsp; &nbsp; &nbsp; &nbsp; <span style="color: #00007f;">Allow</span> from <span style="color: #0000ff;">all</span><br />
&nbsp; &nbsp; &lt;/<span style="color: #000000; font-weight:bold;">Location</span>&gt;<br />
&nbsp; &nbsp;<br />
&nbsp; &nbsp; <span style="color: #00007f;">Action</span> php-cgi /php-cgi<br />
&nbsp; &nbsp; <span style="color: #00007f;">AddHandler</span> php-cgi .php<br />
&nbsp; &nbsp; <span style="color: #00007f;">DirectoryIndex</span> index.php<br />
&lt;/<span style="color: #000000; font-weight:bold;">IfModule</span>&gt;</div></div>
<p>I&#8217;ll be the first to admit, running Trac and WordPress as CGI have made them noticeably slower, but I&#8217;d rather them run slower for as much action that they get and know that my mail will get to me.  If you&#8217;re faced with similar resource constraints, you may want to consider these changes.  There may be other ways I can tweak Apache, such as unloading unused modules, but I&#8217;m not ready to face that yet.</p>
]]></content:encoded>
			<wfw:commentRss>http://thestaticvoid.com/post/2009/07/27/reducing-memory-footprint-of-apache-services/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

