~ubuntu-branches/ubuntu/raring/libjboss-remoting-java/raring

« back to all changes in this revision

Viewing changes to examples/org/jboss/remoting/samples/multiplex/SymmetricScenarioClient.java

  • Committer: Package Import Robot
  • Author(s): Torsten Werner
  • Date: 2011-09-09 14:01:03 UTC
  • mto: This revision was merged to the branch mainline in revision 9.
  • Revision ID: package-import@ubuntu.com-20110909140103-o8ucrolqt5g25k57
Tags: upstream-2.5.3.SP1
ImportĀ upstreamĀ versionĀ 2.5.3.SP1

Show diffs side-by-side

added added

removed removed

Lines of Context:
1
 
/*
2
 
* JBoss, Home of Professional Open Source
3
 
* Copyright 2005, JBoss Inc., and individual contributors as indicated
4
 
* by the @authors tag. See the copyright.txt in the distribution for a
5
 
* full listing of individual contributors.
6
 
*
7
 
* This is free software; you can redistribute it and/or modify it
8
 
* under the terms of the GNU Lesser General Public License as
9
 
* published by the Free Software Foundation; either version 2.1 of
10
 
* the License, or (at your option) any later version.
11
 
*
12
 
* This software is distributed in the hope that it will be useful,
13
 
* but WITHOUT ANY WARRANTY; without even the implied warranty of
14
 
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15
 
* Lesser General Public License for more details.
16
 
*
17
 
* You should have received a copy of the GNU Lesser General Public
18
 
* License along with this software; if not, write to the Free
19
 
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
20
 
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
21
 
*/
22
 
 
23
 
/*
24
 
 * Created on Sep 9, 2005
25
 
 */
26
 
package org.jboss.remoting.samples.multiplex;
27
 
 
28
 
import java.io.InputStream;
29
 
import java.io.OutputStream;
30
 
import java.net.InetSocketAddress;
31
 
import java.net.Socket;
32
 
 
33
 
import org.jboss.remoting.transport.multiplex.VirtualServerSocket;
34
 
import org.jboss.remoting.transport.multiplex.VirtualSocket;
35
 
 
36
 
 
37
 
/**
38
 
 * A SymmetricScenarioClient.
39
 
 
40
 
 * @author <a href="mailto:r.sigal@computer.org">Ron Sigal</a>
41
 
 * @version $Revision: 590 $
42
 
 * <p>
43
 
 * Copyright (c) 2005
44
 
 * </p>
45
 
 */
46
 
 
47
 
public class SymmetricScenarioClient
48
 
{
49
 
   static int bindPort = 5555;
50
 
   static String connectHost = "localhost";
51
 
   static int connectPort = 6666;
52
 
   
53
 
 
54
 
   public void runSymmetricScenario()
55
 
   {
56
 
      try
57
 
      {
58
 
         // Get a virtual socket to use for synchronizing client and server.
59
 
         Socket syncSocket = new Socket(connectHost, connectPort);
60
 
         InputStream is_sync = syncSocket.getInputStream();
61
 
         OutputStream os_sync = syncSocket.getOutputStream();
62
 
         
63
 
         // Create a VirtualServerSocket and connect it to MasterServerSocket
64
 
         // running on the server.
65
 
         VirtualServerSocket serverSocket = new VirtualServerSocket(bindPort);
66
 
         InetSocketAddress address1 = new InetSocketAddress(connectHost, connectPort + 1);
67
 
         is_sync.read();
68
 
         serverSocket.setSoTimeout(5000);
69
 
         serverSocket.connect(address1);
70
 
         
71
 
         // Call constructor to create a virtual socket and connect it to the port on the server
72
 
         // to which the VirtualServerSocket is connected.
73
 
         os_sync.write(5);
74
 
         is_sync.read();
75
 
         int port = serverSocket.getRemotePort();
76
 
         Socket virtualSocket1 = new VirtualSocket(connectHost, port);
77
 
         InputStream is1 = virtualSocket1.getInputStream();
78
 
         OutputStream os1 = virtualSocket1.getOutputStream();
79
 
         
80
 
         // Create a virtual socket by way of VirtualServerSocket.accept().
81
 
         Socket virtualSocket2 = serverSocket.accept();
82
 
         InputStream is2 = virtualSocket2.getInputStream();
83
 
         OutputStream os2 = virtualSocket2.getOutputStream();
84
 
         
85
 
         // Do some i/o and close sockets.
86
 
         os1.write(9);
87
 
         System.out.println(is1.read());
88
 
         os2.write(11);
89
 
         System.out.println(is2.read());
90
 
         virtualSocket1.close();
91
 
         virtualSocket2.close();
92
 
         syncSocket.close();
93
 
         serverSocket.close();
94
 
      }
95
 
      catch (Exception e)
96
 
      {
97
 
         e.printStackTrace();
98
 
      }
99
 
   }
100
 
   
101
 
   public static void main(String[] args)
102
 
   {
103
 
      if (args.length == 3)
104
 
      {
105
 
         bindPort = Integer.parseInt(args[0]);
106
 
         connectHost = args[1];
107
 
         connectPort = Integer.parseInt(args[2]);
108
 
      }
109
 
      
110
 
      new SymmetricScenarioClient().runSymmetricScenario();
111
 
   }
112
 
}
113