<?xml version="1.0" encoding="UTF-8"?> <rss
version="2.0"
xmlns:content="http://purl.org/rss/1.0/modules/content/"
xmlns:wfw="http://wellformedweb.org/CommentAPI/"
xmlns:dc="http://purl.org/dc/elements/1.1/"
xmlns:atom="http://www.w3.org/2005/Atom"
xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
><channel><title>Brandon Checketts &#187; General</title> <atom:link href="http://www.brandonchecketts.com/archives/category/general/feed" rel="self" type="application/rss+xml" /><link>http://www.brandonchecketts.com</link> <description>Web Programming, Linux System Administation, and other geeky stuff</description> <lastBuildDate>Fri, 06 Jan 2012 01:23:26 +0000</lastBuildDate> <language>en</language> <sy:updatePeriod>hourly</sy:updatePeriod> <sy:updateFrequency>1</sy:updateFrequency> <generator>http://wordpress.org/?v=3.3.1</generator> <item><title>Upgrading Disks in a Software Raid System</title><link>http://www.brandonchecketts.com/archives/upgrading-disks-in-a-software-raid-system</link> <comments>http://www.brandonchecketts.com/archives/upgrading-disks-in-a-software-raid-system#comments</comments> <pubDate>Mon, 29 Aug 2011 01:04:07 +0000</pubDate> <dc:creator>Brandon</dc:creator> <category><![CDATA[General]]></category> <category><![CDATA[Linux System Administration]]></category><guid
isPermaLink="false">http://www.brandonchecketts.com/?p=498</guid> <description><![CDATA[I have a system at home with a pair of 640 GB drives, that are getting full. The drives are configured in a Linux Software RAID1 array. Replacing those drives with a pair of 2 TB drives is a pretty easy (although lengthy process). First, we need to verify that our RAID system is running [...]]]></description> <content:encoded><![CDATA[<p>I have a system at home with a pair of 640 GB drives, that are getting full.  The drives are configured in a Linux Software RAID1 array.   Replacing those drives with a pair of 2 TB drives is a pretty easy (although lengthy process).</p><p>First, we need to verify that our RAID system is running correctly.  Take a look at /proc/mdstat to verify that both drives are online:</p><pre>
root@host:~# cat /proc/mdstat
Personalities : [raid1] [linear] [multipath] [raid0] [raid6] [raid5] [raid4] [raid10]
md1 : active raid1 sdb3[1] sda3[0]
      622339200 blocks [2/2] [UU]

md0 : active raid1 sdb1[1] sda1[0]
      192640 blocks [2/2] [UU]
</pre><p>After verifying that the system is running, I powered the machine off and removed the second hard drive and replaced it with the new drive.  Upon starting it back up, Ubuntu noticed that the RAID system was running in degraded mode and I had to hit yes at the console to have it continue booting.</p><p>Once the machine was running, I logged in and created a similar partition structure on the new drive using the fdisk command.  On my system, I have a small 200 partition for /boot as /dev/sdb1, a 1 GB swap partition, and then the rest of the drive is one big block for the root partition.   The I copied the partition table that was on /dev/sda, but for the final partition, made it take up the entire rest of the drive.  Make sure to set the first partition as bootable.  The partitions on /dev/sdb now look like this:</p><pre>
   Device Boot      Start         End      Blocks   Id  System
