Deletes shortest match of $substring from back of $string.
${string%”$substring”} Example
find /var/files -name "*.mp3" | while read string; do mv$ $string ${string%"mp3"}wav done Will strip mp3 of the end of the string and add wav
Hardware interrupts were introduced as a way to avoid wasting the processor’s valuable time in polling loops, waiting for external events. They may be implemented in hardware as a distinct system with control lines, or they may be integrated into the memory subsystem.Read More
[root@dfs2 ~]# cat /proc/interrupts CPU0 CPU1 <items removed> 30: 1543015844 70 IO-APIC-level eth0 33: 982 1125222804 IO-APIC-level eth1 NMI: 0 0 LOC: 312789123 312790125 ERR: 0 MIS: 0 As you can see from the list above the interrupts for the network card has been balanced betwen the Cores.
How many times have you run a command and then thought, ooo crap i now need to leave work, i really should have nohupped it or run it in screen session well welcome to.
disown \[-ar\] \[-h\] [jobspec ...] Without options, each jobspec is removed from the table of active jobs. If the -h option is given, each jobspec is not removed from the table, but is marked so that SIGHUP is not sent to the job if the shell receives a SIGHUP.
I was asked to today if it was possible to add latency and packet loss to a device in order to replicated network problems. After a while googleing i found tc +netem. This allows you do funcy stuff to replicated network problems. If i wanted to add 100ms of latency i could do tc qdisc add dev eth0 root netem delay 100ms
You can also add variation tc qdisc change dev eth0 root netem delay 100ms 10ms
If you need to run the same commands on multiple computers, then maybe you should be thinking about using puppet but if you only need to do a one time thing then there is clusters ssh aka cssh.
After a
apt-get install clusterssh You can then start using it by simple typing
cssh server01 server02 etc etc Another way to do it is include this in you .csshrc file
extra_cluster_file=~/.clusters Then in you ~.
One of my work mates was trying to find the util that allows you to do “pings” to a http server. I knew about it but couldn’t remember the url thusly one has placed it on the block so i dont have to remember it httping.
apt-get install httping On running the command you get the following output
sjohnson@x:~$ httping -g http://google.com - Using proxyserver: nokes.nokia.com:8080 PING google.com:80 (http://google.com): connected to google.
After some googling i have worked out how to add keys to a luks,
First we need to generate a key dd if=/dev/urandom of=keyfile bs=1M count=10
We can then add it to luks cryptsetup luksAddKey /dev/device keyfile
Once this is done we can then unlock the device with a key cryptsetup luksOpen /dev/sdb1 external -d keyfileexternal
A device mapper will be added to /dev/mapper/external
We can then lock the device again with a cryptsetup luksClose external
How to tie into dbus to get alerts on had drive device insertion also generates pretty notifications.
Its the first set in making the code decrypt a usb device on insertion run a rdiff backup and then eject the device.
Step two is to work out how to generate a key file for a pass phrase with luks.
import pynotify import dbus import gobject from dbus.mainloop.glib import DBusGMainLoop import time class DeviceFinder ( ): def run ( self ): pynotify.