<?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>Blog Patrick Espake &#187; processos</title>
	<atom:link href="http://blog.patrickespake.com/tag/processos/feed/" rel="self" type="application/rss+xml" />
	<link>http://blog.patrickespake.com</link>
	<description>O conhecimento evolui quando é compartilhado!</description>
	<lastBuildDate>Fri, 03 Sep 2010 04:24:02 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.1-alpha</generator>
		<item>
		<title>Ruby usando DRb (Distributed Ruby)</title>
		<link>http://blog.patrickespake.com/2009/06/18/ruby-usando-drb-distributed-ruby/</link>
		<comments>http://blog.patrickespake.com/2009/06/18/ruby-usando-drb-distributed-ruby/#comments</comments>
		<pubDate>Thu, 18 Jun 2009 14:41:57 +0000</pubDate>
		<dc:creator>patrickespake</dc:creator>
				<category><![CDATA[Ruby]]></category>
		<category><![CDATA[9000]]></category>
		<category><![CDATA[aplicação]]></category>
		<category><![CDATA[class]]></category>
		<category><![CDATA[cliente]]></category>
		<category><![CDATA[cliente/servidor]]></category>
		<category><![CDATA[def]]></category>
		<category><![CDATA[distributed]]></category>
		<category><![CDATA[distributed ruby]]></category>
		<category><![CDATA[drb]]></category>
		<category><![CDATA[DRbObject]]></category>
		<category><![CDATA[druby]]></category>
		<category><![CDATA[end]]></category>
		<category><![CDATA[hello]]></category>
		<category><![CDATA[invocação remota]]></category>
		<category><![CDATA[join]]></category>
		<category><![CDATA[localhost]]></category>
		<category><![CDATA[new]]></category>
		<category><![CDATA[nil]]></category>
		<category><![CDATA[obj]]></category>
		<category><![CDATA[processos]]></category>
		<category><![CDATA[puts]]></category>
		<category><![CDATA[rede]]></category>
		<category><![CDATA[require]]></category>
		<category><![CDATA[rmi]]></category>
		<category><![CDATA[server]]></category>
		<category><![CDATA[server.rb]]></category>
		<category><![CDATA[server_object]]></category>
		<category><![CDATA[servidor]]></category>
		<category><![CDATA[start_service]]></category>
		<category><![CDATA[thread]]></category>
		<category><![CDATA[transmitir]]></category>

		<guid isPermaLink="false">http://blog.patrickespake.com/?p=728</guid>
		<description><![CDATA[DRb permite programas em Ruby se comunicar uns com os outros na mesma máquina ou através de uma rede, aplicação cliente/servidor. DRb utiliza o método de invocação remota (RMI) para transmitir comandos e dados entre os processos. Nesse post vamos criar dois programas, o servidor e o cliente usando DRb. Construíndo o servidor (server.rb): 1 [...]]]></description>
			<content:encoded><![CDATA[<p><strong>DRb</strong> permite programas em <strong>Ruby</strong> se comunicar uns com os outros na mesma máquina ou através de uma rede, aplicação <strong>cliente/servidor</strong>. DRb utiliza o método de invocação remota <strong>(RMI)</strong> para transmitir comandos e dados entre os processos.</p>
<p>Nesse post vamos criar dois programas, o <strong>servidor</strong> e o <strong>cliente</strong> usando DRb.</p>
<p><strong>Construíndo o servidor (server.rb):</strong></p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
7
8
9
10
11
</pre></td><td class="code"><pre class="ruby" style="font-family:monospace;"><span style="color:#CC0066; font-weight:bold;">require</span> <span style="color:#996600;">'drb'</span>
&nbsp;
<span style="color:#9966CC; font-weight:bold;">class</span> Server
  <span style="color:#9966CC; font-weight:bold;">def</span> hello
    <span style="color:#996600;">&quot;Hello, This is a Distributed Ruby (DRb) Example&quot;</span>
  <span style="color:#9966CC; font-weight:bold;">end</span>
<span style="color:#9966CC; font-weight:bold;">end</span>
&nbsp;
server_object = Server.<span style="color:#9900CC;">new</span>
DRb.<span style="color:#9900CC;">start_service</span><span style="color:#006600; font-weight:bold;">&#40;</span><span style="color:#996600;">'druby://localhost:9000'</span>, server_object<span style="color:#006600; font-weight:bold;">&#41;</span>
DRb.<span style="color:#9900CC;">thread</span>.<span style="color:#9900CC;">join</span></pre></td></tr></table></div>

<p><strong>Entendendo o código do servidor:</strong></p>

<div class="wp_syntax"><div class="code"><pre class="ruby" style="font-family:monospace;"><span style="color:#CC0066; font-weight:bold;">require</span> <span style="color:#996600;">'drb'</span></pre></div></div>

<p>A linha acima apenas requere a biblioteca <strong>DRb</strong>, essa biblioteca que a responsável por fazer a comunicação remota. Você pode encontrar mais informações a seu respeito em: <a href="http://www.ruby-doc.org/stdlib/libdoc/drb/rdoc/index.html">http://www.ruby-doc.org/stdlib/libdoc/drb/rdoc/index.html</a>.</p>

<div class="wp_syntax"><div class="code"><pre class="ruby" style="font-family:monospace;"><span style="color:#9966CC; font-weight:bold;">class</span> Server
  <span style="color:#9966CC; font-weight:bold;">def</span> hello
    <span style="color:#996600;">&quot;Hello, This is a Distributed Ruby (DRb) Example&quot;</span>
  <span style="color:#9966CC; font-weight:bold;">end</span>
<span style="color:#9966CC; font-weight:bold;">end</span></pre></div></div>

<p>O código acima apena cria uma classe e o método hello, que imprime uma mensagem.</p>

<div class="wp_syntax"><div class="code"><pre class="ruby" style="font-family:monospace;">server_object = Server.<span style="color:#9900CC;">new</span>
DRb.<span style="color:#9900CC;">start_service</span><span style="color:#006600; font-weight:bold;">&#40;</span><span style="color:#996600;">'druby://localhost:9000'</span>, server_object<span style="color:#006600; font-weight:bold;">&#41;</span>
DRb.<span style="color:#9900CC;">thread</span>.<span style="color:#9900CC;">join</span></pre></div></div>

<p>Essas três linhas acima que fazem o servidor funcionar, a primeira linha apenas faz a instância da classe Server, a segunda linha inicia o serviço remoto no endereço druby://localhost:9000 disponibilizando o objeto server_object, a terceira linha inicia uma thread no servidor para aceitar requisições remotas.</p>
<p><strong>Construíndo o cliente (client.rb):</strong></p>

<div class="wp_syntax"><table><tr><td class="line_numbers"><pre>1
2
3
4
5
6
</pre></td><td class="code"><pre class="ruby" style="font-family:monospace;"><span style="color:#CC0066; font-weight:bold;">require</span> <span style="color:#996600;">'drb'</span>
&nbsp;
DRb.<span style="color:#9900CC;">start_service</span>
obj = DRbObject.<span style="color:#9900CC;">new</span><span style="color:#006600; font-weight:bold;">&#40;</span><span style="color:#0000FF; font-weight:bold;">nil</span>, <span style="color:#996600;">'druby://localhost:9000'</span><span style="color:#006600; font-weight:bold;">&#41;</span>
&nbsp;
<span style="color:#CC0066; font-weight:bold;">puts</span> obj.<span style="color:#9900CC;">hello</span></pre></td></tr></table></div>

<p><strong>Entendendo o código do cliente:</strong></p>

<div class="wp_syntax"><div class="code"><pre class="ruby" style="font-family:monospace;"><span style="color:#CC0066; font-weight:bold;">require</span> <span style="color:#996600;">'drb'</span></pre></div></div>

<p>A linha acima apenas requere a biblioteca <strong>DRb</strong>, essa biblioteca que a responsável por fazer a comunicação remota. Você pode encontrar mais informações a seu respeito em: <a href="http://www.ruby-doc.org/stdlib/libdoc/drb/rdoc/index.html">http://www.ruby-doc.org/stdlib/libdoc/drb/rdoc/index.html</a>.</p>

<div class="wp_syntax"><div class="code"><pre class="ruby" style="font-family:monospace;">DRb.<span style="color:#9900CC;">start_service</span>
obj = DRbObject.<span style="color:#9900CC;">new</span><span style="color:#006600; font-weight:bold;">&#40;</span><span style="color:#0000FF; font-weight:bold;">nil</span>, <span style="color:#996600;">'druby://localhost:9000'</span><span style="color:#006600; font-weight:bold;">&#41;</span></pre></div></div>

<p>As suas linhas acima inicia o serviço remoto com o servidor, a primeira inicializa o serviço e a segunda estabelece conexão com o servidor no endereço <strong>druby://localhost:9000</strong> obtendo o objeto <strong>Server</strong>.</p>

<div class="wp_syntax"><div class="code"><pre class="ruby" style="font-family:monospace;"><span style="color:#CC0066; font-weight:bold;">puts</span> obj.<span style="color:#9900CC;">hello</span></pre></div></div>

<p>Essa linha acima invoca o método <strong>hello</strong> do objeto remoto <strong>Server</strong>.</p>
<p><strong>Rodando o servidor:</strong></p>
<p>Para inicializar o servidor digite na linha de comando:</p>

<div class="wp_syntax"><div class="code"><pre class="ruby" style="font-family:monospace;">ruby server.<span style="color:#9900CC;">rb</span></pre></div></div>

<p>Não será exibida nenhuma mensagem, o servidor apenas ficará esperando novas requisições remotas.</p>
<p><strong>Rodando o cliente:</strong></p>

<div class="wp_syntax"><div class="code"><pre class="ruby" style="font-family:monospace;">ruby client.<span style="color:#9900CC;">rb</span></pre></div></div>

<p>Quando você rodar o cliente terá como retorno a mensagem:</p>

<div class="wp_syntax"><div class="code"><pre class="ruby" style="font-family:monospace;">Hello, This is a Distributed Ruby <span style="color:#006600; font-weight:bold;">&#40;</span>DRb<span style="color:#006600; font-weight:bold;">&#41;</span> Example</pre></div></div>

<p>Pronto! Esse recurso é muito interessante. ;-)</p>
<p>Se você gostou desse texto e acha que ajudou você, me recomende: <a href="http://www.workingwithrails.com/recommendation/new/person/15479-patrick-espake"><img src="http://workingwithrails.com/images/tools/compact-small-button.jpg" alt="Recommend Me" /></a>.</p>
<p><a class="a2a_dd addtoany_share_save" href="http://www.addtoany.com/share_save"><img src="http://blog.patrickespake.com/wp-content/plugins/add-to-any/share_save_171_16.png" width="171" height="16" alt="Share/Bookmark"/></a> </p>]]></content:encoded>
			<wfw:commentRss>http://blog.patrickespake.com/2009/06/18/ruby-usando-drb-distributed-ruby/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
	</channel>
</rss>
