<?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/"
	xmlns:itunes="http://www.itunes.com/dtds/podcast-1.0.dtd"
	xmlns:media="http://search.yahoo.com/mrss/"
>

<channel>
	<title>Leandro Nunes dos Santos &#187; config</title>
	<atom:link href="http://www.leandronunes.net/tag/config/feed/" rel="self" type="application/rss+xml" />
	<link>http://www.leandronunes.net</link>
	<description>Just another WordPress weblog</description>
	<lastBuildDate>Fri, 11 Feb 2011 11:29:55 +0000</lastBuildDate>
	<generator>http://wordpress.org/?v=2.9.2</generator>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
		<!-- podcast_generator="podPress/8.8" - maintenance_release="8.8.4" -->
		<copyright>Copyright &#xA9; Leandro Nunes dos Santos 2010 </copyright>
		<managingEditor>leandronunes@gmail.com (Leandro Nunes dos Santos)</managingEditor>
		<webMaster>leandronunes@gmail.com (Leandro Nunes dos Santos)</webMaster>
		<category>posts</category>
		<itunes:keywords></itunes:keywords>
		<itunes:subtitle></itunes:subtitle>
		<itunes:summary>Just another WordPress weblog</itunes:summary>
		<itunes:author>Leandro Nunes dos Santos</itunes:author>
		<itunes:category text="Society &amp; Culture"/>
		<itunes:owner>
			<itunes:name>Leandro Nunes dos Santos</itunes:name>
			<itunes:email>leandronunes@gmail.com</itunes:email>
		</itunes:owner>
		<itunes:block>No</itunes:block>
		<itunes:explicit>no</itunes:explicit>
		<itunes:image href="http://www.leandronunes.net/wp-content/plugins/podpress/images/powered_by_podpress_large.jpg" />
		<image>
			<url>http://www.leandronunes.net/wp-content/plugins/podpress/images/powered_by_podpress.jpg</url>
			<title>Leandro Nunes dos Santos</title>
			<link>http://www.leandronunes.net</link>
			<width>144</width>
			<height>144</height>
		</image>
		<item>
		<title>Movendo banco de dados mysql corretamente</title>
		<link>http://www.leandronunes.net/2009/06/movendo-banco-de-dados-mysql-corretamente/</link>
		<comments>http://www.leandronunes.net/2009/06/movendo-banco-de-dados-mysql-corretamente/#comments</comments>
		<pubDate>Tue, 02 Jun 2009 17:50:31 +0000</pubDate>
		<dc:creator>Leandro Nunes</dc:creator>
				<category><![CDATA[banco de dados]]></category>
		<category><![CDATA[config]]></category>
		<category><![CDATA[database]]></category>
		<category><![CDATA[mysql]]></category>

		<guid isPermaLink="false">http://www.leandronunes.net/?p=68</guid>
		<description><![CDATA[Algumas vezes eu preciso rodar um banco mysql que eu copiei de um computador para outro e existem alguns detalhes que se você não prestar atenção você pode acabar perdendo muito tempo em pequenas besteiras.
Primeiro só utilize as dicas deste post caso você tenha um banco de dados muito grande, onde dump do banco leve [...]]]></description>
			<content:encoded><![CDATA[<p>Algumas vezes eu preciso rodar um banco mysql que eu copiei de um computador para outro e existem alguns detalhes que se você não prestar atenção você pode acabar perdendo muito tempo em pequenas besteiras.</p>
<p>Primeiro só utilize as dicas deste post caso você tenha um banco de dados muito grande, onde dump do banco leve bastante tempo para ser gerado. </p>
<p>Caso contrário basta você digitar o comando:</p>
<p><code><br />
   mysqldump -u user -p password database_name > database_dump.sql<br />
</code></p>
<p>no computador que você quer extrair o <em>dump</em> e depois o comando abaixo:</p>
<p><code><br />
  mysql database_name < database_dump.sql<br />
</code></p>
<p>no computador que você deseja armazenar o novo banco de dados.</p>
<p>Mas se este não é o seu caso e você possui uma base de 10gb ou mais, gerar o dump de uma bases dessas é muito complicado, pois demora muito e as vezes copiar todo o banco num pendrive e substituir os arquivos no novo computador vale mais a pena.</p>
<p>Então para isso basta copiar a pasta  '/var/lib/mysql'  para um pendrive, e tem que ser um pendrive grande já que isso só é aconselhável quando se está manipulando bases muito grandes <img src='http://www.leandronunes.net/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> , e depois substituir a pasta '/var/lib/mysql' do servidor no qual você quer que o banco de dados rode por esta pasta copiada.</p>
<p>É aconselhável fazer um bakcup da pasta /var/lib/mysql antes de substituir os arquivos. Assim você poderá repetir este processo e rodar o antigo banco de dados novamente.</p>
<p>No meu caso ficou assim:</p>
<p></code><code></p>
<p>No computador 1<br />
root@barker:~/$ cp -r /var/lib/mysql /media/disk-1</p>
<p>No computador 2<br />
root@smurf:~/$ mv /var/lib/mysql /var/lib/mysql.orig<br />
root@smurf:~/$ cp -r /media/disk-4/mysql /var/lib</p>
<p></code></p>
<p>Antes de rodar este comando no &#8216;Computador 2&#8242; pare o apache.</p>
<p><code><br />
/etc/init.d/apache stop<br />
</code></p>
<p>Observe que para fazer a cópia dos arquivos você terá que ter acesso ao <em>root</em> do computador.</p>
<p>Ao realizar a cópia, as pastas terão permissão somente para o usuário root, então rode o comando:</p>
<p><code><br />
chown mysql.mysql /var/lib/mysql -R<br />
</code></p>
<p>Agora o usuário mysql terá permissão para acessar os arquivos.</p>
<p>Se você tentar inicializar o apache novamente terá o seguinte problema:</p>
<p><code><br />
root@smurf:/var/lib# /etc/init.d/mysql start<br />
Starting MySQL database server: mysqld ..<br />
Checking for corrupt, not cleanly closed and upgrade needing tables..<br />
/usr/bin/mysqladmin: connect to server at 'localhost' failed<br />
error: 'Access denied for user 'debian-sys-maint'@'localhost' (using password: YES)'<br />
root@smurf:/var/lib# ERROR 1045 (28000): Access denied for user 'debian-sys-maint'@'localhost' (using password: YES)<br />
</code></p>
<p>Este erro ocorre pois você copiou a pasta do mysql de um outro computador que possuía configurações específicas daquele computador. Neste caso a configuração em questão é a senha do usuário do banco debian-sys-maint que é o usuário que o sistema operacional utiliza para realizar algumas operações no banco.</p>
<p>O usuário debian-sys-maint é como se fosse o usuário root do banco. Ele é utilizado para realizar executar certos scripts de manutenção no Debian.</p>
<p>Abaixo segue uma breve descrição deste usuário encontrada no arquivo README.Debian:</p>
<blockquote><p>
* MYSQL WON&#8217;T START OR STOP?:<br />
=============================</p>
<p>You may never ever delete the special mysql user &#8220;debian-sys-maint&#8221;.<br />
This user together with the credentials in /etc/mysql/debian.cnf are used by the init  scripts to stop the server as they would require knowledge of the mysql root  users password else.
</p></blockquote>
<p>Então para que o banco possa inicializar corretamente eu preciso dar acesso ao usuário debian-sys-maint ao banco. O Debian utiliza este usuário com a senha definida no arquivo &#8216;/etc/mysql/debian.cnf&#8217;.</p>
<p><code><br />
[client]<br />
host     = localhost<br />
user     = debian-sys-maint<br />
password = ********************<br />
socket   = /var/run/mysqld/mysqld.sock<br />
[mysql_upgrade]<br />
user     = debian-sys-maint<br />
password =  ********************<br />
socket   = /var/run/mysqld/mysqld.sock<br />
basedir  = /usr<br />
</code></p>
<p>Então precisamos modificar a senha do usuário &#8216;debian-sys-maint&#8217; pela senha contida neste arquivo.</p>
<p>Se você não tiver nenhum acesso ao banco, ou seja, nenhum login e senha de usuário para poder modificar a senha do usuário debian-sys-maint então continue lendo o post caso contrário leia também <img src='http://www.leandronunes.net/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> .</p>
<p>Reinicie o mysql com o comando:</p>
<p><code><br />
/usr/bin/mysqld_safe --skip-grant-tables &#038;<br />
</code></p>
<p>Logue no console mysql:</p>
<p><code><br />
root@smurf:# mysql<br />
</code></p>
<p>E modifique as permissões do usuário &#8216;root&#8217; e do usuário &#8216;debian-sys-maint&#8217;. Assim você terá acesso ao banco com o usuário &#8216;root&#8217; também.</p>
<p><code><br />
mysql> UPDATE mysql.user SET Password=PASSWORD('password')    WHERE User='root';<br />
mysql>  FLUSH PRIVILEGES;<br />
mysql> GRANT ALL PRIVILEGES ON *.* TO 'debian-sys-maint'@'localhost' IDENTIFIED BY 'password' WITH GRANT OPTION;<br />
mysql>  FLUSH PRIVILEGES;</p>
<p></code></p>
<p>Substitua a palavra password pelo password que você encontrou no arquivo &#8216;/etc/mysql/debian.cnf&#8217;</p>
<p>Agora basta derrubar o servidor e carregá-lo novamente.</p>
<p><code><br />
  /etc/init.d/mysql stop<br />
  /etc/init.d/mysql start<br />
</code></p>
<p>Não  use o comando &#8216;/etc/init.d/mysql restart&#8217; pois o mysql poderá iniciar com a opção &#8216;&#8211;skip-grant-tables&#8217;  e você não quer isso <img src='http://www.leandronunes.net/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
<p>E tudo funcionará bem agora, pelo menos em teoria <img src='http://www.leandronunes.net/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
]]></content:encoded>
			<wfw:commentRss>http://www.leandronunes.net/2009/06/movendo-banco-de-dados-mysql-corretamente/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Configurando o git depois do import</title>
		<link>http://www.leandronunes.net/2009/05/configurando-o-git-depois-do-import/</link>
		<comments>http://www.leandronunes.net/2009/05/configurando-o-git-depois-do-import/#comments</comments>
		<pubDate>Thu, 28 May 2009 13:51:19 +0000</pubDate>
		<dc:creator>Leandro Nunes</dc:creator>
				<category><![CDATA[git]]></category>
		<category><![CDATA[config]]></category>

		<guid isPermaLink="false">http://www.leandronunes.net/?p=62</guid>
		<description><![CDATA[Eu utilizo o gitosis para gerenciar os meus repositórios git e dei os meus primeiros passos para configurá-lo da forma correta seguido o tutorial hosting-git-repositories-the-easy-and-secure-way.
Antigamente ao adicionar um repositório novo eu tinha um problema.
Eu seguia todos os passos descritos no tutorial para adicionar  um novo repositório, e ao dar um pull  eu recebia [...]]]></description>
			<content:encoded><![CDATA[<p>Eu utilizo o gitosis para gerenciar os meus repositórios git e dei os meus primeiros passos para configurá-lo da forma correta seguido o tutorial <a href="http://scie.nti.st/2007/11/14/hosting-git-repositories-the-easy-and-secure-way">hosting-git-repositories-the-easy-and-secure-way</a>.</p>
<p>Antigamente ao adicionar um repositório novo eu tinha um problema.</p>
<p>Eu seguia todos os passos descritos no tutorial para adicionar  um novo repositório, e ao dar um <em>pull</em>  eu recebia a seguinte mensagem de erro:</p>
<p><code><br />
smurf@smurf:~/safernet/projetos/snscripts$ git pull<br />
You asked me to pull without telling me which branch you<br />
want to merge with, and 'branch.master.merge' in<br />
your configuration file does not tell me either.  Please<br />
name which branch you want to merge on the command line and<br />
try again (e.g. 'git pull <repository> <refspec>').<br />
See git-pull(1) for details on the refspec.</p>
<p>If you often merge with the same branch, you may want to<br />
configure the following variables in your configuration<br />
file:</p>
<p>    branch.master.remote = <nickname><br />
    branch.master.merge = <remote -ref><br />
    remote.<nickname>.url = <url><br />
    remote.<nickname>.fetch = <refspec><br />
</refspec></nickname></url></nickname></remote></nickname></refspec></repository></code></p>
<p>Abrindo o arquivo de configuração do git (.git/config) eu notei que não existiam as informações do <em>branch master</em> que eu estava trabalhando no momento.<br />
<code><br />
[core]<br />
	repositoryformatversion = 0<br />
	filemode = true<br />
	bare = false<br />
	logallrefupdates = true<br />
[remote "origin"]<br />
	url = git@host.com.br:project_name.git<br />
	fetch = +refs/heads/*:refs/remotes/origin/*<br />
</code></p>
<p>Então eu editei o arquivo .git/config adicionando as informações do branch master:</p>
<p><code><br />
[core]<br />
	repositoryformatversion = 0<br />
	filemode = true<br />
	bare = false<br />
	logallrefupdates = true<br />
[remote "origin"]<br />
	url = git@host.com.br:project_name.git<br />
	fetch = +refs/heads/*:refs/remotes/origin/*<br />
[branch "master"]<br />
   remote = origin<br />
   merge = refs/heads/master<br />
</code></p>
<p>Pronto.</p>
<p>Agora será possível dar um <em>pull</em> normalmente.</p>
<p><code><br />
smurf@smurf:~/safernet/projetos/snscripts$ git pull<br />
Already up-to-date.<br />
</code></p>
<p>Não sei se esta é a melhor forma de resolver o problema, mas é a que eu utilizo. </p>
<p>Espero que seja útil para alguém <img src='http://www.leandronunes.net/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
]]></content:encoded>
			<wfw:commentRss>http://www.leandronunes.net/2009/05/configurando-o-git-depois-do-import/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Utilizando as opções do ssh</title>
		<link>http://www.leandronunes.net/2009/04/utilizando-as-opcoes-do-ssh/</link>
		<comments>http://www.leandronunes.net/2009/04/utilizando-as-opcoes-do-ssh/#comments</comments>
		<pubDate>Wed, 15 Apr 2009 02:53:27 +0000</pubDate>
		<dc:creator>Leandro Nunes</dc:creator>
				<category><![CDATA[linux]]></category>
		<category><![CDATA[config]]></category>
		<category><![CDATA[ssh]]></category>

		<guid isPermaLink="false">http://www.leandronunes.net/?p=28</guid>
		<description><![CDATA[Eu não gosto muito de fazer trabalhos repetitivos, então quando eu percebo que alguma atividade tem o potencial de se tornar repetitiva e entediante trato de arranjar um jeito de automatizar o processo  
Claro que algumas vezes eu acabo levando mais tempo automatizando a tarefa do que repentindo-a. Entretanto no somatório de de tempo [...]]]></description>
			<content:encoded><![CDATA[<p>Eu não gosto muito de fazer trabalhos repetitivos, então quando eu percebo que alguma atividade tem o potencial de se tornar repetitiva e entediante trato de arranjar um jeito de automatizar o processo <img src='http://www.leandronunes.net/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
<p>Claro que algumas vezes eu acabo levando mais tempo automatizando a tarefa do que repentindo-a. Entretanto no somatório de de tempo que seria gasto para se realizar a tarefa quando o tempo tende a infinito, eu acabo economizando muito tempo de minha vida que seria gasto em coisas não tão interessantes <img src='http://www.leandronunes.net/wp-includes/images/smilies/icon_wink.gif' alt=';)' class='wp-smiley' /> </p>
<p>A bola da vez é a necessidade de se executar o comando &#8217;ssh&#8217; diversas vezes com diversos parâmetros diferentes. </p>
<p>Pesquisando um pouco encontrei um forma de otimizar meu tempo.</p>
<p>Se você criar um arquivo de nome &#8216;config&#8217; na pasta &#8216;.ssh&#8217; no seu home o ssh carrega este arquivo e procura por opções de configuração que você deseje criar. </p>
<p>Então:<br />
<code><br />
   mkdir "~/.ssh"<br />
   vim "~/.ssh/config"<br />
</code></p>
<p>Agora basta configurar o arquivo de acordo com a sua necessidade.</p>
<p>No meu caso utilizei os seguintes parâmetros de configuração:</p>
<p><code><br />
Host leandro<br />
User smurf<br />
Port 22<br />
HostName leandronunes.net</p>
<p>Host servidor<br />
User root<br />
Port 3021<br />
HostName servidor.com.br</p>
<p>Host proxy<br />
User smurf<br />
Port 2299<br />
HostName app.dcc.ufba.br<br />
LocalForward 3128 app.dcc.ufba.br:8080<br />
</code></p>
<p>No primeiro caso:<br />
<code><br />
Host leandro<br />
User smurf<br />
Port 22<br />
HostName leandronunes.net<br />
</code><br />
Eu ganho a possibilidade de acessar meu servidor apenas digitando o comando:<br />
<code><br />
  ssh leandro<br />
</code></p>
<p>O ssh lerá o arquivo &#8216;~/.ssh/config&#8217; e saberá que eu quero acessar o servidor leandronunes.net, com o usuário smurf e utilizando a porta 22.</p>
<p>O segundo caso é semelhante ao caso anterior só que desta vez eu escolho outra porta para acessar o meu servidor cujo host é servidor.com.br</p>
<p>Eu acesso o servidor com o comando:<br />
<code><br />
  ssh servidor<br />
</code></p>
<p>O terceiro e último exemplo é mais legalzinho.<br />
<code><br />
Host proxy<br />
User smurf<br />
Port 2139<br />
HostName ufba.br<br />
LocalForward 2148 ufba.br:7070<br />
</code></p>
<p>Eu posso acessar o servidor da <a href="http://www.ufba.br">UFBa</a>, que utilizo como proxy para acessar o <a href="http://periodicos.capes.gov.br">periódicos da capes</a> de casa, com o seguinte comando:<br />
<code><br />
   ssh proxy<br />
</code></p>
<p>Somente com isso, o ssh já entende que é para fazer um tunel ssh da minha porta &#8216;2148&#8242; para a porta &#8216;7070&#8242; do meu host &#8216;ufba.br&#8217;, que eu acesso utilizando o usuário &#8217;smurf&#8217; na porta &#8216;2139&#8242;.</p>
<p>Seria algo equivalente ao comando:<br />
<code><br />
ssh -p 2139 app.dcc.ufba.br -L 2148:app.dcc.ufba.br:7070<br />
</code></p>
<p>É claro que você precisa <a href="http://wiki.dcc.ufba.br/Intranet/TutorialProxy">configurar o seu navegador</a> ( que eu espero que seja o <a href="http://br.mozdev.org/">firefox</a> <img src='http://www.leandronunes.net/wp-includes/images/smilies/icon_smile.gif' alt=':)' class='wp-smiley' />  ) para utilizar o proxy.</p>
<p>Existem <a href="http://docs.sun.com/app/docs/doc/816-0219/6m6njqbc9?a=view">muitas outras opções</a> que podem ser realizadas utilizando esta técnica. </p>
<p>Se divirta!</p>
]]></content:encoded>
			<wfw:commentRss>http://www.leandronunes.net/2009/04/utilizando-as-opcoes-do-ssh/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
	</channel>
</rss>