/dev/sdb1   *           1          24      192748+  fd  Linux raid autodetect
/dev/sdb2              25         146      979965   82  Linux swap / Solaris
/dev/sdb3             147      243201  1952339287+  fd  Linux raid autodetect
</pre><p>After the partitions match up, I can now add the partitions on /dev/sdb into the RAID array</p><pre>
root@host:~# mdadm --manage /dev/md0 --add /dev/sdb1
root@host:~# mdadm --manage /dev/md1 --add /dev/sdb3
</pre><p>And watch the status of the rebuild using</p><pre>watch cat /proc/mdstat</pre><p>After that was done, I installed grub onto the new /dev/sdb</p><pre>
grub /dev/sdb
root (hd1)
setup (hd1,0)
</pre><p>Finally, reboot once and make sure that everything works as expected.</p><p>The system is now running with one old drive and one new drive.    The next step is to perform the same steps with removing the other old drive and rebuilding and re-adding it to the raid system.   The steps are the same as above, except performing them with /dev/sda.  I also had to change my BIOS to boot from the second drive.</p><p>Once both drives are installed and working with the RAID array, the final part of the process is to increase the size of the file system to the full size of our new drives.   I first had to disable the EXT3 file system journal.   This was necessary so that the online resize doesn&#8217;t run out of memory.</p><p>Edit /etc/fstab and change the file system type to ext2, and the arguments to include &#8220;noload&#8221; which will disable the file system journal.  My /etc/fstab looks like this:</p><pre>
# /etc/fstab: static file system information.
#
# &lt;file system&gt; &lt;mount point&gt;   &lt;type&gt;  &lt;options&gt;       &lt;dump&gt;  &lt;pass&gt;
proc            /proc           proc    defaults        0       0
# /dev/md1
UUID=b165f4be-a705-4479-b830-b0c6ee77b730 /               <strong>ext2</strong>    <strong>noload</strong>,relatime,errors=remount-ro 0       1
# /dev/md0
UUID=30430fe0-919d-4ea6-b3c2-5e3564344917 /boot           ext3    relatime        0       2
# /dev/sda5
UUID=94b03944-d215-4882-b0e0-dab3a8c50480 none            swap    sw              0       0
# /dev/sdb5
UUID=ebb381ae-e1bb-4918-94ec-c26e388bb539 none            swap    sw              0       0
</pre><p>You then have to run `mkinitramfs` to rebuild the initramfs file to include the desired change to the mount options</p><pre>
root@host:~# mkinitramfs -o /boot/initrd.img-2.6.31-20-generic 2.6.31-20-generic
</pre><p>Reboot to have the system running with journaling disabled on the root partition.  Finally, you can actually increase the RAID device to the full size of the device:</p><pre>
root@host:~# mdadm --grow /dev/md3 --size=max
</pre><p>And then resize the file system:</p><pre>
root@host:~# resize2fs /dev/md1
resize2fs 1.41.9 (22-Aug-2009)
Filesystem at /dev/md1 is mounted on /; on-line resizing required
old desc_blocks = 38, new_desc_blocks = 117
Performing an on-line resize of /dev/md1 to 488084800 (4k) blocks.
</pre><p>The system is now up and running with larger drives <img
src='http://www.brandonchecketts.com/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' /> .   Change the /etc/fstab, rebuild the initramfs, and reboot one more time to re-enable journaling and be running officially.</p> ]]></content:encoded> <wfw:commentRss>http://www.brandonchecketts.com/archives/upgrading-disks-in-a-software-raid-system/feed</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>Map of Amazon Fulfillment Centers</title><link>http://www.brandonchecketts.com/archives/map-of-amazon-fulfillment-centers</link> <comments>http://www.brandonchecketts.com/archives/map-of-amazon-fulfillment-centers#comments</comments> <pubDate>Thu, 14 Jul 2011 03:57:52 +0000</pubDate> <dc:creator>Brandon</dc:creator> <category><![CDATA[General]]></category><guid
isPermaLink="false">http://www.brandonchecketts.com/?p=493</guid> <description><![CDATA[I was doing some research into Amazon&#8217;s fulfillment centers today and had trouble finding them. After finding their addresses, I put them all on a Google Map here Amazon Fulfillment Centers View Amazon Fulfillment Centers in a larger map]]></description> <content:encoded><![CDATA[<p>I was doing some research into Amazon&#8217;s fulfillment centers today and had trouble finding them.   After finding their addresses, I put them all on a Google Map here</p><p><a
href="http://maps.google.com/maps/ms?ie=UTF8&#038;authuser=0&#038;hl=en&#038;oe=UTF8&#038;msa=0&#038;msid=214321102161815585315.0004a7fee1b3e22765024">Amazon Fulfillment Centers</a></p><p><iframe
width="425" height="350" frameborder="0" scrolling="no" marginheight="0" marginwidth="0" src="http://maps.google.com/maps/ms?msa=0&amp;msid=214321102161815585315.0004a7fee1b3e22765024&amp;ie=UTF8&amp;t=h&amp;ll=36.932337,-97.415709&amp;spn=7.982437,43.593644&amp;output=embed"></iframe><br
/><small>View <a
href="http://maps.google.com/maps/ms?msa=0&amp;msid=214321102161815585315.0004a7fee1b3e22765024&amp;ie=UTF8&amp;t=h&amp;ll=36.932337,-97.415709&amp;spn=7.982437,43.593644&amp;source=embed" style="color:#0000FF;text-align:left">Amazon Fulfillment Centers</a> in a larger map</small></p> ]]></content:encoded> <wfw:commentRss>http://www.brandonchecketts.com/archives/map-of-amazon-fulfillment-centers/feed</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>APISigning Now Works with Amazon Simple Email Service (SES)</title><link>http://www.brandonchecketts.com/archives/apisigning-now-works-with-amazon-simple-email-service-ses</link> <comments>http://www.brandonchecketts.com/archives/apisigning-now-works-with-amazon-simple-email-service-ses#comments</comments> <pubDate>Tue, 26 Apr 2011 20:15:58 +0000</pubDate> <dc:creator>Brandon</dc:creator> <category><![CDATA[Encryption]]></category> <category><![CDATA[General]]></category> <category><![CDATA[Programming]]></category> <category><![CDATA[Websites]]></category><guid
isPermaLink="false">http://www.brandonchecketts.com/?p=490</guid> <description><![CDATA[APISigning.com has been signing Amazon Product Advertising requests for a couple of years now. Amazon recently announced their Simple Email Service that makes it easy to send emails via an API. The SES API requires that requests be authenticated using some cryptographic functions that are not easily available on all platforms or programming languages. In [...]]]></description> <content:encoded><![CDATA[<p>APISigning.com has been signing Amazon Product Advertising requests for a couple of years now.  Amazon recently announced their <a
href="http://aws.amazon.com/ses/">Simple Email Service</a> that makes it easy to send emails via an API.  The SES API requires that requests be authenticated using some cryptographic functions that are not easily available on all platforms or programming languages.   In those cases, developers can use the <a
href="http://apisigning.com/ses-usage.html">APISigning SES Service</a> to calculate the correct signature and perform the request on their behalf.</p><p>APISigning has free accounts that effectively allows 10k signing requests each month.  Users who require additional requests can subscribe to a paid account with higher limits.</p> ]]></content:encoded> <wfw:commentRss>http://www.brandonchecketts.com/archives/apisigning-now-works-with-amazon-simple-email-service-ses/feed</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>How to shrink a partition with unmovable files in Windows 7</title><link>http://www.brandonchecketts.com/archives/how-to-shrink-a-partition-with-unmovable-files-in-windows-7</link> <comments>http://www.brandonchecketts.com/archives/how-to-shrink-a-partition-with-unmovable-files-in-windows-7#comments</comments> <pubDate>Sun, 03 Apr 2011 22:56:39 +0000</pubDate> <dc:creator>Brandon</dc:creator> <category><![CDATA[General]]></category><guid
isPermaLink="false">http://www.brandonchecketts.com/?p=488</guid> <description><![CDATA[For some reason Windows can&#8217;t figure out how to move some files around on disk. When attempting to shrink a volume, it will only allow you to shrink it to where the last immovable file is located. These are some things I found necessary to temporarily get rid of those immovable files so that an [...]]]></description> <content:encoded><![CDATA[<p>For some reason Windows can&#8217;t figure out how to move some files around on disk.   When attempting to shrink a volume, it will only allow you to shrink it to where the last immovable file is located.  These are some things I found necessary to temporarily get rid of those immovable files so that an NTFS volume could be shrunk</p><p>1- Disable System Restore  (Right click on Computer => Properties => System Protection => System Restore)<br
/> 2- Disable Virtual Memory (Right click on Comptuer => Properties => Advanced System Settings => Performance (Settings) => Advanced Tab => Virtual Memory (Change) => No Paging File => Set.<br
/> 3- Run Disk Cleanup to get rid of Thumbnails, Temporary Internet Files, and a bunch of other files that it makes no sense why they are immovable.<br
/> 4- Restart the computer to have #1 and #2 take effect</p><p>Try to shrink the volume again.  If it still is unreasonably large, you will then have to look at Event Viewer to find which file is at the boundary.<br
/> 1- Right click on Computer => Manage => Event Viewer => Windows Logs => Application.<br
/> 2- Click on Filter Current Log, and put &#8217;259&#8242; for the Event ID<br
/> 3- Click on the latest event and look through the detail to find the problematic file.  You can then attempt to delete that file (or set of files) manually.   You may have to restart into safe mode to delete some files</p><p>It took me about 5 loops of doing the above before I was finally able to shrink my volume to the size that I wanted.   After successful, you can then re-enable the features that you want (namely System Restore and Virtual Memory)</p> ]]></content:encoded> <wfw:commentRss>http://www.brandonchecketts.com/archives/how-to-shrink-a-partition-with-unmovable-files-in-windows-7/feed</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>Troubleshooting OpenVZ Out of Memory and Could Not Allocate Memory Errors</title><link>http://www.brandonchecketts.com/archives/troubleshooting-openvz-out-of-memory-and-could-not-allocate-memory-errors</link> <comments>http://www.brandonchecketts.com/archives/troubleshooting-openvz-out-of-memory-and-could-not-allocate-memory-errors#comments</comments> <pubDate>Fri, 18 Feb 2011 19:20:25 +0000</pubDate> <dc:creator>Brandon</dc:creator> <category><![CDATA[General]]></category> <category><![CDATA[Linux System Administration]]></category><guid
isPermaLink="false">http://www.brandonchecketts.com/?p=481</guid> <description><![CDATA[I will sometimes run into an error inside an OpenVZ guest where the system complains about running out of memory. This is usually seen as a message containing &#8220;Cannot allocate memory&#8221;. It may even occur when trying to enter into the container [root@host ~]# vzctl enter 908 entered into CT 908 -bash: /root/.bash_profile: Cannot allocate [...]]]></description> <content:encoded><![CDATA[<p>I will sometimes run into an error inside an OpenVZ guest where the system complains about running out of memory.  This is usually seen as a message containing &#8220;Cannot allocate memory&#8221;.   It may even occur when trying to enter into the container</p><pre>
[root@host ~]# vzctl enter 908
entered into CT 908
-bash: /root/.bash_profile: Cannot allocate memory
</pre><p>This particular error can be difficult to troubleshoot because OpenVZ has so many different limits.  The &#8220;Cannot allocate Memory&#8221; error is a pretty generic error, so Googling it doesn&#8217;t necessarily yield any useful results.</p><p>I&#8217;ve found that the best way to track down the source of the problem is to examine the /proc/user_beancounter statistics on the host server.   The far right column is labeled &#8216;failcnt&#8217; and is a simple counter for the number of times that particular resource has been exhausted.   Any non-zero numbers in that column may indicate a problem.   In this example, you can see that the dcachesize parameter is too small and should be increased</p><pre>
[root@host ~]# cat /proc/user_beancounters
Version: 2.5
       uid  resource                     held              maxheld              barrier                limit              failcnt
      908:  kmemsize                  5170890              5776435             43118100             44370492                    0
            lockedpages                     0                    0                  256                  256                    0
            privvmpages                 53561                55089              1048576              1048576                    0
            shmpages                        2                    2                21504                21504                    0
            dummy                           0                    0                    0                    0                    0
            numproc                        30                   38                 2000                 2000                    0
            physpages                    6136                 7392                    0  9223372036854775807                    0
            vmguarpages                     0                    0                65536                65536                    0
            oomguarpages                 6136                 7392                26112  9223372036854775807                    0
            numtcpsock                      8                    8                  360                  360                    0
            numflock                        5                    6                  380                  420                    0
            numpty                          0                    1                   16                   16                    0
            numsiginfo                      0                    2                  256                  256                    0
            tcpsndbuf                  140032                    0             10321920             16220160                    0
            tcprcvbuf                  131072                    0              1720320              2703360                    0
            othersockbuf               151320               156864              4504320             16777216                    0
            dgramrcvbuf                     0                 8472               262144               262144                    0
            numothersock                  107                  109                 5000                 5000                    0
            dcachesize                3408570              3413265              3409920              3624960                   81
            numfile                       724                  957                18624                18624                    0
            dummy                           0                    0                    0                    0                    0
            dummy                           0                    0                    0                    0                    0
            dummy                           0                    0                    0                    0                    0
            numiptent                      10                   10                  128                  128                    0
