Here's a nice feature-to-feature comparison and quick start of major Enterprise OS. IBM Aix, HPUX and Sun Solaris are covered.
It's worth noting that only Sun Solaris is currently fully supported in x86 environment and AIX lacks any type of support for architectures different from POWER.
The article comes from IBM so maybe is a bit biased.
2009/05/29
2009/05/20
Get a list of most populated tables in mysql
If you are a sysadmin and do not have a fellow mysql dba, you should learn some tricks to look for big tables or tables used very much.
This query (and modified versions of it) accomplishes the task:
mysql> SELECT table_name, table_schema, engine, table_rows, data_length FROM information_schema.tables where table_schema not in ('information_schema', 'mysql') order by table_rows desc limit 20;
This searches for every table which is not part of 'information_schema' and 'mysql' (that is every user database).
The result is similar to this one (names and schemas removed to protect the innocents ;))
This query (and modified versions of it) accomplishes the task:
mysql> SELECT table_name, table_schema, engine, table_rows, data_length FROM information_schema.tables where table_schema not in ('information_schema', 'mysql') order by table_rows desc limit 20;
This searches for every table which is not part of 'information_schema' and 'mysql' (that is every user database).
The result is similar to this one (names and schemas removed to protect the innocents ;))
+-----------------------+--------------+--------+------------+-------------+
| table_name | table_schema | engine | table_rows | data_length |
+-----------------------+--------------+--------+------------+-------------+
| | | MyISAM | 2828398 | 162470312 |
| | | MyISAM | 1609232 | 131429376 |
| | | MyISAM | 1195717 | 218651496 |
| | | InnoDB | 574491 | 43581440 |
| | | MyISAM | 565128 | 10737432 |
| | | MyISAM | 480290 | 26981100 |
| | | MyISAM | 380521 | 22509908 |
| | | MyISAM | 280128 | 8536752 |
| | | MyISAM | 227324 | 18714388 |
| | | MyISAM | 210842 | 17857596 |
| | | InnoDB | 201526 | 45694976 |
| | | MyISAM | 177225 | 10055608 |
| | | InnoDB | 123960 | 5783552 |
| | | MyISAM | 119143 | 9524852 |
| | | MyISAM | 99960 | 10038104 |
| | | MyISAM | 97712 | 8010128 |
| | | InnoDB | 94167 | 8404992 |
| | | MyISAM | 93962 | 16401252 |
| | | MyISAM | 91817 | 1836340 |
| | | InnoDB | 84424 | 4734976 |
+-----------------------+--------------+--------+------------+-------------+
20 rows in set (0.18 sec)
2009/05/19
Multipath and partitions on linux
If you have a multipath device, you can partition it. This can have many purposes, typically to use some space differently if you have a cluster and only a LUN to use as quorum disk and for data.
Sometimes, you partition the multipath device with fdisk, but the device is "in use" by the kernel and partition devices (mpathXp1, mpathXp2 and so on) don't get created.
Simply use kpartx to create those devices in "userspace":
root# kpartx -a /dev/mpath/mpath0
If you are not sure, leave the -a to preview the results.
Sometimes, you partition the multipath device with fdisk, but the device is "in use" by the kernel and partition devices (mpathXp1, mpathXp2 and so on) don't get created.
Simply use kpartx to create those devices in "userspace":
root# kpartx -a /dev/mpath/mpath0
If you are not sure, leave the -a to preview the results.
Unison on Windows
Since we are moving from one place to another (still in Rome), i needed to sinchronyze files between my current linux workstation and the notebook I was given. For me, the obvious tool is unison, and I went looking for instructions to make it work on windows, as on the notebook it's installed a windows-only VPN software.
The process turned to be fairly complex, as usual due to dll/path hell which is the doom of windows machines when dealing with a no-installer software.
1. Getting Unison and prerequisites.
The unison Homepage points here: , where I downloaded the gtk-enabled windows executable.
Unison needs the gtk library, the page suggests using those provided by Pidgin. I already had Pidgin installed, so I did nothing.
2. Putting Unison where it would find gtk dll
The page also advise to append the gtk library directory to the %PATH% variable. I opted instead to move the Unison-2.27.57 Gtk+.exe executable in the GTK directory ("C:\Programmi\File comuni\GTK\2.0\bin" in my system). This is more straightforward and easier to do and lets me have more than one GTK installation if need arises. Note that you cannot register the dll to be automatically found (I don't know why, but a dialog tells me so when I use regsvr32 on libgtk-win32-2.0-0.dll.
3. Getting ssh.exe plink wrapper
From this page [http://www.wischik.com/lu/programmer/unison-ssh.html] I downloaded the plink wrapper (I googled for unison windows ssh and it was the first hit). I put in the same folder that the unison executable. It has a bug and it does not work with a plain password (I planned to use a private key anyway)
4. Generating private key to use with plink
It's easy, use puttygen (you should have it if you installed putty with the standard windows installer, otherwise grab it here). Note that the Putty links points to the most current version of Putty, but it may change, so peek at the download page for updates.
As usual, generate a new key (I prefer to generate a fresh key for automated task, it's easier to revoke if it gets compromised as it does not have usually a passphrase) and publish the public key on the linux box which will act as a "unison server" in the authorized_keys file (usually ~/.ssh/authorized_keys, change the permissions to rw------- before doing anything else if you create a new file)
5. Configuring the key in the unison profile
Using the ssh plink wrapper, you need to modify the unison profile file. Create a new profile, select the local directory to configure, select the remote directory (using ssh), insert the host and the user that you granted access by publishing the public key.
Then locate the profile file (in C:\Documents and Settings\ \.unison on my windows system) and add these lines:
sshcmd=ssh.exe
sshargs=-i path\to\privatekey_file_on_windows.ppk
ignorecase=true
you can add also perms=0 since most of the times the permissions will be totally screwed from a unix fs to ntfs (god forbids using FAT32 nowadays!)
Note: the path you specify with the sshargs option must not contain spaces.
6. Run and test
Now run Unison and verify that it detects differences in the files and that it makes good suggestions on which file is newer on which system.
Troubleshooting
The only thing you can do wrong is the public key stuff, check with cmd, cd to the directory where you have copied ssh.exe and try ssh manually:
C:\somedir> ssh -l username -i path\to\privatekey_file_on_windows.ppk hostname
and see if you can login.
Otherwise you screwed something up; check the authorized_keys name, permissions and position on the filesystem (and if it contains the right public key).
The process turned to be fairly complex, as usual due to dll/path hell which is the doom of windows machines when dealing with a no-installer software.
1. Getting Unison and prerequisites.
The unison Homepage points here: , where I downloaded the gtk-enabled windows executable.
Unison needs the gtk library, the page suggests using those provided by Pidgin. I already had Pidgin installed, so I did nothing.
2. Putting Unison where it would find gtk dll
The page also advise to append the gtk library directory to the %PATH% variable. I opted instead to move the Unison-2.27.57 Gtk+.exe executable in the GTK directory ("C:\Programmi\File comuni\GTK\2.0\bin" in my system). This is more straightforward and easier to do and lets me have more than one GTK installation if need arises. Note that you cannot register the dll to be automatically found (I don't know why, but a dialog tells me so when I use regsvr32 on libgtk-win32-2.0-0.dll.
3. Getting ssh.exe plink wrapper
From this page [http://www.wischik.com/lu/programmer/unison-ssh.html] I downloaded the plink wrapper (I googled for unison windows ssh and it was the first hit). I put in the same folder that the unison executable. It has a bug and it does not work with a plain password (I planned to use a private key anyway)
4. Generating private key to use with plink
It's easy, use puttygen (you should have it if you installed putty with the standard windows installer, otherwise grab it here). Note that the Putty links points to the most current version of Putty, but it may change, so peek at the download page for updates.
As usual, generate a new key (I prefer to generate a fresh key for automated task, it's easier to revoke if it gets compromised as it does not have usually a passphrase) and publish the public key on the linux box which will act as a "unison server" in the authorized_keys file (usually ~/.ssh/authorized_keys, change the permissions to rw------- before doing anything else if you create a new file)
5. Configuring the key in the unison profile
Using the ssh plink wrapper, you need to modify the unison profile file. Create a new profile, select the local directory to configure, select the remote directory (using ssh), insert the host and the user that you granted access by publishing the public key.
Then locate the profile file (in C:\Documents and Settings\
sshcmd=ssh.exe
sshargs=-i path\to\privatekey_file_on_windows.ppk
ignorecase=true
you can add also perms=0 since most of the times the permissions will be totally screwed from a unix fs to ntfs (god forbids using FAT32 nowadays!)
Note: the path you specify with the sshargs option must not contain spaces.
6. Run and test
Now run Unison and verify that it detects differences in the files and that it makes good suggestions on which file is newer on which system.
Troubleshooting
The only thing you can do wrong is the public key stuff, check with cmd, cd to the directory where you have copied ssh.exe and try ssh manually:
C:\somedir> ssh -l username -i path\to\privatekey_file_on_windows.ppk hostname
and see if you can login.
Otherwise you screwed something up; check the authorized_keys name, permissions and position on the filesystem (and if it contains the right public key).
2009/05/04
Updated Mandriva 2009 to spring
The update did complete successfully, but only after manual intervention.
The update process looped on trying to install mplayer (mandriva version) while it conflicted with mplayer plf version. I had to remove the mplayer plf rpm manually from the console before the script went on.
When the notebook rebooted for the new kernel, X did not start; but mandriva offered a text mode dialog to reconfigure (and test) it.
I still have to see a linux distro upgrade flawlessly; but this time mandriva quite did it, if I did not tinker with plf, everything should go on in an acceptable way.
So the vote on the update process is 7/10.
The update process looped on trying to install mplayer (mandriva version) while it conflicted with mplayer plf version. I had to remove the mplayer plf rpm manually from the console before the script went on.
When the notebook rebooted for the new kernel, X did not start; but mandriva offered a text mode dialog to reconfigure (and test) it.
I still have to see a linux distro upgrade flawlessly; but this time mandriva quite did it, if I did not tinker with plf, everything should go on in an acceptable way.
So the vote on the update process is 7/10.
2009/05/03
Upgrading Mandriva 2009 to spring
Tonight I started the automatic (i.e. graphical) upgrade of my notebook to mandriva 2009.1 (a.k.a 2009 Spring)...
More info to follow after upgrade.
More info to follow after upgrade.
Subscribe to:
Posts (Atom)