Sunday, February 20, 2011

Enabling WOL for ubuntu

Once you have the BIOS setup for to receive Wake On Lan/Magic packet you then need to tell Ubuntu to keep the Ethernet controller alive on a halt. Otherwise the magic packet is going to be ignored. To do this

sudo apt-get install ethtool

Now execute the command to set the wake on lan mode to on "g". You may need to tweak the eth0 piece to match the correct Ethernet interface.
sudo ethtool -s eth0 wol g

And confirm the setting with:
sudo ethtool eth0

At this point you can halt the machine and wake it but.. the setting is only temporary so you need to install a boot script in the server to make it permanent. Nothing is worst than shutting down the server while you are remote only to have it never come back on the next activation.
sudo vi /etc/init.d/wakeonlan

Now add the text.
#!/bin/sh
ethtool -s eth0 wol g
exit

Set execute permissions on the script:
sudo chmod a+x /etc/init.d/wakeonlan

Now at this point is is best to confirm the script actually works, unless you like making problems to fix.. So run it. And then install the script for startup:
update-rc.d -f /etc/init.d/wakeonlan defaults

Confirm output the install worked without errors.

Now your right to go. Dont forgot to get the MAC address from an ifconfig and then shutdown with:
sudo halt

Then simply send the magic packet(crafted from the Mac addres) to you local intranets broadcast address and the machine should wake up. If you want it to work from remote, map a random port or your NAT that will recast it to the local broadcast address and your done.

If it doesn't work then there are a range of problem items to check:
  • Confirm bios wake in LAN is on
  • Confirm for older bios's wake signal from pci is on
  • Confirm that the router led is indicating that the wire is connected and the link powered.
  • Confirm the router firewall isnt filtering the wake on LAN, often ports 7 or 9.
  • Confirm the wake on LAN tool is not a BS tool that doesn't work. There are a surprising number of them for how simple the magic packet is. For windows try Wolcmd.exe, ubuntu: wakeonlan, and the dd-wrt routers wol service also works nicely.
  • Confirm that the machine wasn't hard powered off. this tends to kill the sleeping ethernet controller and prevent the wakeup after that point.
Refer: http://ubuntuforums.org/showthread.php?t=234588 http://wiki.xbmc.org/index.php?title=HOW-TO_set_up_Wake-On-Lan_%28Ubuntu%29#The_init.d_script

Thursday, February 17, 2011

Perl generic data structure dumper

Here is a quick function to dump the contents of a generic mass of variables. I use it to debug the mass of random data structures that appear in random perl scripts

sub rec_print
{
    my ($message, $lead) = @_;
    
    if (ref($message) eq 'ARRAY') 
    { 
       # print  ":\n";        
        rec_print($_, $lead . " ")  foreach (@$message);
    }
    elsif (ref($message) eq 'HASH') 
    {
        foreach my $k (keys %$message)
        {
            print  "$lead$k:\n";
            rec_print($message->{$k}, $lead . " ");
        }
    }
    else
    {
        print "$lead$message\n";
    }
}

#example
rec_print({a=>"abc", b=>"bcd"},"");

Wednesday, February 16, 2011

boost, in vista using mingw and cmd.exe

Gezz.. what a pain... Getting boost to build in mingw is a bit of a mess. The docs dont "officially" cover it, but it does work once you patch together all the various missing pieces. Here is how:

Mingw version: 4.5
Boost Version: 1.45
OS: Vista.

First Download the tar.bz version from http://sourceforge.net/projects/boost/files/boost/1.45.0/.
Dont download the build version of bjam it wont work. You need to build it.

Build bjam:
Refer: http://boost.org/doc/libs/1_45_0/doc/html/jam/building.html

Note that I use the directory c:\tools as my install area for all programs that need to avoid the windows UAE etc idiocy.. Transfer the unziped/untared files into the desired location and then build the bjam.exe

In cmd.exe execute:
cd C:\tools\boost_1_45_0\tools\build\v2\engine\src
build.bat mingw
Once built copy C:\tools\boost_1_45_0\tools\build\v2\engine\src\bin.ntx86\bjam.exe into C:\tools\MinGW\bin (makes it easy later, since you likely have it in your %PATH% var already.)

Build the boost libs In cmd.exe execute:
bjam toolset=gcc --build-type=complete stage
Refer: http://www.boost.org/doc/libs/1_45_0/more/getting_started/windows.html#or-build-from-the-command-prompt

Wait copious amounts of time... There seems to be ALOT of warnings simply ignore them they are "harmless"