</pre><p>You can do a little investigation to see what each particular limit does.  I will usually not dig too deep, but just double the value and try again.   You can set a new value using the vzctl command like this:</p><pre>
[root@host ~] vzctl set 908 --dcachesize=6819840:7249920 --save
</pre>]]></content:encoded> <wfw:commentRss>http://www.brandonchecketts.com/archives/troubleshooting-openvz-out-of-memory-and-could-not-allocate-memory-errors/feed</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>Website Performance: Tables Versus CSS</title><link>http://www.brandonchecketts.com/archives/website-performance-tables-versus-css</link> <comments>http://www.brandonchecketts.com/archives/website-performance-tables-versus-css#comments</comments> <pubDate>Sat, 16 Oct 2010 21:00:18 +0000</pubDate> <dc:creator>Brandon</dc:creator> <category><![CDATA[General]]></category> <category><![CDATA[PHP]]></category> <category><![CDATA[Programming]]></category> <category><![CDATA[Website Performance]]></category> <category><![CDATA[Websites]]></category><guid
isPermaLink="false">http://www.brandonchecketts.com/?p=478</guid> <description><![CDATA[Most website designers have been using CSS for page layout for several years now, but I occasionally see some websites that continue to use HTML tables for layout. As I&#8217;ve been focusing on website performance lately, I&#8217;ve found some references that modern browsers render sites using tables for layout slower than they do sites that [...]]]></description> <content:encoded><![CDATA[<p>Most website designers have been using CSS for page layout for several years now, but I occasionally see some websites that continue to use HTML tables for layout.  As I&#8217;ve been focusing on website performance lately, I&#8217;ve found some references that modern browsers render sites using tables for layout slower than they do sites that use CSS.  I decided to investigate and confirmed that there are many possible situations where sites using large tables will appear to load much slower than those using CSS.  I put together two pages to confirm:</p><p><a
href="/book_samples/performance_divs.php" target="_blank">This page uses &lt;div&gt; elements for layout</a><br
/> and<br
/> <a
href="/book_samples/performance_tables.php" target="_blank">This pages uses a large table for layout</a></p><p>On both pages I&#8217;ve added a 5-second sleep near the end of the page to show what might happen if the server was slow, if there were network problems, or any other number of things may have happened.</p><p>Notice that the page created using a table changes a lot after the delay.  I&#8217;ve tried it in Firefox 3 which extends the main (yellow) content section all of the way to the right until it receives the rest of the document, at which point it has to shrink that part to make room for the section on the right.   Internet Explorer behaves even worse.  It leaves a blank white page until after the delay, at which point it draws the whole table.</p><p>By contrast, the page created with CSS positioning shows all of the content above the delay and has it in the correct position.  When the rest of the document is sent it just fills in the appropriate content, but doesn&#8217;t have to re-arrange anything on the page.</p> ]]></content:encoded> <wfw:commentRss>http://www.brandonchecketts.com/archives/website-performance-tables-versus-css/feed</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>Southeast Linux Fest Presentation on MySQL Replication</title><link>http://www.brandonchecketts.com/archives/southeast-linux-fest-presentation-on-mysql-replication</link> <comments>http://www.brandonchecketts.com/archives/southeast-linux-fest-presentation-on-mysql-replication#comments</comments> <pubDate>Mon, 14 Jun 2010 02:01:51 +0000</pubDate> <dc:creator>Brandon</dc:creator> <category><![CDATA[General]]></category> <category><![CDATA[Linux System Administration]]></category> <category><![CDATA[LUG]]></category> <category><![CDATA[MySQL]]></category><guid
isPermaLink="false">http://www.brandonchecketts.com/?p=460</guid> <description><![CDATA[I was fortunate to be selected to give a presentation at the 2010 Southeast Linux Fest held this year in Greenville, SC. The topic was MySQL replication which I picked from a similar presentation I gave about about 1.5 years ago at my local LUG. I&#8217;ve configured plenty of replicated servers and I think that [...]]]></description> <content:encoded><![CDATA[<p>I was fortunate to be selected to give a presentation at the 2010 <a
href="http://www.southeastlinuxfest.org/">Southeast Linux Fest</a> held this year in Greenville, SC. The topic was MySQL replication which I picked from a similar presentation I gave about about 1.5 years ago at my <a
href="http://www.uga.edu/chugalug/">local LUG</a>.   I&#8217;ve configured plenty of replicated servers and I think that I understand it well enough to explain it to others.</p><p>The 2-hour presentation is about half slides and half demo.  Throughout the course of the presentation I set up a simple master-slave.  Then I add a second slave.   Taking it a step farther I set up the three servers to replicate in a chain, and finally I configure them to replicate in a full circle so that changes made on one are propagated to all of the others.  I intentionally do things that break replication at certain points to show some of the limitations and configurable features that can help it to work.</p><p>Slides for the presentation are available <a
href="/downloads/self2010-mysql-replication.odp">OpenOffice format</a>.</p><p>The presentation was recorded, so hopefully the SELF team will have those videos available shortly.</p> ]]></content:encoded> <wfw:commentRss>http://www.brandonchecketts.com/archives/southeast-linux-fest-presentation-on-mysql-replication/feed</wfw:commentRss> <slash:comments>0</slash:comments> </item> <item><title>Script to Import Static Pages into GetSimple CMS</title><link>http://www.brandonchecketts.com/archives/script-to-import-static-pages-into-getsimple-cms</link> <comments>http://www.brandonchecketts.com/archives/script-to-import-static-pages-into-getsimple-cms#comments</comments> <pubDate>Thu, 13 May 2010 04:30:52 +0000</pubDate> <dc:creator>Brandon</dc:creator> <category><![CDATA[General]]></category> <category><![CDATA[PHP]]></category> <category><![CDATA[Websites]]></category><guid
isPermaLink="false">http://www.brandonchecketts.com/?p=457</guid> <description><![CDATA[I&#8217;ve recently been impressed with a very simple Content Management System called GetSimple. It provides just the very basics that allows a user to edit their own website content. For brochure sites with owners who don&#8217;t want the complexity of a larger CMS, I think it is pretty ideal. When I develop a site though, [...]]]></description> <content:encoded><![CDATA[<p>I&#8217;ve recently been impressed with a very simple Content Management System called <a
href="http://get-simple.info/">GetSimple</a>.  It provides just the very basics that allows a user to edit their own website content.  For brochure sites with owners who don&#8217;t want the complexity of a larger CMS, I think it is pretty ideal.</p><p>When I develop a site though, I typically have a header and footer, and then all of the content pages exist as PHP files that simply include that header and footer.  Converting a static site like that into the CMS takes a bunch of copy/pasting.  I always try to avoid such tedious jobs, and so developed a script  that will import those static pages into a GetSimple installation.</p><p>To run this script, I wanted to import a bunch of files in a &#8216;static&#8217; directory where I had moved all of the static files to.  I then ran this from the command line to import all of the content into GetSimple</p><pre>
# for file in `find static -type f`
> do
> ./getsimple_import_file.php $file
> done
</pre><p>The script is available as <a
href="http://www.brandonchecketts.com/downloads/getsimple_import_file.php">getsimple_import_file.php</a></p><p>It takes a little configuration before running it.   It works by simulating the data that you would submit when creating the page through the web interface, so we have to fake the necessary session cookie.  Uncomment the bit in the middle that will display your cookie and run the script once.  You&#8217;ll need to copy your cookie name and value into the script before doing any actual imports.</p><p>Once you&#8217;ve done that, you will probably want to change the regular expression that attempts to grab the page title from your file.  You may also want to manipulate how it figures the URL to use.</p><p>Feel free to post comments here if  you found this useful, or made any changes  you&#8217;d like to share with other users</p> ]]></content:encoded> <wfw:commentRss>http://www.brandonchecketts.com/archives/script-to-import-static-pages-into-getsimple-cms/feed</wfw:commentRss> <slash:comments>9</slash:comments> </item> <item><title>Skipping the DROP TABLE, CREATE TABLE statements in a large mysqldump file.</title><link>http://www.brandonchecketts.com/archives/skipping-the-drop-table-create-table-statements</link> <comments>http://www.brandonchecketts.com/archives/skipping-the-drop-table-create-table-statements#comments</comments> <pubDate>Wed, 28 Apr 2010 14:03:52 +0000</pubDate> <dc:creator>Brandon</dc:creator> <category><![CDATA[General]]></category> <category><![CDATA[Linux System Administration]]></category> <category><![CDATA[MySQL]]></category> <category><![CDATA[Programming]]></category><guid
isPermaLink="false">http://www.brandonchecketts.com/?p=451</guid> <description><![CDATA[I have a large table of test data that I&#8217;m copying into some development environments. I exported the table with a mysqldump which has a DROP TABLE and CREATE TABLE statements at the top DROP TABLE IF EXISTS `mytable`; CREATE TABLE `mytable` ( `somecol` varchar(10) NOT NULL default '', ... other columns ... PRIMARY KEY [...]]]></description> <content:encoded><![CDATA[<p>I have a large table of test data that I&#8217;m copying into some development environments.  I exported the table with a mysqldump which has a DROP TABLE and CREATE TABLE statements at the top</p><pre>
DROP TABLE IF EXISTS `mytable`;
CREATE TABLE `mytable` (
  `somecol` varchar(10) NOT NULL default '',
   ... other columns ...
  PRIMARY KEY  (`somecol`),
  KEY `isbn10` (`somecol`)
) ENGINE=InnoDB DEFAULT CHARSET=latin1;
</pre><p>The problem is that the developer has altered the table and re-importing the test data would undo those changes.  Editing the text file is impractical because of its size (500 MB gzipped).  So I came up with this workaround which just slightly alters the SQL using sed so that it doesn&#8217;t try to drop or recreate the table.  It comments out the DROP TABLE line, and creates the new table in the test database instead of the real database.</p><pre>
zcat bigfile.sql.gz |sed "s/DROP/-- DROP/"|sed "s/CREATE TABLE /CREATE TABLE test./"|mysql databasename
</pre>]]></content:encoded> <wfw:commentRss>http://www.brandonchecketts.com/archives/skipping-the-drop-table-create-table-statements/feed</wfw:commentRss> <slash:comments>2</slash:comments> </item> <item><title>Sleeping for a random amount of time in a shell script</title><link>http://www.brandonchecketts.com/archives/sleeping-for-a-random-amount-of-time-in-a-shell-script</link> <comments>http://www.brandonchecketts.com/archives/sleeping-for-a-random-amount-of-time-in-a-shell-script#comments</comments> <pubDate>Fri, 26 Mar 2010 21:17:05 +0000</pubDate> <dc:creator>Brandon</dc:creator> <category><![CDATA[General]]></category> <category><![CDATA[Linux System Administration]]></category><guid
isPermaLink="false">http://www.brandonchecketts.com/?p=444</guid> <description><![CDATA[You can use the special $RANDOM environment variable to get a random number and divide it by the maximum number of seconds that you want to wait. Use the remainder as the number of seconds to sleep since it will always be between zero and the max you specified. This example will sleep anywhere between [...]]]></description> <content:encoded><![CDATA[<p>You can use the special $RANDOM environment variable to get a random number and divide it by the maximum number of seconds that you want to wait.  Use the remainder as the number of seconds to sleep since it will always be between zero and the max you specified.  This example will sleep anywhere between zero and 10 minutes (600 seconds)</p><pre>
 /bin/sleep/sleep   `/usr/bin/expr $RANDOM % 600`
</pre><p>Purists will note that it isn&#8217;t truly random.  The maximum value for $RANDOM is 32767 which is not evenly divisible by most likely values, but it is close enough.</p> ]]></content:encoded> <wfw:commentRss>http://www.brandonchecketts.com/archives/sleeping-for-a-random-amount-of-time-in-a-shell-script/feed</wfw:commentRss> <slash:comments>0</slash:comments> </item> </channel> </rss>
<!-- Performance optimized by W3 Total Cache. Learn more: http://www.w3-edge.com/wordpress-plugins/

Minified using disk
Page Caching using disk (user agent is rejected)
Database Caching 1/17 queries in 0.014 seconds using disk

Served from: www.brandonchecketts.com @ 2012-02-04 02:31:48 -->
