I just installed a new server from HP, a ProLiant DL180 G6. Here are some notes about the setup.
To check the hardware status you need to install the ProLiant Support Package. Running a Debian/Ubuntu you should import the HP PSP mirror in your
sources.list . It can be found here, you might include something like:
aptitude update you’ll find some new packages. I recommend to install
hpaclui to speak to your raid-controllers and
hp-health to interact with your hardware.
hpaclui you can ask the raid-controllers for some information:
So you get an idea of your storage.
hp-health packages comes with a tool called
hpasmcli . It’s used to query all the hardware states:
Both tools are very easy to use and give a great overview about the health. So I immediately developed a monitoring plugin that parses the output of those runs. I came to the point, that I wasn’t able to find some documentation about the
hpasmcli tool. Most of its output was clear, but I don’t know what happens if a fan breaks. The output with working fans looks like:
So what if a fan is broken? Is it still
Present and the
Speed -string just changes to
NONE or something like that? I send a support request to HP, but all they respond was a premium-rate number to call. Seems that my understanding of service differs from theirs. Since I don’t know how the output looks like in an error case (I don’t want to stick pencils into new machines) the plugin can’t decide whether the fans are OK. If you want to use my plugin you need to skip fan-checks until HP publishes a document with possible values.
IMHO a public tool should be open source, so I can get those information on my own, or at least well documented!
Btw. HP if you read this, please include some permanent links to your web interface ;-)
Today a lot of great mails arrived at my inbox. In one of them I was reading I’ve just added your feed to the site.
Where did this mail come from?
The sender of the email was Tal Galili. He is a researcher in BioStatistics at the Tel Aviv University, very active around the internet. He also originated R-Bloggers and in this email he told me that I’m recruited ;-)
What is R-Bloggers
R-Bloggers is an aggregation of more than 200 bloggers writing about GNU’s R and some statistics/math/hacks that can be done using R. If you didn’t heard about R-Bloggers I strongly recommend to take a look at their website. I’m following this project since a while, it’s a great fusion of brainiacs! So I’m proud to have my modest R-related articles listed between them.
Btw. if you like R-Bloggers and/or have some R experiences yet you should also take a look at the ‘R’ programming Wikibook. Contributing your knowledge is greatly appreciated!
Let’s see what the future brings, happy hacking!
…sts (of course!). Yesterday I just installed a rating plugin, inspired by these stackexchange platforms.
Searching through the WordPress plugin directory didn’t make me happy. All existing plugins lack of desired features. After some tests I decided to modify UpDownUpDown of Dave Konopka. It’s a nice plugin, but still didn’t match my criteria. For example guests were not allowed to vote, there were some XHTML bugs and I didn’t like the style. So I created a patch (it’s attached..) and sent it to Dave (I don’t yet have a github account). He told me that he’ll take a look at it and might apply it to the official plugin, so if you also want to use this rating plugin with my additional features just keep the URL in mind and watch out for a new version.
The special version I’m using here right now has of course some more slight changes, to have it perfectly matched to my own blog. So you are now able to vote for articles, positive or negative, to give me a hint what my visitors like to read ;-)
I additionally installed a further page that lists my articles sorted by votes: top. So you can get a smart overview of best/worst content.
With this in mind: Happy voting! ;-)
Ever worried about these disgusting packets leaving your network interface!? Why not creating your own packets?
Of course it’s more than nonsense creating all packets on your own, but sometimes there might be a reason making you wish you could..
For ex. for my last article I searched for a possibility to modify some contents of a packet. First I thought about using
iptables , but than I found a nice tool: scapy!
To open the interface just run
scapy . You can easily create an IP packet by typing something like this:
So an IP packet is stored in the variable
ippacket . This packet will be send to
binfalse.de and has a
12 (if there are more than 12 network nodes between your machine and the target it will disappear and never arrive at the target).
Let’s create some TCP stuff:
We stored some TCP information in
tcpcrap . This packet will be send through your port
1337 and hopefully arrive at port
80 (in general a webserver is listening on port
That’s it for the networking part. Last but not least we will create some data to send:
Combining all parts we’ll get a very nice packet, sending it will trigger my webserver to send the main page of my website (Sending exactly this packet won’t ever result in any website from my webserver. Why? Just think about…):
Well done! Ok, that’s very much to do. But fortunately it’s just that much code for explanation, you can send the same packet in a single line:
Very smart, isn’t it? You can also sniff whooshing packets! But something like this I won’t explain, find out by yourself ;-)
I often here people saying something like
SSH to your home PC? Sitting behind a NAT? A snowball's chance in hell...
But is it really impossible?
What is a NAT?
NAT (network address translation) is a technique to cover multiple clients behind one router. Kristian Köhntopp explained the technology very well in his article NAT ist kein Sicherheitsfeature (GER). But let me summarize some things. Here is a small image to visualize the topology of an example network:
You see, the NAT represents something like a bridge between it’s clients (in network
10.0.0.0/24 ) and the rest of the world. The connections of the clients are translated by this router.
10.0.0.3 wants to speak to my webserver
22.214.171.124 , he sends a packet containing, among others, the following information:
So all machines on the way from
126.96.36.199 know whom to send the packet next. When this packet arrives at the NAT, the NAT will rewrite it. The NAT stores a table for all recent connections. Each entry consists of a client IP, client port and a local port on its public interface. For our example the table entry for this example might look like:
|Source IP||Source Port||NAT IP||NAT Port|
The resulting port on the NAT is arbitary, it’s just one free port.. Each packet arriving on port
1234 of the public interface of the NAT is forwarded to
10.0.0.3:39478 . Our rewritten packet
10.0.0.3->188.8.131.52 now contains the following informations:
and is send to the next node in the world wide web. Nobody out of
10.0.0.0/24 will ever know that there is a machine
10.0.0.3 requesting a website from
184.108.40.206 . The webserver on
220.127.116.11 will send it’s answer to the pretended source,
18.104.22.168:1234 , and the NAT will forward the traffic according to its table entry to
Why do NAT’s exists? The solely plausible reason seem to be the lack of IPv4 addresses. With a NAT an ISP just need to offer a single IP address for a huge bunch of clients. Hopefully this will change in times of IPv6!
Why does it seem to be impossible?
Since the private network
10.0.0.0/24 is not known by the outer world (it is simply not route-able in the Internet, see wikipedia), you cannot connect from outside
10.0.0.0/24 straight to
10.0.0.3 . The WWW will only see
22.214.171.124 as source for all the clients. That means all clients in
10.0.0.0/24 have the same public IP for each machine that is not in
10.0.0.0/24 . So how to access
10.0.0.3 ? Speaking to
126.96.36.199 will result in crap, you don’t know which port will be forwarded to whom!? If it is forwarded at all…
How is it nevertheless possible?
…is not very nice, if you are looking for a real solution please skip this paragraph and continue with solutions two and three ;-)
Since there is no entry in the NAT table that specifies an outside target, you can send packets from any location to
188.8.131.52:1234 and the NAT will forward them to
10.0.0.3:39478 (according to my example). So to create a path from outside to
10.0.0.3 ‘s SSH server you just need to send a packet from
10.0.0.3:22 to any server outside that informs you about the source IP and source port that was reported by the NAT (it’s the address that will be forwarded to the client). If you immediately connect to this address, and if a SSH server is listening on
10.0.0.3:22 , you should be able to establish a SSH session. Simple isn’t it ;-)
To get this working you could try something like repeating the following commands frequently:
Of course you can also install some
iptables rules to rewrite the TCP packets. So you can send the packets from some other ports than
iptables will rewrite them so the target machine (and the NAT) thinks they came from
:22 . With this setup you don’t have to stop SSH, because you don’t need the free port… But just hack it your way ;-)
…is much more comfortable. You can set up a reverse SSH tunnel! Again you need another machine outside the NAT, that has a SSH server running and will act as your gateway. Just connect to it from your local machine behind the NAT:
That will open the port
your.server . All packets arriving at this port are transferred through the SSH tunnel to your home PC. Run something like screen or top on the server to always transfer packets (otherwise the connection will be closed after some time), with
-o ServerAliveInterval=XXX you can adjust the threshold for closing the SSH connection. Surround it with a
while loop and you’ll reestablish closed connections (network errors or something like that):
By default the opened port is just bound to
127.0.0.1 (the servers loopback interface), so you can only send packets from the server itself (or need some more network hacking). To have this hack listening to
0.0.0.0 (all interfaces) add the following to your
and restart the daemon.
…might be the most elegant. Set up a VPN! But that’s too much for now, request some explanations from 3dfxatwork, he’s your OpenVPN guy!, and take a look at Dirty NAT tricks to get a VPN to work with clients also numbered in the private address space
So you see, no hasty prejudices ;-)