Client/server - PowerPoint PPT Presentation

About This Presentation
Title:

Client/server

Description:

Client/server - SUNY Oneonta ... Client/server – PowerPoint PPT presentation

Number of Views:144
Avg rating:3.0/5.0
Slides: 42
Provided by: hig103
Category:

less

Transcript and Presenter's Notes

Title: Client/server


1
Client/server
2
The (simple) Client/Server Connection using
Stream Sockets The Server
  • 5 steps to building the server
  • Create a ServerSocket object registers an
    available TCP/IP port and a maximum queue length
  • ServerSocket servernew ServerSocket(port,queuele
    n)
  • This is called the handshake point. If the queue
    is full the connection is refused. The process
    is known as binding a server to a port. Only
    one application at a time can be bound to a
    particular port.

3
Simple Server continued Step 2
  • 2. The server listens, or blocks for a client
    connection
  • Socket connection server.accept()
  • The socket connection makes possible interaction
    with the client via I/O streams. The server
    interacts with a client at a different port than
    the handshake point, which makes possible
    multi-threaded servers (ie.,after connection is
    established, the server can spawn a thread to
    process this client and go on listening for
    another.

4
Simple Server continued Step 3
  • 3. The server gets I/O connections associated
    with the client socket. I/O across the
    connection is not really much different than
    other java i/o.
  • ObjectInputStream input new ObjectInputStream(co
    nnection.getInputStream())
  • ObjectOutputStream output new
    ObjectOutputStream(connection.getOutputStream())
  • The servers output stream is the clients input
    stream, and visa versa.

5
Simple Server continued
  • 4. Process the connection this phase is
    application-specific and might involve a single
    message being sent, complicated objects being
    exchanged, a loop, whatever.
  • 5. Close the connection by invoking close()
    method on the streams.

6
The (simple) Client/Server Connection using
Stream Sockets The Client
  • 4 steps to building the client
  • 1. Establish a connection to the server
  • Socket connection new Socket(serverIP,port)
  • A connection is returned if this step is
    successful, otherwise an IOException is thrown.
    Notice, the client needs to know where the server
    is (the servers IP) while the server doesnt
    know in advance the clients address.

7
Simple Client continued Step 2
  • 3. The client gets I/O connections associated
    with the socket.
  • ObjectInputStream input new ObjectInputStream(co
    nnection.getInputStream())
  • ObjectOutputStream output new
    ObjectOutputStream(connection.getOutputStream())
  • Other stream types can be used to wrap around
    these for manipulation different object types.
    Any serializable object can be passed via the IO
    connection.

8
Simple Client continued
  • 3. Processing phase
  • 4. Close the connection by invoking close()
    method on the streams. This is application
    specific- the client needs to know when the
    server is done so as to avoid an IOException
    (EOFException) trying to read past EOF mark.

9
server code (in slide notes)
  • http//employees.oneonta.edu/higgindm/internet
    programming/Server.html

10
Client code
  • http//employees.oneonta.edu/higgindm/internet20p
    rogramming/Client.html

11
ServerTest app
  • http//employees.oneonta.edu/higgindm/internet20p
    rogramming/ServerTest.html
  • import javax.swing.JFrame
  • public class ServerTest
  • public static void main( String args )
  • Server application new Server() //
    create server
  • application.setDefaultCloseOperation(
    JFrame.EXIT_ON_CLOSE )
  • application.runServer() // run server
    application
  • // end main
  • // end class ServerTest

12
Clienttest.java app feeds a urlhttp//employees.
oneonta.edu/higgindm/internet20programming/Client
Test.html
  • import javax.swing.JFrame
  • public class ClientTest
  • public static void main( String args )
  • Client application // declare client
    application
  • // if no command line args
  • if ( args.length 0 )
  • application new Client( "137.141.19.2"
    ) // connect to localhost
  • else
  • application new Client( args 0 )
    // use args to connect
  • application.setDefaultCloseOperation(
    JFrame.EXIT_ON_CLOSE )
  • application.runClient() // run client
    application
  • // end main

13
Compile and run
  • Compile 4 java files. Run ServerTest, then
    ClientTest
  • Exercise modify clienttest code so a url is
    entered on the command line.
  • Run the client and server on different machines
  • Hint You can use
  • c\ipconfig \all
  • to show a machines ip, if you can get to the
    command prompt
  • Loop back URL is 127.0.0.1

14
Server window
15
Client window
16
Some communication
17
Client closes connection
18
Connectionless Client/server communication via
datagrams
  • While the connection-based client/server model is
    similar to the telephone, the datagram model is
    more like the post office.
  • The message is posted in sequential numbered
    packets and re-assembled at the target location.
  • Messages may arrive jumbled, or not at all.
  • This example uses the UserDatagramProtocol (UDP)
    between client and server.

19
Server structure in datagram communication
  • DatagramSocket socket//use this datatype
  • try
  • socket new DatagramSocket(5000)// specify port
  • catch(SocketException se)
  • Wait for packets
  • Byte datanew byte100
  • while(true)//forever loop
  • try
  • Datagram receivepacketnew DatagramPacket(data,
    data.length)
  • socket.recieve(receivepacket)
  • catch(IOException e)

20
Datagram server continued
  • //Send packet to clientalso inside try catch for
    ioexception
  • Datagram sendpacketnew DatagramPacket(receivepack
    et.getData(),receivepacket.getLength(),receivepack
    et.getAddress(),receivepacket.getPort())
  • socket.send(sendpacket)

21
Datagram (packet) server
  • The server uses two DatagramPackets one to send
    and one to receive packets.
  • This application uses java.net classes
  • java.net.DatagramPacket and java.net.DatagramSocke
    t
  • DatagramSocket is created in a try block where
    the server is bound to a port. Processing on the
    serverside involves an infinite loop waiting for
    packets. Clients must specify the server port
    when sending packets.
  • Datagram method receive() blocks until a packet
    is received then stores the packet info in its
    Datagram argument.
  • Methods are called to display senders IP, port,
    message length and the message itself.

22
Packets 4 files
  • http//employees.oneonta.edu/higgindm/internet20p
    rogramming/PacketServer.html
  • http//employees.oneonta.edu/higgindm/internet20p
    rogramming/PacketClient.html
  • http//employees.oneonta.edu/higgindm/internet20p
    rogramming/PacketServerTest.html
  • http//employees.oneonta.edu/higgindm/internet20p
    rogramming/PacketClientTest.html

23
PacketClient frame
24
PacketServer frame
25
Threaded client/server
  • Some background
  • LockSwingUtilities.invokeLater()
  • Scanner
  • Executor for threads
  • Synchronization using Locks

26
Scanner
  • Scanner is replacing StringTokenizer. It is
    similar, versatile and easy to use.
  • Deitel pg 59 has an example.
  • import java.util.Scanner
  • Scanner inputnew Scanner(System.in)
  • int x
  • xinput.nextInt()

27
SwingUtilities.invokeLater()
  • Having multiple threads manipulate GUI content
    may not give expected results. Better to have
    the event-dispatching thread queue requests to
    display answers, change colors, and so on, and
    handle them in order. Here is a method to do it
  • SwingUtilities.invokeLater(
  • new Runnable()
  • public void run()
  • thread does stuff to GUI
  • )

28
Executor service for running threads
  • Recommended thread construction in jdk1.5 is
  • public class mythread extends Runnable
  • public void run()
  • //loop or whatever
  • try
  • Thread.sleep(sometime)
  • the rest of it
  • catch(InterruptedException e)

29
Executor service for running threads
  • Executor Service example Deitels text pg 1059
  • import java.util.concurrent.
  • Thread a new Thread()//not recommended
  • //should be
  • RunnableThingy a new RunnableThingy()
  • Thread b new Thread()//as above
  • ExecutorService threadExExecutors.newFixedThreadP
    ool(2)
  • //can run just two threads
  • threadEx.execute(a)
  • threadEx.execute(b)
  • theadEx.shutdown()

30
Executor service for running threads
  • Runnables are managed and executed by a class
    that implements Executor interface. This has one
    method, (execute).
  • An executor manages a thread pool.
  • Executor assigns each runnable object to a thread
    in the pool. If there are none it may make a new
    thread (newCachedThreadPool) or queue the
    runnable for the next available thread as in the
    fixed thread pool.

31
Synchronization using Lock
  • Example in Deitel text pg 1071
  • This is fairly similar to providing synchronized
    methods.
  • import java.util.concurrent.locks.

32
Synchronization using Lock
  • import java.util.concurrent.locks.Lock
  • import java.util.concurrent.locks.ReentrantLock
  • import java.util.concurrent.locks.Condition
  • public class SynchronizedBuffer implements Buffer
  • // Lock to control synchronization with this
    buffer
  • private Lock accessLock new ReentrantLock()
  • // conditions to control reading and writing
  • private Condition canWrite
    accessLock.newCondition()
  • private Condition canRead accessLock.newCondi
    tion()
  • private int buffer -1 // shared by producer
    and consumer threads
  • private boolean occupied false

33
Synchronization using Lock set
  • public void set( int value )
  • accessLock.lock() // lock this object
  • try
  • while ( occupied )
  • System.out.println( "Producer tries
    to write." )
  • displayState( "Buffer full. Producer
    waits." )
  • canWrite.await()// wait until buffer
    is empty
  • // end while
  • buffer value // set new buffer value
  • // producer cannot store new value until consumer
    retrieves current value
  • occupied true
  • displayState( "Producer writes "
    buffer )
  • // signal thread waiting to read from
    buffer
  • canRead.signal()
  • // end try
  • catch ( InterruptedException exception )
  • exception.printStackTrace()
    // end catch
  • finally
  • accessLock.unlock() // unlock this
    object

34
Synchronization using Lock get
  • public int get()
  • int readValue 0 // initialize value
    read from buffer
  • accessLock.lock() // lock this object
  • // output thread information and buffer
    information, then wait
  • try // while no data to
    read, place thread in waiting state
  • while ( !occupied )
  • System.out.println( "Consumer tries
    to read." )
  • displayState( "Buffer empty. Consumer
    waits." )
  • canRead.await() // wait until buffer
    is full
  • // end while
  • // indicate that producer can store
    another value
  • // because consumer just retrieved
    buffer value
  • occupied false
  • readValue buffer // retrieve value
    from buffer
  • displayState( "Consumer reads "
    readValue )
  • // signal thread waiting for buffer to
    be empty
  • canWrite.signal()
  • // end try
  • // if waiting thread interrupted, print
    stack trace

35
Threaded client/server code links below and in
slide notes
  • http//employees.oneonta.edu/higgindm/internet20p
    rogramming/TicTacToeServerTest.html
  • http//employees.oneonta.edu/higgindm/internet20p
    rogramming/TicTacToeServer.html
  • http//employees.oneonta.edu/higgindm/internet20p
    rogramming/TicTacToeClient.html
  • http//employees.oneonta.edu/higgindm/internet20p
    rogramming/TicTacToeClientTest.html

36
TicTacToeServer
  • In notes

37
TicTacToe client
38
Compile run
  • Compile the 4 files. Run TicTacToeServerTest
    first. You need to run 2 clients (players).
  • A window opens for the server and a board appears
    for each client.

39
Client boards after play
40
Exercises
  • Modify the client to connect to a server on
    another machine.
  • Fix the server so it can tell when the game
    ends.

41
Socket project
  • Modify the threaded client server to play your
    choice
  • Hexapawn on 4X4 or larger board
  • Dominoes
  • Othello
  • A simple card game War, or maybe 21
  • First option may be easiest. Othello also isnt
    too hard. Make sure the server recognizes whose
    move it is, allows only correct moves, and knows
    when the game is over (or when a client
    terminates).
Write a Comment
User Comments (0)
About PowerShow.com