iostat -xkd 1
Pretty useful.
iostat -xkd 1
Pretty useful.
A customer was getting a bad error: : Block Device Mapping is Invalid.
It was because the cbs wasn’t building in time from the image , and the build was timing out. So the solution was pretty simple. Add the CBS first:
supernova customer volume-create 55 --volume-type=SSD --display-name=starating --image-id=5674345-dfgegdf-34553531123
Oh, thanks Aaron dude. You rock.
Hey. So if only I had a cake for every customer that asked if we could delete all of their cloud files in a single container for them (i’d be really really really fat so maybe that is a bad idea). A dollar though, now there’s a thought.
On that note, here is a dollar. Probably the best dollar you’ll see today. You could probably do this with php, bash or swiftly, but doing it *THIS* way is also awesome, and I learnt (although some might say learned) something. Here is how I did it. I should also importantly thank Matt Dorn for his contributions to this article. Without him this wouldn’t exist.
Step 1. Install Python, pip
yum install python pip apt-get install python pip
Step 2. Install Pyrax (rackspace Python Openstack Library)
pip install pyrax
Step 3. Install Libevent
curl -L -O https://github.com/downloads/libevent/libevent/libevent-2.0.21-stable.tar.gz tar xzf libevent-2.0.21-stable.tar.gz cd libevent-2.0.21-stable ./configure --prefix="$VIRTUAL_ENV" make && make install cd $VIRTUAL_ENV/..
Step 4. Install Greenlet and Gevent
pip install greenlet pip install gevent
Step 5. Check gevent library loading in Python Shell
python import gevent
If nothing comes back, the gevent lib works OK.
Step 6. Create the code to delete all the files
#!/usr/bin/python # -*- coding: utf-8 -*- from gevent import monkey from gevent.pool import Pool from gevent import Timeout monkey.patch_all() import pyrax if __name__ == '__main__': pool = Pool(100) pyrax.set_setting('identity_type', 'rackspace') pyrax.set_setting('verify_ssl', False) # Rackspace Credentials Go here, Region LON, username: mycloudusername apikey: myrackspaceapikey. pyrax.set_setting('region', 'LON') pyrax.set_credentials('mycloudusername', 'myrackspaceapikey') cf = pyrax.cloudfiles # Remember to set the container correctly (which container to delete all files within?) container = cf.get_container('testing') objects = container.get_objects(full_listing=True) def delete_object(obj): # added timeout of 5 seconds just in case with Timeout(5, False): try: obj.delete() except: pass for obj in objects: pool.spawn(delete_object, obj) pool.join()
It’s well worth noting that this can also be used to list all of the objects as well, but that is something for later…
Step 7. Execute (not me the script!)
The timeout can be adjusted. And the script can be run several times to ensure any missed files are retried to be deleted.
https://developer.rackspace.com/blog/custom-images-via-boot-dot-rackspace-dot-com-training-wheels-included/
What it says on the tin
So, today we had a customer that was using a custom VHD/VDI with his server and it wasn’t working. I knew it would be one of the 3 things:
1) incorrect vm_mode flag
2) Image size too big for flavors ‘min disk’
3) image using journaling
As it turned out this customer was using journaling. However, if it was a PV HVM type, here is how I would correctly set the mode
supernova customer image-meta vfd09a81-g431-4279-9467-5e4284944b53 set vm_mode=hvm
Pretty simple fix.
for id in $(cat list.txt); do supernova lon show $id | awk '/accessIPv4/ {print $4}'; done >> iplist.txt
It’s a pretty simple hack. thanks to Jan for this.
Of course you need to extract the machine id’s to run the above statement. Here is how I did that:
nova list --tenant 10010101 > list.txt
Pretty cool. And yeah I know, I put step 1 after step 2, but you get the idea !
Linux
ping www.google.com | while read pong; do echo "$(date): $pong"; done
Windows
@echo off :loop ping -n 1 %1 >nul || echo %date% %time% no reply from %1 >> pinglog.txt choice /N /T 1 /D Y >nul goto loop
My Colleague at work asked me to create a bootable CD of XenServer 6.2. So I thought I’d quickly throw together a tutorial on how to do this.
Step 1. Download the ISO from Xen website http://xenserver.org/open-source-virtualization-download.html
In my case I’m using the 6.2 version release. but this process is good for burning any bootable ISO
wget http://downloadns.citrix.com.edgesuite.net/8159/XenServer-6.2.0-install-cd.iso
Step 2. Convert from iso to a dmg/img
hdiutil convert -format UDRW -o xenserver6.2.img XenServer-6.2.0-install-cd.iso
Step 3. Locate USB device in my case it was /dev/disk2. My colleague was using xen 6.5 previously.
diskutil list $ diskutil list /dev/disk1 #: TYPE NAME SIZE IDENTIFIER 0: GUID_partition_scheme *14.4 MB disk1 1: Apple_HFS MenuMeters 1.8.1 14.4 MB disk1s1 /dev/disk2 #: TYPE NAME SIZE IDENTIFIER 0: XenServer-6.5.0 *62.0 GB disk2
Step 4. unmount the USB disk
diskutil unmountDisk /dev/disk2
Step 5. Create the USB image
sudo dd if=xenserver6.2.img.dmg of=/dev/disk2 bs=1m 563+1 records in 563+1 records out 590448640 bytes transferred in 186.928304 secs (3158690 bytes/sec)
Step 6. Eject USB device safely
diskutil eject /dev/disk2
Job done! You should now have a working bootable USB disk ISO for xen server 6.2 ready to install.
# xe vm-list name-label=slice10100000 params=blocked-operations blocked-operations (MRW) : start:
xe vm-param-clear param-name=blocked-operations uuid=cabd0000-0001d-c000-43c8-134cf40c215e
xe vm-start vm=vmuuidhere
Hi guys. So I was working with cloud files API and I thought I would put together a piece of code that allows uploads of an entire file structure to a cloud files container. It won’t work with sub directories yet, but it’s simple enough to give anyone a better understanding of how this works. Please note the token I am using is not a real genuine token.
!/bin/sh # This Scripts Uploads an entire file structure to a cloud files container # CLOUD FILES TOKEN TOKEN='AAAjsa_x-Pe2YuyHVM7kuS-A67LcZNx4-MOCKTOKENjZ1GoLTwVKcQhyE9t-gZIIBMknJBEtD2JbJbWS4W1Pd7wJqXfxgN2ykVSfhcga1ch-vwBFAvlsjMj-ew6eMSG-TyEG7Q_ABC231' # Folder to Upload FROM FILES=/root/cloud-files/files/* # Container to Upload to CONTAINER=meh2 for f in $FILES do echo "Upload start $f ..." FILENAME=`basename $f` # take action on each file curl -i -X PUT https://storage101.lon3.clouddrive.com/v1/MossoCloudFS_10045567/meh2/$FILENAME -T /root/cloud-files/files/$FILENAME -H "X-Auth-Token: $TOKEN" done