<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" media="screen" href="/~d/styles/rss2full.xsl"?><?xml-stylesheet type="text/css" media="screen" href="http://feeds.feedburner.com/~d/styles/itemcontent.css"?><rss 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/" xmlns:creativeCommons="http://backend.userland.com/creativeCommonsRssModule" xmlns:feedburner="http://rssnamespace.org/feedburner/ext/1.0" version="2.0">

<channel>
	<title>luauf.com</title>
	
	<link>http://luauf.com</link>
	<description>Sistemas Operativos, Bases de Datos, Programación y Redes</description>
	<lastBuildDate>Mon, 14 May 2012 01:15:43 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.3.2</generator>
		<atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="self" type="application/rss+xml" href="http://feeds.feedburner.com/luauf" /><feedburner:info uri="luauf" /><atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="hub" href="http://pubsubhubbub.appspot.com/" /><creativeCommons:license>http://creativecommons.org/licenses/by/2.5/</creativeCommons:license><feedburner:emailServiceId>luauf</feedburner:emailServiceId><feedburner:feedburnerHostname>http://feedburner.google.com</feedburner:feedburnerHostname><item>
		<title>Alinear a la derecha los botones minimizar, maximizar y cerrar de Chromium en Gnome</title>
		<link>http://feedproxy.google.com/~r/luauf/~3/JiQe_b4whaY/</link>
		<comments>http://luauf.com/2012/05/04/alinear-a-la-derecha-los-botones-minimizar-maximizar-y-cerrar-de-chromium-en-gnome/#comments</comments>
		<pubDate>Fri, 04 May 2012 06:00:09 +0000</pubDate>
		<dc:creator>Luciano</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Sistemas Operativos]]></category>
		<category><![CDATA[Alineación]]></category>
		<category><![CDATA[Chromium]]></category>
		<category><![CDATA[Ubuntu]]></category>

		<guid isPermaLink="false">http://luauf.com/?p=1316</guid>
		<description><![CDATA[Una nueva ayuda memoria, en este caso, como alinear a la derecha los botones Minimizar, Maximizar y Cerrar en Chromium. Luego de instalar Ubuntu 12.04, gnome-shell y de personalizar todos los detalles de...]]></description>
			<content:encoded><![CDATA[<p>Una nueva ayuda memoria, en este caso, como alinear a la derecha los botones Minimizar, Maximizar y Cerrar en Chromium.</p>
<p>Luego de instalar Ubuntu 12.04, gnome-shell y de personalizar todos los detalles de mi escritorio, me encontré con un detalle estético poco feliz, que no era de mi agrado (que conste que era simplemente una cuestión personal). El <strong>detalle</strong>: los botones Minimizar, Maximizar y Cerrar de Chromium alineados a la izquierda x-(</p>
<p><a href="http://luauf.com/wp-content/uploads/2012/05/screenshot.png"><img class="aligncenter size-medium wp-image-1318" title="screenshot" src="http://luauf.com/wp-content/uploads/2012/05/screenshot-300x175.png" alt="" width="300" height="175" /></a></p>
<p><span id="more-1316"></span><br />
Como es la segunda vez que me encuentro con el mismo problema, y buscar la solución me demandó unos 10 minutos que no quiero perder la pròxima, dejo sentada aquí mi ayuda memoria:</p>
<p>Para cambiar la alineación de los botones minimizar, maximizar y cerrar a la derecha, simplemente ejecutar en una terminal:</p>
<p><strong>gconftool-2 &#8211;type string &#8211;set /apps/metacity/general/button_layout &#8220;menu:minimize,maximize,close&#8221;</strong></p>
<p>Si te gusta como quedaban a la izquierda (yo paso), puedes regresarlos de la siguiente forma:</p>
<p><strong>gconftool-2 &#8211;type string &#8211;set /apps/metacity/general/button_layout &#8220;close,minimize,maximize:&#8221;</strong></p>
<p>En uno u otro caso la actualización es inmediata, no se requiere reiniciar absolutamente nada.</p>
<img src="http://feeds.feedburner.com/~r/luauf/~4/JiQe_b4whaY" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://luauf.com/2012/05/04/alinear-a-la-derecha-los-botones-minimizar-maximizar-y-cerrar-de-chromium-en-gnome/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		<feedburner:origLink>http://luauf.com/2012/05/04/alinear-a-la-derecha-los-botones-minimizar-maximizar-y-cerrar-de-chromium-en-gnome/</feedburner:origLink></item>
		<item>
		<title>Introducción a Control de Versiones con Git</title>
		<link>http://feedproxy.google.com/~r/luauf/~3/YPbQ9AGjV4o/</link>
		<comments>http://luauf.com/2012/02/25/introduccion-a-control-de-versiones-con-git/#comments</comments>
		<pubDate>Sun, 26 Feb 2012 00:47:54 +0000</pubDate>
		<dc:creator>Luciano</dc:creator>
				<category><![CDATA[Gestión]]></category>
		<category><![CDATA[Miscelaneas]]></category>
		<category><![CDATA[Programación]]></category>
		<category><![CDATA[control de versiones]]></category>
		<category><![CDATA[CVS]]></category>
		<category><![CDATA[git]]></category>
		<category><![CDATA[Repositorio]]></category>
		<category><![CDATA[SVN]]></category>
		<category><![CDATA[versiones]]></category>

		<guid isPermaLink="false">http://luauf.com/?p=1199</guid>
		<description><![CDATA[Git es un software de control de versiones, como lo son, por ejemplo: CVS, SVN o VSS. Git fue diseñado por Torvalds con el objetivo de llevar el kernel de Linux en un...]]></description>
			<content:encoded><![CDATA[<p><strong>Git</strong> es un software de control de versiones, como lo son, por ejemplo: CVS, SVN o VSS.</p>
<p><strong>Git</strong> fue diseñado por <strong>Torvalds</strong> con el objetivo de llevar el kernel de Linux en un repositorio confiable o como el propio <strong>Linus</strong> dijo &#8220;rápido, muy rápido, fácil, bonito y espectacular&#8221;.</p>
<p style="text-align: center;"><a href="http://luauf.com/wp-content/uploads/2012/02/git_logo.png"><img class="aligncenter size-medium wp-image-1258" title="git_logo" src="http://luauf.com/wp-content/uploads/2012/02/git_logo-300x164.png" alt="" width="300" height="164" /></a></p>
<p>Una de las referencias de Linus en el diseño de <strong>git</strong> fue CVS, pero como un ejemplo de lo que NO HAY QUE HACER, pues lo sufrió durante siete años en una compañía y allí aprendió a odiarlo con pasión. Linus tampoco quizo probar con SVN, pues el lema de SVN era &#8220;hacer CVS bien&#8221;, y eso ya lo condenaba, pues no había forma de hacer a CVS bien.</p>
<p>Dejando de lado las anécdotas anteriores, Git es utilizado por la mayoría de los desarrollos open source de la actualidad:</p>
<ul>
<li>El propio Git</li>
<li>Linux Kernel</li>
<li>Perl</li>
<li>Eclipse</li>
<li>Gnome</li>
<li>KDE</li>
<li>Qt</li>
<li>Ruby on Rails</li>
<li>Android</li>
<li>PostgreSQL</li>
<li>Debian</li>
<li>X.org</li>
</ul>
<p><span id="more-1199"></span>Para quienes no saben lo que es un software control de versiones, básicamente, se puede resumir en un servidor donde se suben los archivos de un proyecto y a medida que se van modificando se van registrando y documentando estos cambios (versionando). En principio la idea es sencilla y más de un improvisado podría cuestionar el uso del mismo. No obstante, en la medida que un proyecto crece, la cantidad de archivos aumenta, los cambios y la cantidad de programadores también, resulta totalmente insostenible trabajar sin un control de versiones.</p>
<p>Trabajar sin control de versiones implica no saber donde está el último fuente, arrancar trabajando de una versión anterior y perderse los cambios de la que realmente era la última, no saber cuales son y quien realizó los cambios, no deshacer fácilmente los cambios realizados (downgrade), o no poder facilitar la transición a una versión totalmente nueva de un proyecto manteniendo el soporte a la anterior.</p>
<p>Una cosa más, la mayoría de los IDEs actuales tienen integración con Git, o si no la tienen, tienen algún plugin para hacerlo. Ahora, si no utilizas un IDE, tu caso es un poco más delicado <img src='http://luauf.com/wp-includes/images/smilies/icon_wink.gif' alt=';-)' class='wp-smiley' /> </p>
<p>Sin más preámbulos, vamos a la práctica. En mis prácticas no utilizaré IDE, utilizaré un único archivo fuente y utilizaré el mismo equipo (dotado con Ubuntu Linux) como repositorio y cliente. Por lo tanto, primero, descargaré lo necesario: apt-get install git-core</p>
<p>Primer paso, en rol de &#8220;servidor&#8221;, creo el repositorio:</p>
<div class="syntax_hilite">
<div id="code-15">
<div class="code">$ git init mi_repositorio</div>
</div>
</div>
<p></p>
<p>Initialized empty Git repository in /home/luciano/mi_repositorio/.git/</p>
<p>En caso de no pasar el último argumento, en mi caso: mi_repositorio, el repositorio se inicializará en el directorio actual.</p>
<p>Ahora, en rol de &#8220;cliente&#8221;, supongamos que tengo mis desarrollos en este path:</p>
<div class="syntax_hilite">
<div id="code-16">
<div class="code">$ pwd<br />
/home/luciano/desarrollo</div>
</div>
</div>
<p>
Si quiero &#8220;sincronizar&#8221; mi directorio de desarrollo con el repositorio de git, debe hacer un &#8220;clone&#8221;, así:</p>
<div class="syntax_hilite">
<div id="code-17">
<div class="code">$ git clone /home/luciano/mi_repositorio<br />
Cloning into luciano&#8230;<br />
<span style="">done</span>.<br />
<span style="">warning</span>: You appear to have cloned an empty repository.</div>
</div>
</div>
<p>
Estamos arrancando de cero, por lo tanto el warning es ignorable <img src='http://luauf.com/wp-includes/images/smilies/icon_wink.gif' alt=';-)' class='wp-smiley' /> </p>
<p>El argumento que cambiará del &#8220;clone&#8221; en el caso que el repositorio se encuentre en otro servidor, será el path del repositorio, que deberá ser antecedido por usuario@host, por ejemplo:</p>
<div class="syntax_hilite">
<div id="code-18">
<div class="code">git clone username@host:/path/to/repository</div>
</div>
</div>
<p></p>
<p>Un repositorio administrador por git cuenta con lo que se denominan tres árboles, el primero, el directorio local (directorio de trabajo). El segundo es un &#8220;directorio intermedio&#8221; a donde van a parar los archivos que se agregan al proyecto, finalmente el &#8220;HEAD&#8221; donde reside la última versión confirmada. Ahora, veremos como agregar un archivo al repositorio y como &#8220;commitearlo&#8221;.</p>
<p>Primero, creo un archivo fuente en mi directorio de trabajo:</p>
<div class="syntax_hilite">
<div id="code-19">
<div class="code">$ pwd<br />
/home/luciano/desarrollo<br />
$ cd mi_repositorio<br />
$ touch holamundo.<span style="">c</span></div>
</div>
</div>
<p></p>
<p>Observen lo siguiente, no hay nada que decir:</p>
<div class="syntax_hilite">
<div id="code-20">
<div class="code">$ git status<br />
# On branch master<br />
#<br />
# Initial commit<br />
#<br />
# Untracked files:<br />
# <span style="color:#006600; font-weight:bold;">&#40;</span>use <span style="color:#CC0000;">&#8220;git add &#8230;&#8221;</span> to include in what will be committed<span style="color:#006600; font-weight:bold;">&#41;</span><br />
#<br />
# holamundo.<span style="">c</span><br />
nothing added to commit but untracked files present <span style="color:#006600; font-weight:bold;">&#40;</span>use <span style="color:#CC0000;">&#8220;git add&#8221;</span> to track<span style="color:#006600; font-weight:bold;">&#41;</span></div>
</div>
</div>
<p></p>
<p>Ahora, agrego el archivo al repositorio:</p>
<div class="syntax_hilite">
<div id="code-21">
<div class="code">$ git add holamundo.<span style="">c</span></div>
</div>
</div>
<p></p>
<p>Finalmente, commit:</p>
<div class="syntax_hilite">
<div id="code-22">
<div class="code">$ git commit -m <span style="color:#CC0000;">&#8220;revision inicial&#8221;</span> holamundo.<span style="">c</span><br />
<span style="color:#006600; font-weight:bold;">&#91;</span>master <span style="color:#006600; font-weight:bold;">&#40;</span>root-commit<span style="color:#006600; font-weight:bold;">&#41;</span> 2b983d9<span style="color:#006600; font-weight:bold;">&#93;</span> revision inicial<br />
Committer: Luciano</div>
</div>
</div>
<p></p>
<p>Ahora, el estado nuevamente:</p>
<div class="syntax_hilite">
<div id="code-23">
<div class="code">$ git status<br />
# On branch master<br />
nothing to commit <span style="color:#006600; font-weight:bold;">&#40;</span>working directory clean<span style="color:#006600; font-weight:bold;">&#41;</span></div>
</div>
</div>
<p></p>
<p>Un último comentario acerca de lo último, el commit quedó registrado con mi usuario (Committer) y mi host luciano@lucid.</p>
<p>Una opción, antes de lo anterior, es setear esos valores de la siguiente forma:</p>
<div class="syntax_hilite">
<div id="code-24">
<div class="code">$ git config –global user.<span style="">name</span> “Juan Del Rio”<br />
$ git config –global user.<span style="">email</span> juan@delrio.<span style="">com</span></div>
</div>
</div>
<p></p>
<p>Ahora, modifico el fuente y observo el estado de nuevo:</p>
<div class="syntax_hilite">
<div id="code-25">
<div class="code">$ echo <span style="color:#CC0000;">&#8220;/* holamundo program */&#8221;</span>&amp;gt; holamundo.<span style="">c</span></p>
<p>$ git status<br />
# On branch master<br />
# Changes not staged for commit:<br />
# <span style="color:#006600; font-weight:bold;">&#40;</span>use <span style="color:#CC0000;">&#8220;git add &#8230;&#8221;</span> to update what will be committed<span style="color:#006600; font-weight:bold;">&#41;</span><br />
# <span style="color:#006600; font-weight:bold;">&#40;</span>use <span style="color:#CC0000;">&#8220;git checkout &#8212; &#8230;&#8221;</span> to discard changes in working directory<span style="color:#006600; font-weight:bold;">&#41;</span><br />
#<br />
# modified: holamundo.<span style="">c</span><br />
#<br />
no changes added to commit <span style="color:#006600; font-weight:bold;">&#40;</span>use <span style="color:#CC0000;">&#8220;git add&#8221;</span> and/or <span style="color:#CC0000;">&#8220;git commit -a&#8221;</span><span style="color:#006600; font-weight:bold;">&#41;</span></div>
</div>
</div>
<p></p>
<p>Hay cambios sin &#8220;commitear&#8221;, por lo tanto, hago un nuevo commit:</p>
<div class="syntax_hilite">
<div id="code-26">
<div class="code">$ git commit -m <span style="color:#CC0000;">&#8220;agregue encabezado&#8221;</span> holamundo.<span style="">c</span></p>
<p>$ git status<br />
# On branch master<br />
nothing to commit <span style="color:#006600; font-weight:bold;">&#40;</span>working directory clean<span style="color:#006600; font-weight:bold;">&#41;</span></div>
</div>
</div>
<p></p>
<p>Para terminar (por ahora), si elimino el archivo:</p>
<div class="syntax_hilite">
<div id="code-27">
<div class="code">$ rm holamundo.<span style="">c</span></p>
<p>$ git status<br />
# On branch master<br />
# Changes not staged for commit:<br />
# <span style="color:#006600; font-weight:bold;">&#40;</span>use <span style="color:#CC0000;">&#8220;git add/rm &#8230;&#8221;</span> to update what will be committed<span style="color:#006600; font-weight:bold;">&#41;</span><br />
# <span style="color:#006600; font-weight:bold;">&#40;</span>use <span style="color:#CC0000;">&#8220;git checkout &#8212; &#8230;&#8221;</span> to discard changes in working directory<span style="color:#006600; font-weight:bold;">&#41;</span><br />
#<br />
# deleted: holamundo.<span style="">c</span><br />
#<br />
no changes added to commit <span style="color:#006600; font-weight:bold;">&#40;</span>use <span style="color:#CC0000;">&#8220;git add&#8221;</span> and/or <span style="color:#CC0000;">&#8220;git commit -a&#8221;</span><span style="color:#006600; font-weight:bold;">&#41;</span></div>
</div>
</div>
<p></p>
<p>Por lo tanto debo:</p>
<div class="syntax_hilite">
<div id="code-28">
<div class="code">$ git rm holamundo.<span style="">c</span><br />
$ git commit -m <span style="color:#CC0000;">&#8220;bye bye adios&#8221;</span> holamundo.<span style="">c</span><br />
$ git status<br />
# On branch master<br />
nothing to commit <span style="color:#006600; font-weight:bold;">&#40;</span>working directory clean<span style="color:#006600; font-weight:bold;">&#41;</span></div>
</div>
</div>
<p></p>
<p>Por hoy esto es todo, a pesar de que es muy poco y aún no es lo suficiente para compreder las virtudes de un sistema de control de versiones, basta para saber como hacer &#8220;altas, bajas y modificaciones&#8221;.</p>
<p>En la próxima entrega, quedo comprometido en tratar los &#8220;push&#8221; a un servidor remoto, trabajar con &#8220;branches&#8221;, hacer &#8220;merges&#8221; y un poco más.</p>
<div></div>
<img src="http://feeds.feedburner.com/~r/luauf/~4/YPbQ9AGjV4o" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://luauf.com/2012/02/25/introduccion-a-control-de-versiones-con-git/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		<feedburner:origLink>http://luauf.com/2012/02/25/introduccion-a-control-de-versiones-con-git/</feedburner:origLink></item>
		<item>
		<title>Ayuda memoria: loops infinitos en el shell</title>
		<link>http://feedproxy.google.com/~r/luauf/~3/n12OApAFwt4/</link>
		<comments>http://luauf.com/2012/01/26/ayuda-memoria-loops-infinitos-en-el-shell/#comments</comments>
		<pubDate>Fri, 27 Jan 2012 01:44:47 +0000</pubDate>
		<dc:creator>Luciano</dc:creator>
				<category><![CDATA[Bash]]></category>
		<category><![CDATA[Miscelaneas]]></category>
		<category><![CDATA[Programación]]></category>
		<category><![CDATA[UNIX]]></category>
		<category><![CDATA[bash]]></category>
		<category><![CDATA[bucle]]></category>
		<category><![CDATA[infinito]]></category>
		<category><![CDATA[ksh]]></category>
		<category><![CDATA[LOOP]]></category>
		<category><![CDATA[sh]]></category>
		<category><![CDATA[Shell]]></category>

		<guid isPermaLink="false">http://luauf.com/?p=1197</guid>
		<description><![CDATA[Este blog, me ha sido en más de una ocasión, mi ayuda memoria ideal. En otras tantas ocasiones, un link al mismo me permitió &#8220;ayudar al prójimo&#8221;, más bien, ahorrarme tiempo de utilización...]]></description>
			<content:encoded><![CDATA[<p>Este blog, me ha sido en más de una ocasión, mi ayuda memoria ideal. En otras tantas ocasiones, un link al mismo me permitió &#8220;ayudar al prójimo&#8221;, más bien, ahorrarme tiempo de utilización de cuerdas vocales y ahorrar al otro el fastidio de escucharme.</p>
<p>Por tal motivo, y ante un requerimiento del primer tipo (como &#8220;ayuda memoria&#8221;) quiero publicar algo que frecuentemente utilizo (o que cuando no es tan frecuente mi fragil memoria olvida):</p>
<p><strong>¿Cómo hacer un loop infinito en un intérprete de comandos (sh, ksh o similar)?</strong></p>
<p>Pongamos unas comillas al &#8220;infinito&#8221;, todo concluye al fin, nada puede escapar a un <strong>Ctrl+C</strong> o a un break (produce un abandono inmediato) dentro del bucle.</p>
<p><span id="more-1197"></span></p>
<pre>while :; do
  # Todo lo que quieras repetir infinitas veces
  echo "Hola Mundo"
  sleep 2
done</pre>
<p>No olvides el sleep, sino pasarán cosas muy rápido <img src='http://luauf.com/wp-includes/images/smilies/icon_wink.gif' alt=';-)' class='wp-smiley' /> </p>
<p>Otras opciones son utilizar las <em>palabras especiale</em>s <strong>true</strong> (indica que una condición en verdadera) y <strong>false</strong> (indica que una condición es falsa) de<strong> bash</strong>:</p>
<pre>while true; do
  ...
  ...
done</pre>
<p>O:</p>
<pre>until false; do
  ...
  ...</pre>
<pre>done</pre>
<div></div>
<img src="http://feeds.feedburner.com/~r/luauf/~4/n12OApAFwt4" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://luauf.com/2012/01/26/ayuda-memoria-loops-infinitos-en-el-shell/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		<feedburner:origLink>http://luauf.com/2012/01/26/ayuda-memoria-loops-infinitos-en-el-shell/</feedburner:origLink></item>
		<item>
		<title>Exportar una base de datos MDB a SQL (mysql, oracle, sybase, etc.)</title>
		<link>http://feedproxy.google.com/~r/luauf/~3/6MzG6H18oas/</link>
		<comments>http://luauf.com/2011/09/12/exportar-una-base-de-datos-mdb-a-sql-mysql-oracle-sybase-etc/#comments</comments>
		<pubDate>Tue, 13 Sep 2011 02:00:38 +0000</pubDate>
		<dc:creator>Luciano</dc:creator>
				<category><![CDATA[Bases de Datos]]></category>
		<category><![CDATA[MySQL]]></category>
		<category><![CDATA[SQL]]></category>
		<category><![CDATA[access]]></category>
		<category><![CDATA[exportar]]></category>
		<category><![CDATA[mdb]]></category>
		<category><![CDATA[Oracle]]></category>
		<category><![CDATA[Postgres]]></category>
		<category><![CDATA[sybase]]></category>

		<guid isPermaLink="false">http://luauf.com/?p=1193</guid>
		<description><![CDATA[Recuerdo instantes de mi pasado donde he tenido la necesidad de llevar Bases de Datos MDB, Microsoft Access, a bases de datos MySQL. Recuerdo por entonces MySQL Migration Toolkit, una herramienta para realizar...]]></description>
			<content:encoded><![CDATA[<p>Recuerdo instantes de mi pasado donde he tenido la necesidad de llevar Bases de Datos MDB, Microsoft Access, a bases de datos MySQL.</p>
<p>Recuerdo por entonces MySQL Migration Toolkit, una herramienta para realizar esta carga requerida. No obstante no era de mi agrado, y lo que buscaba por entonces era simplemente obtener un script SQL con el código DDL y DML necesario para el CREATE de los objetos de la base de datos y los INSERTs de los datos. A esa utilidad, hoy Linuxeando, le encontré el nombre: <strong><a href="http://mdbtools.sourceforge.net/">mdbtools</a></strong>.</p>
<p>MDBtools es un suite de herramientas (mdb-array mdb-header mdb-parsecsv mdb-schema mdb-tables mdb-export mdb-hexdump mdb-prop mdb-sql mdb-ver) que permiten, entre sus funciones, obtener  esquema de una base de datos y exportar en SQL los datos de la misma.</p>
<p><span id="more-1193"></span>Veamos un ejemplo básico y sencillo que consiste en:</p>
<ul>
<li>Exportar el diseño de la vieja y querida Neptuno.mdb (conocida base de datos distribuida como ejemplo con Microsoft Access) en formato de sentencias de definición de datos SQL.</li>
<li>Obtener el nombre de las tablas de la misma base de datos</li>
<li>Exportar los datos de cada tabla bajo la forma de INSERTs SQL.</li>
</ul>
<div class="syntax_hilite">
<div id="code-30">
<div class="code">$ sudo aptitude install mdbtools</p>
<p>$ mdb-schema Neptuno.<span style="">mdb</span> mysql&amp;gt; Neptuno_schema.<span style="">sql</span> #donde mysql se puede reemplazar por otro dialecto: oracle, sybase o postgres.</p>
<p>$ for tabla in `cat Neptuno_tables.<span style="">txt</span>`; do mdb-export -R \; -I Neptuno.<span style="">mdb</span> $<span style="color:#006600; font-weight:bold;">&#123;</span>tabla<span style="color:#006600; font-weight:bold;">&#125;</span>; done&amp;gt; Neptuno_data.<span style="">sql</span></p>
<p>$ rm Neptuno_tables.<span style="">txt</span></div>
</div>
</div>
<p></p>
<p>Fácil, sencillo y util&#8230; lástima que en mi caso llega tarde, no obstante en conocimiento perdura y nadie puede asegurarme que no me encuentre alguna vieja MDB en mi camino.</p>
<p>Vía: <a href="http://www.wikipeando.com/index.php/archives/481">Wikipeando</a></p>
<img src="http://feeds.feedburner.com/~r/luauf/~4/6MzG6H18oas" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://luauf.com/2011/09/12/exportar-una-base-de-datos-mdb-a-sql-mysql-oracle-sybase-etc/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		<feedburner:origLink>http://luauf.com/2011/09/12/exportar-una-base-de-datos-mdb-a-sql-mysql-oracle-sybase-etc/</feedburner:origLink></item>
		<item>
		<title>¿Cómo conectarse a MySQL desde un programa en C?</title>
		<link>http://feedproxy.google.com/~r/luauf/~3/NhUS4VgjhzU/</link>
		<comments>http://luauf.com/2011/07/09/%c2%bfcomo-conectarse-a-mysql-desde-un-programa-en-c/#comments</comments>
		<pubDate>Sat, 09 Jul 2011 18:01:54 +0000</pubDate>
		<dc:creator>Luciano</dc:creator>
				<category><![CDATA[Bases de Datos]]></category>
		<category><![CDATA[C]]></category>
		<category><![CDATA[MySQL]]></category>
		<category><![CDATA[Programación]]></category>
		<category><![CDATA[API]]></category>
		<category><![CDATA[C++]]></category>
		<category><![CDATA[librerias]]></category>

		<guid isPermaLink="false">http://luauf.com/?p=1192</guid>
		<description><![CDATA[La respuesta al título de esta publicación es muy sencilla, conectarse a MySQL desde C se realiza mediante una API provista por el mismo proveedor de base de datos. La API de C...]]></description>
			<content:encoded><![CDATA[<p>La respuesta al título de esta publicación es muy sencilla, conectarse a MySQL desde C se realiza mediante una API provista por el mismo proveedor de base de datos.</p>
<p>La API de C es ditribuida con MySQL, no es más que una librería (libmysqlclient) que interfacea entre el programa y la base de datos.</p>
<p>La documentación provista por MySQL es muy completa (<a href="http://dev.mysql.com/doc/refman/5.0/en/c.html">MySQL C API</a>), no obstante, fiel a nuestra costumbre iremos a un ejemplo sencillo y concreto.</p>
<p><span id="more-1192"></span>¿Qué necesitamos?</p>
<ul>
<li>Un servidor de base de datos MySQL, al cual conectarnos</li>
<li>Un programa cliente</li>
<li>La librería mysqlclient</li>
<li>mysql-devel, headers con la firma de la librería</li>
<li>gcc</li>
</ul>
<p>Con cualquier variante de UNIX más la instalación manual de la distribución binaria (tar.gz) tendremos todo lo que necesitamos. Caso contrario habrá que instalar los paquetes necesarios que incluya los requisitos mencionados, por ejemplo <strong>mysql-devel</strong>.</p>
<p>Primero, sin ir al detalle en concreto de cada línea (no cuesta nada interpretar el código, pues está bien comentado) veamos el siguiente fuente:</p>
<div class="syntax_hilite">
<div id="c-32">
<div class="c"><span style="color: #808080; font-style: italic;">/* mi_cliente */</span><br />
<span style="color: #339933;">#include</span><br />
<span style="color: #339933;">#include</span></p>
<p>main<span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#123;</span><br />
MYSQL *conn;<br />
MYSQL_RES *res;<br />
MYSQL_ROW row;</p>
<p><span style="color: #993333;">char</span> *server = <span style="color: #ff0000;">&#8220;localhost&#8221;</span>;<br />
<span style="color: #993333;">char</span> *user = <span style="color: #ff0000;">&#8220;root&#8221;</span>;<br />
<span style="color: #993333;">char</span> *password = <span style="color: #ff0000;">&#8220;PASSWORD&#8221;</span>; <span style="color: #808080; font-style: italic;">/* set me first */</span><br />
<span style="color: #993333;">char</span> *database = <span style="color: #ff0000;">&#8220;mysql&#8221;</span>;</p>
<p>conn = mysql_init<span style="color: #66cc66;">&#40;</span><span style="color: #000000; font-weight: bold;">NULL</span><span style="color: #66cc66;">&#41;</span>;</p>
<p><span style="color: #808080; font-style: italic;">/* Connect to database */</span><br />
<span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span>!mysql_real_connect<span style="color: #66cc66;">&#40;</span>conn, server,<br />
user, password, database, <span style="color: #cc66cc;">0</span>, <span style="color: #000000; font-weight: bold;">NULL</span>, <span style="color: #cc66cc;">0</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#123;</span><br />
fprintf<span style="color: #66cc66;">&#40;</span>stderr, <span style="color: #ff0000;">&#8220;%s<span style="color: #000099; font-weight: bold;">\n</span>&#8220;</span>, mysql_error<span style="color: #66cc66;">&#40;</span>conn<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>;<br />
exit<span style="color: #66cc66;">&#40;</span><span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span>;<br />
<span style="color: #66cc66;">&#125;</span></p>
<p><span style="color: #808080; font-style: italic;">/* send SQL query */</span><br />
<span style="color: #b1b100;">if</span> <span style="color: #66cc66;">&#40;</span>mysql_query<span style="color: #66cc66;">&#40;</span>conn, <span style="color: #ff0000;">&#8220;show tables&#8221;</span><span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span> <span style="color: #66cc66;">&#123;</span><br />
fprintf<span style="color: #66cc66;">&#40;</span>stderr, <span style="color: #ff0000;">&#8220;%s<span style="color: #000099; font-weight: bold;">\n</span>&#8220;</span>, mysql_error<span style="color: #66cc66;">&#40;</span>conn<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span>;<br />
exit<span style="color: #66cc66;">&#40;</span><span style="color: #cc66cc;">1</span><span style="color: #66cc66;">&#41;</span>;<br />
<span style="color: #66cc66;">&#125;</span></p>
<p>res = mysql_use_result<span style="color: #66cc66;">&#40;</span>conn<span style="color: #66cc66;">&#41;</span>;</p>
<p><span style="color: #808080; font-style: italic;">/* output table name */</span><br />
<a href="http://www.opengroup.org/onlinepubs/009695399/functions/printf.html"><span style="color: #000066;">printf</span></a><span style="color: #66cc66;">&#40;</span><span style="color: #ff0000;">&#8220;MySQL Tables in mysql database:<span style="color: #000099; font-weight: bold;">\n</span>&#8220;</span><span style="color: #66cc66;">&#41;</span>;<br />
<span style="color: #b1b100;">while</span> <span style="color: #66cc66;">&#40;</span><span style="color: #66cc66;">&#40;</span>row = mysql_fetch_row<span style="color: #66cc66;">&#40;</span>res<span style="color: #66cc66;">&#41;</span><span style="color: #66cc66;">&#41;</span> != <span style="color: #000000; font-weight: bold;">NULL</span><span style="color: #66cc66;">&#41;</span><br />
<a href="http://www.opengroup.org/onlinepubs/009695399/functions/printf.html"><span style="color: #000066;">printf</span></a><span style="color: #66cc66;">&#40;</span><span style="color: #ff0000;">&#8220;%s <span style="color: #000099; font-weight: bold;">\n</span>&#8220;</span>, row<span style="color: #66cc66;">&#91;</span><span style="color: #cc66cc;">0</span><span style="color: #66cc66;">&#93;</span><span style="color: #66cc66;">&#41;</span>;</p>
<p><span style="color: #808080; font-style: italic;">/* close connection */</span><br />
mysql_free_result<span style="color: #66cc66;">&#40;</span>res<span style="color: #66cc66;">&#41;</span>;<br />
mysql_close<span style="color: #66cc66;">&#40;</span>conn<span style="color: #66cc66;">&#41;</span>;<br />
<span style="color: #66cc66;">&#125;</span></div>
</div>
</div>
<p></p>
<p>Ahora si veamos la parte más interesa saber ¿cómo compilar?</p>
<p>Entre los argumentos a pasarle al gcc tenemos los directorios con las librerías, las librerías propiamente dichas, los directorios de encabezados (.h), y otras opciones más del compilador. Esto no representa ningún problema, menos aún con <a href="http://dev.mysql.com/doc/refman/5.0/en/mysql-config.html. mysql_config">mysql_config</a>  es un pequeño utilitario de MySQL que provee información para el compilador.</p>
<p>De esta forma:</p>
<ul>
<li><strong>mysql_config &#8211;libs</strong>: devuelve los path de las librerías y las librerías propiamente dichas a linkear.</li>
<li><strong>mysql_config &#8211;cflags</strong>: devuelve, entre otros argumentos, los path de los headers.</li>
</ul>
<p>Finalmente, podemos compilar de esta manera tan sencilla:</p>
<pre>$ gcc -o mi_cliente $(mysql_config --cflags) mi_cliente.c $(mysql_config --libs)</pre>
<p>Y luego ejecutar:</p>
<pre>$ ./mi_cliente</pre>
<p>Realmente, muy sencillo ¿no?</p>
<p>Vía: <a href="http://www.cyberciti.biz/tips/linux-unix-connect-mysql-c-api-program.html">nixCraft</a></p>
<img src="http://feeds.feedburner.com/~r/luauf/~4/NhUS4VgjhzU" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://luauf.com/2011/07/09/%c2%bfcomo-conectarse-a-mysql-desde-un-programa-en-c/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		<feedburner:origLink>http://luauf.com/2011/07/09/%c2%bfcomo-conectarse-a-mysql-desde-un-programa-en-c/</feedburner:origLink></item>
		<item>
		<title>Ya falta menos para Gnome 3</title>
		<link>http://feedproxy.google.com/~r/luauf/~3/B3rI8AG9OKs/</link>
		<comments>http://luauf.com/2011/01/26/ya-falta-menos-para-gnome-3/#comments</comments>
		<pubDate>Thu, 27 Jan 2011 00:54:37 +0000</pubDate>
		<dc:creator>Luciano</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Sistemas Operativos]]></category>
		<category><![CDATA[Gnome]]></category>
		<category><![CDATA[gnome shell]]></category>
		<category><![CDATA[GUI]]></category>
		<category><![CDATA[Shell]]></category>

		<guid isPermaLink="false">http://luauf.com/?p=1185</guid>
		<description><![CDATA[En medio de las vacaciones de verano del hemisferio sur, y entre tantas pobres noticias del mercado futbolero y automotriz; aparece en mis feeds GNOME 3 &#8211; Made of Easy. Fue esa lectura...]]></description>
			<content:encoded><![CDATA[<p>En medio de las vacaciones de verano del hemisferio sur, y entre tantas pobres noticias del mercado futbolero y automotriz; aparece en mis feeds <a href="http://gnome3.org/">GNOME 3 &#8211; Made of Easy</a>. Fue esa lectura la que me hizo recordar de Gnome 3, la esperada novedad que debería salir a la luz no antes de Abril del presente año&#8230; aunque de ahí a que llegue a las principales distros de Linux habrá que esperar algo más.</p>
<p><em>&#8220;El nuevo escritorio de GNOME eleva la elegancia a un nuevo nivel. Simple, bello, GNOME3 ha &lt;barrido&gt; el desorden existente para llegar a un escritorio sencillo, simple, facil de usar y más hermoso que nunca; con nuevo tema, nueva fuente y animaciones cuidadas.&#8221;</em></p>
<p style="text-align: center;"><a href="http://luauf.com/wp-content/uploads/2011/01/window-picker.png"><img class="aligncenter size-medium wp-image-1190" title="window-picker" src="http://luauf.com/wp-content/uploads/2011/01/window-picker-300x225.png" alt="" width="300" height="225" /></a></p>
<p>No obstante, ansioso, sin poder esperar su lanzamiento hice lo mismo que había echo tiempo atrás, <a href="http://gnome3.org/tryit.html">Try it out</a>!. El proceso es sencillo, bajar los fuentes y compilar&#8230; cosa que está bien <a href="http://live.gnome.org/GnomeShell#building">aqui</a>, que se resume en pocos pasos y que de no mediar problemas, <strong>apt-get install</strong>&#8216;s de por medio se resume en:</p>
<p><span id="more-1185"></span></p>
<ul>
<li>curl -O http://git.gnome.org/browse/gnome-shell/plain/tools/build/gnome-shell-build-setup.sh</li>
<li>/bin/bash gnome-shell-build-setup.sh</li>
<li>sudo rm -rf /usr/lib*/*.la</li>
<li>jhbuild build</li>
</ul>
<p>Finalmente, para ejecutar el nuevo shell:</p>
<ul>
<li>cd ~/gnome-shell/source/gnome-shell/src</li>
<li>sudo ./gnome-shell &#8211;replace</li>
</ul>
<p>Luego de eso, deberiamos poder empezar a disfrutar de un entorno nuevo, sencillo, cuidado y que representa la principal innovación en GNOME en años.</p>
<p><a href='http://luauf.com/2011/01/26/ya-falta-menos-para-gnome-3/app-picker/' title='app-picker'><img width="150" height="150" src="http://luauf.com/wp-content/uploads/2011/01/app-picker-150x150.png" class="attachment-thumbnail" alt="app-picker" title="app-picker" /></a><br />
<a href='http://luauf.com/2011/01/26/ya-falta-menos-para-gnome-3/overview-big/' title='overview-big'><img width="150" height="150" src="http://luauf.com/wp-content/uploads/2011/01/overview-big-150x150.png" class="attachment-thumbnail" alt="overview-big" title="overview-big" /></a><br />
<a href='http://luauf.com/2011/01/26/ya-falta-menos-para-gnome-3/search-big/' title='search-big'><img width="150" height="150" src="http://luauf.com/wp-content/uploads/2011/01/search-big-150x150.png" class="attachment-thumbnail" alt="search-big" title="search-big" /></a><br />
<a href='http://luauf.com/2011/01/26/ya-falta-menos-para-gnome-3/search-results/' title='search-results'><img width="150" height="150" src="http://luauf.com/wp-content/uploads/2011/01/search-results-150x150.png" class="attachment-thumbnail" alt="search-results" title="search-results" /></a><br />
<a href='http://luauf.com/2011/01/26/ya-falta-menos-para-gnome-3/window-picker/' title='window-picker'><img width="150" height="150" src="http://luauf.com/wp-content/uploads/2011/01/window-picker-150x150.png" class="attachment-thumbnail" alt="window-picker" title="window-picker" /></a></p>
<img src="http://feeds.feedburner.com/~r/luauf/~4/B3rI8AG9OKs" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://luauf.com/2011/01/26/ya-falta-menos-para-gnome-3/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		<feedburner:origLink>http://luauf.com/2011/01/26/ya-falta-menos-para-gnome-3/</feedburner:origLink></item>
		<item>
		<title>Borrar los archivos de más de N días (en Windows)</title>
		<link>http://feedproxy.google.com/~r/luauf/~3/pGvn8Fng2BQ/</link>
		<comments>http://luauf.com/2010/12/04/borrar-los-archivos-de-mas-de-n-dias-en-windows/#comments</comments>
		<pubDate>Sat, 04 Dec 2010 19:19:03 +0000</pubDate>
		<dc:creator>Luciano</dc:creator>
				<category><![CDATA[Miscelaneas]]></category>
		<category><![CDATA[Programación]]></category>
		<category><![CDATA[Sistemas Operativos]]></category>
		<category><![CDATA[Windows]]></category>
		<category><![CDATA[bat]]></category>
		<category><![CDATA[borrar archivos]]></category>
		<category><![CDATA[purgar]]></category>
		<category><![CDATA[script]]></category>
		<category><![CDATA[shell script]]></category>

		<guid isPermaLink="false">http://luauf.com/?p=1184</guid>
		<description><![CDATA[Las publicaciones al blog son cada vez más esporádicas, no por eso poco importantes. Es decir, aveces prefiero publicar poco y útil antes que periódico e inservible. En este caso, quiero aportar a...]]></description>
			<content:encoded><![CDATA[<p>Las publicaciones al blog son cada vez más esporádicas, no por eso poco importantes. Es decir, aveces prefiero publicar poco y útil antes que periódico e inservible.</p>
<p>En este caso, quiero aportar a este blog (mi humilde base de conocimientos) una forma muy sencilla de eliminar archivos de más de N de días de antigüedad en forma automática (ideal para ejecutar por el programador de tareas), algo muy útil para purgar logs o borrar temporales inútiles. En mi caso, fue utilizado para eliminar imágenes periódicas de una cámara IP (JPEG posting) que al final del día unía en un video diario.</p>
<p style="text-align: center;">
<p>Luego de buscar y buscar y estando a punto de escribir un Windows shell script bastante artesanal me encontré con <a href="http://ss64.com/nt/forfiles.html">FORFILES</a>, un <a href="http://ss64.com/nt/">comando de Windows</a>, que permite de una forma sencilla de seleccionar uno o más archivos y ejecutar un comando sobre los mismos.</p>
<p><span id="more-1184"></span><br />
Está de más decir que lo primero que deberías hacer es ver como funciona FORFILES:</p>
<div class="syntax_hilite">
<div id="code-35">
<div class="code">forfiles /?</div>
</div>
</div>
<p></p>
<p>De todas formas, si eres algo perezoso, aquí va la solución al problema que da título a esta presentación:</p>
<div class="syntax_hilite">
<div id="code-36">
<div class="code">forfiles -p <span style="color:#CC0000;">&#8220;C:<span style="color:#000099; font-weight:bold;">\d</span>onde<span style="color:#000099; font-weight:bold;">\e</span>sten<span style="color:#000099; font-weight:bold;">\t</span>us<span style="color:#000099; font-weight:bold;">\a</span>rchivos&#8221;</span> -s -m *.* -d -c <span style="color:#CC0000;">&#8220;cmd /c del @path&#8221;</span></div>
</div>
</div>
<p></p>
<p>Vía: <a href="http://stackoverflow.com/questions/51054/batch-file-to-delete-files-older-than-n-days">stackoverflow</a></p>
<img src="http://feeds.feedburner.com/~r/luauf/~4/pGvn8Fng2BQ" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://luauf.com/2010/12/04/borrar-los-archivos-de-mas-de-n-dias-en-windows/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		<feedburner:origLink>http://luauf.com/2010/12/04/borrar-los-archivos-de-mas-de-n-dias-en-windows/</feedburner:origLink></item>
		<item>
		<title>Hojas de referencia de comandos de UNIX, vi/vim, etc.</title>
		<link>http://feedproxy.google.com/~r/luauf/~3/Qf_zfPcJqKo/</link>
		<comments>http://luauf.com/2010/09/27/hojas-de-referencia-de-comandos-de-unix-vivim-etc/#comments</comments>
		<pubDate>Mon, 27 Sep 2010 11:00:14 +0000</pubDate>
		<dc:creator>Luciano</dc:creator>
				<category><![CDATA[Miscelaneas]]></category>
		<category><![CDATA[UNIX]]></category>
		<category><![CDATA[cheat sheet]]></category>
		<category><![CDATA[Comandos]]></category>
		<category><![CDATA[hojas de referencia]]></category>
		<category><![CDATA[jQuery]]></category>
		<category><![CDATA[rgb]]></category>
		<category><![CDATA[vi]]></category>
		<category><![CDATA[vim]]></category>

		<guid isPermaLink="false">http://luauf.com/?p=1178</guid>
		<description><![CDATA[Y un día volví&#8230; y como no podía ser de otra manera con las clásicas hojas de referencia, para imprimir y tener a nuestro lado en los escritorios. Como lo más destacado de...]]></description>
			<content:encoded><![CDATA[<p>Y un día volví&#8230; y como no podía ser de otra manera con las clásicas hojas de referencia, para imprimir y tener a nuestro lado en los escritorios.</p>
<p>Como lo más destacado de este post, les dejo una cheatsheet de comandos de UNIX.</p>
<p style="text-align: center;"><a href="http://luauf.com/wp-content/uploads/2010/09/unix_commands_cheatsheet.jpg"><img class="aligncenter size-thumbnail wp-image-1179" title="unix_commands_cheatsheet" src="http://luauf.com/wp-content/uploads/2010/09/unix_commands_cheatsheet-150x150.jpg" alt="" width="150" height="150" /></a></p>
<p style="text-align: center;">
<p><span id="more-1178"></span>Y como plus, algunas cheatsheet varias, de esas que encontrarás miles en Internet. Son una hoja de referencia de vi/vim (a menos que trabajes hace tiempo con vi o vim, esta hoja te será muy útil inclusive para saber como salir del editor <img src='http://luauf.com/wp-includes/images/smilies/icon_wink.gif' alt=';-)' class='wp-smiley' />  ).</p>
<p style="text-align: center;"><a href="http://luauf.com/wp-content/uploads/2010/09/vi-vim-cheat-sheet.gif"><img class="aligncenter size-medium wp-image-1180" title="vi-vim-cheat-sheet" src="http://luauf.com/wp-content/uploads/2010/09/vi-vim-cheat-sheet-300x212.gif" alt="" width="300" height="212" /></a></p>
<p>Y además, otras dos hojas acerca de las equivalencias en colores RGB/Hexadecimal (para imprimir a colores) y otra de JQuery, estas últimas dos para webmasters por sobre todas las cosas.</p>
<p style="text-align: center;"><a href="http://luauf.com/wp-content/uploads/2010/09/rgb-hex-cheat-sheet-v1.png"><img class="aligncenter size-medium wp-image-1181" title="rgb-hex-cheat-sheet-v1" src="http://luauf.com/wp-content/uploads/2010/09/rgb-hex-cheat-sheet-v1-220x300.png" alt="" width="220" height="300" /></a></p>
<p style="text-align: center;"><a href="http://luauf.com/wp-content/uploads/2010/09/Jquery-Cheat-Sheet-1.2.png"><img class="aligncenter size-medium wp-image-1182" title="Jquery-Cheat-Sheet-1.2" src="http://luauf.com/wp-content/uploads/2010/09/Jquery-Cheat-Sheet-1.2-300x225.png" alt="" width="300" height="225" /></a></p>
<p>Vía: <a href="http://www.pixelbeat.org/cmdline.html">PixelBeat</a></p>
<img src="http://feeds.feedburner.com/~r/luauf/~4/Qf_zfPcJqKo" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://luauf.com/2010/09/27/hojas-de-referencia-de-comandos-de-unix-vivim-etc/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		<feedburner:origLink>http://luauf.com/2010/09/27/hojas-de-referencia-de-comandos-de-unix-vivim-etc/</feedburner:origLink></item>
		<item>
		<title>Usar discos reales en Virtualbox</title>
		<link>http://feedproxy.google.com/~r/luauf/~3/YWxXhukzUSY/</link>
		<comments>http://luauf.com/2010/05/10/usar-discos-reales-en-virtualbox/#comments</comments>
		<pubDate>Mon, 10 May 2010 11:00:50 +0000</pubDate>
		<dc:creator>Luciano</dc:creator>
				<category><![CDATA[Linux]]></category>
		<category><![CDATA[Miscelaneas]]></category>
		<category><![CDATA[Sistemas Operativos]]></category>
		<category><![CDATA[Virtualización]]></category>
		<category><![CDATA[virtual box]]></category>
		<category><![CDATA[vmware]]></category>

		<guid isPermaLink="false">http://luauf.com/?p=1176</guid>
		<description><![CDATA[Un tip para tener a mano que resuelve las siguientes dos cuestiones: Virtualizar un Sistema Operativo ya instalado en una partición existente Crear un nuevo disco virtual en Virtualbox que apunte a una...]]></description>
			<content:encoded><![CDATA[<p><a href="http://luauf.com/wp-content/uploads/2010/05/virtualboxlogo.png"><br />
</a>Un tip para tener a mano que resuelve las siguientes dos cuestiones:</p>
<ul>
<li>Virtualizar un Sistema Operativo ya instalado en una partición existente</li>
</ul>
<ul>
<li>Crear un nuevo disco virtual en Virtualbox que apunte a una partición, sobre la cual se instalará un Sistema Operativo (desde una máquina virtual) y que luego se utilizará sin virtualizar.</li>
</ul>
<p><span id="more-1176"></span></p>
<p><a href="http://luauf.com/wp-content/uploads/2010/05/virtualboxlogo.png"><img class="aligncenter" title="virtualboxlogo" src="http://luauf.com/wp-content/uploads/2010/05/virtualboxlogo-290x300.png" alt="" width="290" height="300" /></a></p>
<p>Bien, para uno u otro fin necesitamos crear un disco virtual (<strong>.vmdk</strong>) pero que &#8220;apunte&#8221; a una partición real. Para el primer objetivo la partición existe y ya tiene un Sistema Operativo instalado. Para el segundo objetivo debemos, al menos, crear la partición (sin necesidad de formatear ni nada, simplemente crear la partición, puedes valerte de Gparted para esta tarea).</p>
<p>Finalmente, creamos el &#8220;link&#8221;:</p>
<p>$ VBoxManage internalcommands createrawvmdk -filename /path/to/file.vmdk -rawdisk /dev/sda -relative -register</p>
<p>Vía: <a href="http://crysol.org/es/node/1275">CRySoL</a></p>
<div></div>
<img src="http://feeds.feedburner.com/~r/luauf/~4/YWxXhukzUSY" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://luauf.com/2010/05/10/usar-discos-reales-en-virtualbox/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		<feedburner:origLink>http://luauf.com/2010/05/10/usar-discos-reales-en-virtualbox/</feedburner:origLink></item>
		<item>
		<title>¿Como conocer mi IP privada y mi IP pública?</title>
		<link>http://feedproxy.google.com/~r/luauf/~3/54nbYYhZPyI/</link>
		<comments>http://luauf.com/2010/04/24/%c2%bfcomo-conocer-mi-ip-privada-y-mi-ip-publica/#comments</comments>
		<pubDate>Sun, 25 Apr 2010 02:07:31 +0000</pubDate>
		<dc:creator>Luciano</dc:creator>
				<category><![CDATA[Bash]]></category>
		<category><![CDATA[BSD]]></category>
		<category><![CDATA[Linux]]></category>
		<category><![CDATA[Programación]]></category>
		<category><![CDATA[Sistemas Operativos]]></category>
		<category><![CDATA[UNIX]]></category>
		<category><![CDATA[awk]]></category>
		<category><![CDATA[bash]]></category>
		<category><![CDATA[cut]]></category>
		<category><![CDATA[ifconfig]]></category>
		<category><![CDATA[IP]]></category>
		<category><![CDATA[ip privada]]></category>
		<category><![CDATA[ip publica]]></category>
		<category><![CDATA[Redes]]></category>
		<category><![CDATA[script]]></category>
		<category><![CDATA[sed]]></category>
		<category><![CDATA[shell script]]></category>
		<category><![CDATA[Shell scripts]]></category>
		<category><![CDATA[wget]]></category>

		<guid isPermaLink="false">http://luauf.com/?p=1173</guid>
		<description><![CDATA[¿Como conocer mi IP privada y mi IP pública?, esa es la cuestión. Vamos a ver un pequeño script para lograr este propósito utilizando algunos comandos ya vistos y utilizados en la historia...]]></description>
			<content:encoded><![CDATA[<p>¿Como conocer mi IP privada y mi IP pública?, esa es la cuestión.</p>
<p>Vamos a ver un pequeño script para lograr este propósito utilizando algunos comandos ya vistos y utilizados en la historia de este blog con varios distintos propósitos (<a href="http://luauf.com/2009/03/26/ejemplos-de-como-configurar-la-interfaz-de-red-mediante-ifconfig/">ifconfig</a>, <a href="http://luauf.com/2009/05/04/varios-ejemplos-de-uso-del-comando-grep/">grep</a>, <a href="http://luauf.com/2009/04/12/descargar-videos-de-youtube-de-la-forma-mas-facil/">cut</a>, <a href="http://luauf.com/2008/04/02/top-5-de-los-comandos-mas-utilizados/">awk</a>, <a href="http://luauf.com/2008/04/15/descargar-un-sitio-web-completo/">wget</a>, <a href="http://luauf.com/2010/02/22/reemplazar-cadenas-en-archivos-con-sed/">sed</a>)</p>
<p align="center"><img class="aligncenter size-full wp-image-1174" title="terminal" src="http://luauf.com/wp-content/uploads/2010/04/terminal.png" alt="" width="128" height="128" /></p>
<p><span id="more-1173"></span></p>
<p>Primero, para obtener mi IP local (privada) puedo hacerlo mediante <a href="http://luauf.com/2009/03/26/ejemplos-de-como-configurar-la-interfaz-de-red-mediante-ifconfig/">ifconfig</a>, ahora, con la ayuda de <a href="http://luauf.com/2009/05/04/varios-ejemplos-de-uso-del-comando-grep/">grep</a>, <a href="http://luauf.com/2008/04/02/top-5-de-los-comandos-mas-utilizados/">awk</a> y <a href="http://luauf.com/2009/04/12/descargar-videos-de-youtube-de-la-forma-mas-facil/">cut</a> quitaré todo lo que sobra para obtener <strong>solo</strong> la IP.</p>
<div class="syntax_hilite">
<div id="code-39">
<div class="code">ifconfig | grep <span style="color:#CC0000;">&#8216;inet:&#8217;</span>| grep -v <span style="color:#CC0000;">&#8217;127.0.0.1&#8242;</span> | cut -d: -f2 | awk <span style="color:#CC0000;">&#8216;{print $1}&#8217;</span></div>
</div>
</div>
<p></p>
<p>Segundo, con la ayuda de un sitio web  y <a href="http://luauf.com/2008/04/15/descargar-un-sitio-web-completo/">wget</a> obtendré mi IP pública, IP otorgada por el servidor de Internet al conectarme, por lo general es dinámica (a menos que paguemos a nuestro ISP por una IP fija). Al resultado obtenido con la ayuda de <a href="http://luauf.com/2010/02/22/reemplazar-cadenas-en-archivos-con-sed/">sed</a> le dejaré tan <strong>solo</strong> la IP.</p>
<div class="syntax_hilite">
<div id="code-40">
<div class="code">wget -q -O &#8211; checkip.<span style="">dyndns</span>.<span style="">org</span>|sed -e <span style="color:#CC0000;">&#8216;s/.*Current IP Address://&#8217;</span> -e <span style="color:#CC0000;">&#8216;s/ </span></div>
</div>
</div>
<p></p>
<p>Vía: <a href="http://belinuxmyfriend.blogspot.com/2010/04/saber-la-ip-de-red-y-publica-con-un.html">Be Linux my Friend</a></p>
<img src="http://feeds.feedburner.com/~r/luauf/~4/54nbYYhZPyI" height="1" width="1"/>]]></content:encoded>
			<wfw:commentRss>http://luauf.com/2010/04/24/%c2%bfcomo-conocer-mi-ip-privada-y-mi-ip-publica/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		<feedburner:origLink>http://luauf.com/2010/04/24/%c2%bfcomo-conocer-mi-ip-privada-y-mi-ip-publica/</feedburner:origLink></item>
	</channel>
</rss>