You can build boost test programs(in cmd or msys) with:
g++ -I"c:\tools\boost_1_45_0" -L"c:\tools\boost_1_45_0\stage\lib" -static boost_lamba_test.cpp -o a.exe
g++ -I"c:\tools\boost_1_45_0" -L"c:\tools\boost_1_45_0\stage\lib" -static boost_regex_test.cpp -lboost_regex-mgw45-1_45 -o b.exe

Lamba test: http://www.boost.org/doc/libs/1_45_0/more/getting_started/windows.html#build-a-simple-program-using-boost
Regex test: http://www.boost.org/doc/libs/1_45_0/more/getting_started/windows.html#link-your-program-to-a-boost-library

Keep in mind the order of the source and libs files is important in mingw
http://www.mingw.org/wiki/Specify_the_libraries_for_the_linker_to_use

Sunday, February 13, 2011

remote server shutdown.

In 2009 I wrote about passwordless shutdown of a ubuntu. At that time my object was remote shutdown and boot up of the server ie from an iphone or zaurus running an ultra-lite web server.

The resulting system would send the magic packet to wakeup the main server, zip the days data, scp the data to the main server and then ssh to the shutdown down user(causing the machine to halt). Now that I have an old iphone 3g I was seriously considering porting my ultra light server to it.

Anyway some how I got off track...again... My ubuntu server didnt cleanly upgrade to 10.10 so am I rebuilding it from scratch. Here is how to setup the auto shutdown user:

First add the shutdown user:
sudo adduser --home /home/shutdown shutdown

Or add the existing user to the shutdown group. (or combo of both)
sudo usermod -a -G shutdown username

Grant him ssh rights with:
sudo vi /etc/ssh/sshd_config

Add the line:
AllowUsers shutdown

And setup his ssh key:
sudo su -l shutdown
mkdir 
chmod 700 .ssh/
touch .ssh/authorized_keys 
chmod 600 .ssh/authorized_keys 
vi .ssh/authorized_keys 

And add the line(with your ssh key and note the forced command "/sbin/halt"):
command="/sbin/halt",no-port-forwarding,no-X11-forwarding,no-agent-forwarding,no-pty ssh-rsa .... ==

Now by default halt cant be run without sudoing so to fix that edit the sudoers file
sudo visudo
UPDATE: You can can now add an extension file to the sudoers.d directory and not have to modifiy /etc/sudoers directly this way it doesnt break on every system upgrade..
sudo vi /etc/sudoers.d/passwordless_shutdown

Add the lines to grant rights to shutdown(and no one else) for the halt command
%shutdown ALL=NOPASSWD: /sbin/shutdown
%shutdown ALL=NOPASSWD: /sbin/halt

Then halt can be run as (an no password will be required)
sudo halt

If this still isnt sufficient (and it isnt for some scripting applications) The "sudo" part of the command can be removed by chmoding the command halt so that its runnable outside of a root user.
sudo chmod +s /sbin/reboot

Of course this basically allows any user on the system shutdown rights. so be careful with the chmod way.

Git setup in ubuntu 10.10

Here is a quick run down of the commands to setup git in ubuntu server edition 10.10
I user remote logins alot so i dont want the git keys to be the same as the remote login users.. This way the git user can only mess with the repos and cant sudo to anything.

The simplest way to setup a private and secure git repo is to use ssh, avoid packages like gitosis et al, as they complicate the system setup needlessly.

Start of with installing git.
sudo apt-get -y install git-core

Setup a git user with(without sudoer rights);
sudo useradd --home /home/git --shell /bin/sh git
sudo su -l git
mkdir ~/.ssh
chmod 700 ~/.ssh
mkdir ~/repos

Now to setup a repo do the following:
sudo su -l git
cd ~/repos
git init --bare testing.git

Now your remote repo url (and username) is;
ssh://git@server.ip.address/~/repos/testing.git

But it can be checked out locally with:
git clone ~git/repos/testing.git

Check out the local version and confirm it.

For the remote a client is needed. TortoiseSVN was big favorite of mine. So im going for TortoiseGIT as my client. To setup it up you need to install Msysgit then tortiseGIT.
http://code.google.com/p/msysgit/downloads/list
http://code.google.com/p/tortoisegit/downloads/list

When I tried to check out my repo the clone failed on me due to the "PermitRootLogin no" and "PasswordAuthentication no" settings in my sshd_config fix it with
sudo su -l gitadmin
sudo vi /etc/ssh/sshd_config

And add the user "git" to you AllowUsers line and install
AllowUsers git

Setup the remote users ssh key with PuttyGen and then add your ssh users pub key to the git user so that the client can login and pull/push the repo
sudo vi ~git/.ssh/authorized_keys

And then restart ssh and confirm the download of the admin settings:
sudo /etc/init.d/ssh restart

Refer:
http://book.git-scm.com