/usr/share/doc/pyro/html/1-intro.html is in pyro-doc 1:3.16-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 | <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-type" content="text/html;charset=UTF-8">
<title>PYRO - Introduction</title>
<link rel="stylesheet" type="text/css" href="pyromanual_print.css" media="print">
<link rel="stylesheet" type="text/css" href="pyromanual.css" media="screen">
</head>
<body>
<div class="nav">
<table width="100%">
<tr>
<td align="left"><a href="index.html"><previous</a> | <a href="index.html">contents</a> | <a href=
"2-concepts.html">next></a></td>
<td align="right">Pyro Manual</td>
</tr>
</table>
<hr></div>
<!-- ******************* INTRODUCTION ******************** -->
<h2>1. Introduction</h2>Thank you for choosing the often regarded number one Remote Method Invocation package
for Python!
<p>
Pyro is short for PYthon Remote Objects. It is an advanced and powerful
Distributed Object Technology system written entirely in Python, that is
designed to be very easy to use. Never worry about writing network
communication code again, when using Pyro you just write your Python objects
like you would normally. With only a few lines of extra code, Pyro takes care
of the network communication between your objects once you split them over
different machines on the network. All the gory socket programming details are
taken care of, you just call a method on a remote object as if it were a local
object!</p>
<p>
Pyro provides an object-oriented form of RPC. You can use Pyro within a single
system but also use it for IPC. For those that are familiar with Java, Pyro
resembles Java's Remote Method Invocation (<a href="http://java.sun.com/products/jdk/rmi/index.html">RMI</a>).
It is less similar to <a href="http://www.omg.org/gettingstarted/corbafaq.htm">CORBA</a> -
which is a system- and language independent Distributed Object Technology and
has much more to offer than Pyro or RMI.
But Pyro is <strong>small</strong>, <strong>simple</strong>,
<strong>fun</strong> and <strong>free</strong>! For another overview of what Pyro is, see the Pyro page online
(<a href="http://irmen.home.xs4all.nl/pyro3/">http://irmen.home.xs4all.nl/pyro3</a>). You can also download the package from
there.</p>
<p><strong>Copyright and Disclaimer</strong><br>
This software is copyright © by Irmen de Jong. It is subject to change without notice. Pyro comes
as-is, without warranty and in no event can Irmen de Jong be held liable for any problems resulting
from this software. License: Pyro is released under the MIT license, see the file "<a href="LICENSE">LICENSE</a>".</p>
<p><strong>Security Warning</strong><br>
<em>In the Security chapter is an <a href="9-security.html">important security warning</a> that you absolutely must
read!</em></p>
<p><strong>Legacy version</strong><br>
Pyro 3.x is in maintenance mode.
This means it will only get security- and bugfixes.
New projects are strongly advised to use <a href="http://irmen.home.xs4all.nl/pyro/">Pyro4</a> instead,
which is the new Pyro version that is actively being developed.
</p>
<p><strong>Features of Pyro 3.x</strong></p>
<ul>
<li>Written in 100% pure Python. It is small, simple and extremely portable - it runs everywhere Python runs and TCP/IP networking is available.</li>
<li>Naming Service which keeps record of the location of objects. The location of the NS can be discovered by a broadcast mechanism, and various other ways, if your network doesn't support broadcasting. NS has option to keep its naming database persistent (on disk) so that it survives shutdowns. </li>
<li>High-level Event Service with topic channels.</li>
<li> Mobile objects. Clients and servers can pass objects around - even when the server has never known them before. Pyro will then automatically transfer the needed Python bytecode.</li>
<li>Support for Python types only restricted by those that the standard 'pickle' module handles (all builtin types, and user created classes) Objects as arguments are also supported.</li>
<li>Support for all Python argument types (variable argument lists and keyword arguments, <code>*args</code> and <code>**keywords</code>).</li>
<li>Exceptions that occur in the remote object will actually be raised too on the client, just as if the error occured locally. Pyro's exception transportation mechanism makes this possible.</li>
<li>Dynamic Proxies - no need for additional tools or classes.</li>
<li>Direct remote attribute access with normal Python syntax.</li>
<li>Server can dynamically create or remove new Pyro objects.</li>
<li>Multithreaded server support to handle multiple requests simultaneously.</li>
<li>Automatic reconnection in case of network connection failures.</li>
<li>Fast one-way invocation possible.</li>
<li>Pyro contains heavily tested network communication code that works reliable on all platforms </li>
<li>Talk between 32-bit and 64-bit machines, regardless of processor architecture and operating system</li>
<li>A lot of examples are included in the Pyro distribution!</li>
</ul>
<p><strong>To get an idea of how Pyro works, here is a scenario:</strong></p>
<ol>
<li>You write a module '<code>test</code>' containing a class '<code>testclass</code>', which will be accessed
remotely.</li>
<li>The server creates one or more instances of the '<code>testclass</code>', and registers them with the Pyro Name
Server.</li>
<li>The client queries the Name Server for the location of those objects. It gets a Pyro URI (Universal Resource
Identifier) for them.</li>
<li>The client creates proxies for the remote objects.</li>
<li>Because the proxy mimics the real '<code>testclass</code>', the client can now invoke methods on the remote
objects. The proxy will forward the method invocations and return the results, just as if it was the remote object
itself. Not a single line of network communication code has been written.</li>
</ol>This looks like a big oversimplification, but it isn't!
<p>To dive directly into the code, have a look at the various Pyro examples in the <code>examples</code> directory
(read the <code>Readme.txt</code>). There is much to learn there. The easiest example to start with
is the "simple"
example, it shows how a normal python object is made into a Pyro object and accessed remotely from
the client.</p>
<p><strong>Required Software:</strong></p>
<ul>
<li>This version of Pyro needs at least Python 2.5, but it is not compatible with Python 3.x. (you'll need Pyro 4.x for that).</li>
<li>You will have to use the same major Python version everywhere to make sure the data format is compatible (if
you are using the default builtin pickle protocol)</li>
<li>Because basic Pyro does not depend on any third party libraries or extension modules, it runs wherever Python
is available, however, the command line utility scripts are designed for Windows(NT) and Unix sh. You might
experience problems trying to run them on other systems.</li>
<li>The <code>pyro-xnsc</code> tool requires the Tkinter Python extension module, with Tcl/Tk installed.</li>
<li>The <code>pyro-wxnsc</code> tool requires the WxPython extension module with WxWindows.</li>
</ul>
<p><strong>Important information Links</strong></p>
<ul>
<li><a href="http://irmen.home.xs4all.nl/pyro3">Pyro 3.x home page</a></li>
<li><a href="http://irmen.home.xs4all.nl/pyro">Pyro4 home page</a> - the successor of Pyro 3.x that is actively being developed.</li>
<li><a href="http://pypi.python.org/pypi/Pyro/">Python package index for Pyro</a></li>
<li><a href="http://pypi.python.org/pypi/Pyro4/">Python package index for Pyro4</a></li>
<li>Info about the <a href="http://lists.sourceforge.net/lists/listinfo/pyro-core">Mailing list</a>, which is the
best way of getting help.</li>
</ul>
<p><strong>Related technology</strong></p>
<ul>
<li>Java Remote Method Invocation (<a href="http://download.oracle.com/javase/6/docs/technotes/guides/rmi/index.html">RMI</a>)</li>
<li>Common Object Request Broker Architecture (<a href="http://www.omg.org/gettingstarted/corbafaq.htm">CORBA</a>)</li>
<li><a href="http://omniorb.sourceforge.net/">OmniORB</a> - a CORBA implementation with Python bindings</li>
</ul>
<p><strong>Thanks</strong></p>
<p>I want to thank everybody on the <a href="http://lists.sourceforge.net/lists/listinfo/pyro-core">Pyro mailing
list</a>, your participation is of great value. And to everybody who contacted me about Pyro, for positive remarks,
comments, or with problems (it all helps to improve Pyro): Thank You!</p>
<div class="nav">
<hr>
<table width="100%">
<tr>
<td align="left"><a href="index.html"><previous</a> | <a href="index.html">contents</a> | <a href=
"2-concepts.html">next></a></td>
<td align="right">Pyro Manual</td>
</tr>
</table></div>
</body>
</html>
|