Socket Options. abstraction Introduction getsockopt and setsockopt function socket state Generic socket option IPv4 socket option ICMPv6 socket option.

Slides:



Advertisements
Similar presentations
Florida State UniversityCOP Advanced Unix Programming Raw Sockets Datalink Access Chapters 25, 26.
Advertisements

Introduction to Sockets Jan Why do we need sockets? Provides an abstraction for interprocess communication.
Nonblocking I/O Blocking vs. non-blocking I/O
Multicasting© Dr. Ayman Abdel-Hamid, CS4254 Spring CS4254 Computer Network Architecture and Programming Dr. Ayman A. Abdel-Hamid Computer Science.
CCNA – Network Fundamentals
Guide to TCP/IP, Third Edition
Chapter 12 Transport protocols. Outline 12.1 introduction 12.2 TCP/IP protocol suite.
1 TCP - Part I Relates to Lab 5. First module on TCP which covers packet format, data transfer, and connection management.
I/O Models Satish Krishnan. I/O Models Blocking I/O Non-blocking I/O I/O Multiplexing Signal driven I/O Asynchronous I/O.
CS3505 The Internet and Info Hiway transport layer protocols : TCP/UDP.
Transport Layer – TCP (Part1) Dr. Sanjay P. Ahuja, Ph.D. Fidelity National Financial Distinguished Professor of CIS School of Computing, UNF.
Elementary TCP Sockets© Dr. Ayman Abdel-Hamid, CS4254 Spring CS4254 Computer Network Architecture and Programming Dr. Ayman A. Abdel-Hamid Computer.
Multicasting - Part II© Dr. Ayman Abdel-Hamid, CS4254 Spring CS4254 Computer Network Architecture and Programming Dr. Ayman A. Abdel-Hamid Computer.
Sockets CS 3516 – Computer Networks. Outline Socket basics Socket details (TCP and UDP) Socket options Final notes.
Networks: TCP/IP Socket Calls1 Elementary TCP Sockets Chapter 4 UNIX Network Programming Vol. 1, Second Ed. Stevens.
Elementary TCP Sockets Chapter 4 UNIX Network Programming Vol. 1, Second Ed. Stevens.
Socket Programming.
Multimedia Networking Sockets. Outline Socket basics Socket details (TCP and UDP) Socket options Final notes.
Socket Options Jari Kellokoski. Introduction So far we have discovered some basic usage of socket With socket options we control sockets more suitable.
Computer Network Architecture and Programming
Operating Systems Sockets. Outline F Socket basics F TCP sockets F Socket details F Socket options F Final notes F Project 3.
Socket option Getsockopt ou setsockopt fcntl ioctl.
1 Introduction to Raw Sockets 2 IP address Port address MAC address TCP/IP Stack 67 Bootp DHCP OSPF protocol frame type UDP Port # TCP Port.
ECE 4110 – Internetwork Programming Client-Server Model.
University of Calgary – CPSC 441.  UDP stands for User Datagram Protocol.  A protocol for the Transport Layer in the protocol Stack.  Alternative to.
Chapter 17 Networking Dave Bremer Otago Polytechnic, N.Z. ©2008, Prentice Hall Operating Systems: Internals and Design Principles, 6/E William Stallings.
IT1352-NETWORK PROGRAMMING AND MANAGEMENT
Signal-Driven I/O Concepts and steps for using signal-driven I/O
6.1. Transport Control Protocol (TCP) It is the most widely used transport protocol in the world. Provides reliable end to end connection between two hosts.
TCP : Transmission Control Protocol Computer Network System Sirak Kaewjamnong.
FALL 2005CSI 4118 – UNIVERSITY OF OTTAWA1 Part 2.5 Internetworking Chapter 25 (Transport Protocols, UDP and TCP, Protocol Port Numbers)
 Wind River Systems, Inc Chapter - 13 Network Programming.
More on Socket API. How to Place Timeouts on Sockets (1)  Using SIGALRM signal Connection timeout 기간의 축소 Response timeout advio/dgclitimeo3.clib/connect_timeo.c.
Chapter 12 Transmission Control Protocol (TCP)
Programming with TCP – III 1. Zombie Processes 2. Cleaning Zombie Processes 3. Concurrent Servers Using Threads  pthread Library Functions 4. TCP Socket.
1 TCP: Reliable Transport Service. 2 Transmission Control Protocol (TCP) Major transport protocol used in Internet Heavily used Completely reliable transfer.
Review: How to create a TCP end point? What is the right format for sin_port and sin_addr in the sockaddr_in data structure? How many different ways we.
Chapter 2 Applications and Layered Architectures Sockets.
Network Programming Eddie Aronovich mail:
7.9 TCP Socket Options 7.10 SCTP Socket Options 7.11 fcntl Function 7.12 Summary 報告者 : 梁凱鈞.
More on Socket API. More on Socket I/O Functions  Scatter read and gather write.
TELE 402 Lecture 10: Unix domain … 1 Overview Last Lecture –Daemon processes and advanced I/O functions This Lecture –Unix domain protocols and non-blocking.
Netprog: Advanced Sockets Programming1 Advanced Sockets Programming Ref: Chapter 7,11,21,22.
Advanced Sockets API-II Vinayak Jagtap
CPSC 441 TUTORIAL – FEB 13, 2012 TA: RUITNG ZHOU UDP REVIEW.
1 Socket Options Ref: Chapter 7. 2 Socket Options Various attributes that are used to determine the behavior of sockets.Various attributes that are used.
Socket options: a summary –Tcp options, ip options and general socket options can be examined and sometimes modified. getsockopt, setsockopt routines Some.
I/O Multiplexing. What is I/O multiplexing? When an application needs to handle multiple I/O descriptors at the same time –E.g. file and socket descriptors,
TELE 402 Lecture 12: Signal-Driven I/O & Raw Socket 1 Overview Last Lecture –Advanced UDP sockets and threads –Source: Chapters 22&26 of Stevens’ book.
Today’s topic: UDP Reliable communication over UDP.
1 Socket Options getsockopt and setsockopt functions Check options and obtain default values Generic socket options IPv4 socket options IPv6 socket options.
CMPT 471 Networking II Network Programming © Janice Regan,
UDP : User Datagram Protocol 백 일 우
Data Communications and Networks Chapter 6 – IP, UDP and TCP ICT-BVF8.1- Data Communications and Network Trainer: Dr. Abbes Sebihi.
TCP/IP1 Address Resolution Protocol Internet uses IP address to recognize a computer. But IP address needs to be translated to physical address (NIC).
Lecture 3 TCP and UDP Sockets CPE 401 / 601 Computer Network Systems slides are modified from Dave Hollinger.
SOCKET PROGRAMMING Presented By : Divya Sharma.
1 Chapter 24 Internetworking Part 4 (Transport Protocols, UDP and TCP, Protocol Port Numbers)
IPv4 socket option Level => IPPROTO_IP
Socket Option.
Chapter 17 and 18: TCP is connection oriented
TCP - Part I Relates to Lab 5. First module on TCP which covers packet format, data transfer, and connection management.
Network Programming CSC- 341
Chapter 07. Socket Options.
Advanced Network Programming spring 2007
Advanced Sockets Programming
Process-to-Process Delivery: UDP, TCP
Socket options: a summary
Transport Layer 9/22/2019.
Advanced UNIX programming
Presentation transcript:

Socket Options

abstraction Introduction getsockopt and setsockopt function socket state Generic socket option IPv4 socket option ICMPv6 socket option IPv6 socket option TCP socket option fcnl function

Introduction Three ways to get and set the socket option that affect a socket –getsockopt, setsockopt function=>IPv4 and IPv6 multicasting options –fcntl function => nonblocking I/O, signal driven I/O –ioctl function =>chapter16

getsockopt and setsockopt function #include int getsockopt(int sockfd,, int level, int optname, void *optval, socklent_t *optlen); int setsockopt(int sockfd, int level, int optname, const void *optval, socklent_t optlen); sockfd => open socket descriptor level => code in the system to interprete the option(generic, IPv4, IPv6, TCP) optval => pointer to a variable from which the new value of option is fetched by setsockopt, or into which the current value of the option is stored by setsockopt. optlen => the size of the option variable.

Generic socket option SO_BROCAST => enable or disable the ability of the process to send broadcast message.(only datagram socket : Ethernet, token ring..) SO_DEBUG =>kernel keep track of detailed information about all packets sent or received by TCP(only supported by TCP) SO_DONTROUTE=>outgoing packets are to bypass the normal routing mechanisms of the underlying protocol. SO_ERROR=>when error occurs on a socket, the protocol module in a Berkeley-derived kernel sets a variable named so_error for that socket. Process can obtain the value of so_error by fetching the SO_ERROR socket option

SO_KEEPALIVE=>wait 2hours, and then TCP automatically sends a keepalive probe to the peer. –Peer response »ACK(everything OK) »RST(peer crashed and rebooted):ECONNRESET »no response:ETIMEOUT =>socket closed –example: Rlogin, Telnet… –Normally used by servers SO_KEEPALIVE

SO_LINGER SO_LINGER =>specify how the close function operates for a connection-oriented protocol(default:close returns immediately) –struct linger{ int l_onoff; /* 0 = off, nonzero = on */ int l_linger; /*linger time : second*/ }; l_onoff = 0 : turn off, l_linger is ignored l_onoff = nonzero and l_linger is 0:TCP abort the connection (send RST), discard any remaining data in send buffer. l_onoff = nonzero and l_linger is nonzero : process wait until remained data sending, or until linger time expired. If socket has been set nonblocking it will not wait for the close to complete, even if linger time is nonzero.

SO_LINGER client server write Close close returns Data queued by TCP Application reads queued data and FIN close data FIN Ack of data and FIN FIN Default operation of close:it returns immediately

SO_LINGER client server write Close Data queued by TCP Application reads queued data and FIN close data FIN Ack of data and FIN FIN close returns Close with SO_LINGER socket option set and l_linger a positive value

SO_LINGER client server write Shutdown read block Data queued by TCP Application reads queued data and FIN close data FIN Ack of data and FIN FIN read returns 0 Using shutdown to know that peer has received our data

An way to know that the peer application has read the data –use an application-level ack or application ACK –client char ack; Write(sockfd, data, nbytes); // data from client to server n=Read(sockfd, &ack, 1); // wait for application-level ack –server nbytes=Read(sockfd, buff, sizeof(buff)); //data from client //server verifies it received the correct amount of data from // the client Write(sockfd, “”, 1);//server’s ACK back to client

SO_RCVBUF, SO_SNDBUF let us change the default send-buffer, receive-buffer size. –Default TCP send and receive buffer size : »4096bytes » bytes –Default UDP buffer size : 9000bytes, bytes SO_RCVBUF option must be setting before connection established. –For client, it should be before calling connect() –For server it should be before calling listen() TCP socket buffer size should be at least three times the MSSs

SO_RCVLOWAT, SO_SNDLOWAT Every socket has a receive low-water mark and send low-water mark.(used by select function) Receive low-water mark: –the amount of data that must be in the socket receive buffer for select to return “readable”. –Default receive low-water mark : 1 for TCP and UDP Send low-water mark: –the amount of available space that must exist in the socket send buffer for select to return “writable” –Default send low-water mark : 2048 for TCP –UDP send buffer never change because dose not keep a copy of send datagram.

SO_RCVTIMEO, SO_SNDTIMEO allow us to place a timeout on socket receives and sends. Default disabled

SO_REUSEADDR, SO_REUSEPORT Allow a listening server to start and bind its well known port even if previously established connection exist that use this port as their local port. Allow multiple instance of the same server to be started on the same port, as long as each instance binds a different local IP address. Allow a single process to bind the same port to multiple sockets, as long as each bind specifies a different local IP address. Allow completely duplicate bindings : multicasting

SO_TYPE Return the socket type. Returned value is such as SOCK_STREAM, SOCK_DGRAM...

SO_USELOOPBACK This option applies only to sockets in the routing domain(AF_ROUTE). The socket receives a copy of everything sent on the socket.

IPv4 socket option Level => IPPROTO_IP IP_HDRINCL => If this option is set for a raw IP socket, we must build our IP header for all the datagrams that we send on the raw socket.

IPv4 socket option IP_OPTIONS=>allows us to set IP option in IPv4 header.(chapter 24) IP_RECVDSTADDR=>This socket option causes the destination IP address of a received UDP datagram to be returned as ancillary data by recvmsg.(chapter20)

IP_RECVIF Cause the index of the interface on which a UDP datagram is received to be returned as ancillary data by recvmsg.(chapter20)

IP_TOS lets us set the type-of-service(TOS) field in IP header for a TCP or UDP socket. If we call getsockopt for this option, the current value that would be placed into the TOS(type of service) field in the IP header is returned

IP_TTL We can set and fetch the default TTL(time to live field).

ICMPv6 socket option This socket option is processed by ICMPv6 and has a level of IPPROTO_ICMPV6. ICMP6_FILTER =>lets us fetch and set an icmp6_filter structure that specifies which of the 256possible ICMPv6 message types are passed to the process on a raw socket.(chapter 25)

IPv6 socket option This socket option is processed by IPv6 and have a level of IPPROTO_IPV6. IPV6_ADDRFORM=>allow a socket to be converted from IPv4 to IPv6 or vice versa.(chapter 10) IPV6_CHECKSUM=>specifies the byte offset into the user data of where the checksum field is located.

IPV6_DSTOPTS Specifies that any received IPv6 destination options are to be returned as ancillary data by recvmsg.

IPV6_HOPLIMIT Setting this option specifies that the received hop limit field be returned as ancillary data by recvmsg.(chapter 20) Default off.

IPV6_HOPOPTS Setting this option specifies that any received IPv6 hop-by-hop option are to be returned as ancillary data by recvmsg.(chapter 24)

IPV6_NEXTHOP This is not a socket option but the type of an ancillary data object that can be specified to sendmsg. This object specifies the next-hop address for a datagram as a socket address structure.(chapter20)

IPV6_PKTINFO Setting this option specifies that the following two pieces of infoemation about a received IPv6 datagram are to be returned as ancillary data by recvmsg:the destination IPv6 address and the arriving interface index.(chapter 20)

IPV6_PKTOPTIONS Most of the IPv6 socket options assume a UDP socket with the information being passed between the kernel and the application using ancillary data with recvmsg and sendmsg. A TCP socket fetch and store these values using IPV6_ PKTOPTIONS socket option.

IPV6_RTHDR Setting this option specifies that a received IPv6 routing header is to be returned as ancillary data by recvmsg.(chapter 24) Default off

IPV6_UNICAST_HOPS This is similar to the IPv4 IP_TTL. Specifies the default hop limit for outgoing datagram sent on the socket, while fetching the socket option returns the value for the hop limit that the kernel will use for the socket.

TCP socket option There are five socket option for TCP, but three are new with Posix.1g and not widely supported. Specify the level as IPPROTO_TCP.

TCP_KEEPALIVE This is new with Posix.1g It specifies the idle time in second for the connection before TCP starts sending keepalive probe. Default 2hours this option is effective only when the SO_KEEPALIVE socket option enabled.

TCP_MAXRT This is new with Posix.1g. It specifies the amount of time in seconds before a connection is broken once TCP starts retransmitting data. –0 : use default –-1:retransmit forever –positive value:rounded up to next transmission time

TCP_MAXSEG This allows us to fetch or set the maximum segment size(MSS) for TCP connection.

TCP_NODELAY This option disables TCP’s Nagle algorithm. (default this algorithm enabled) purpose of the Nagle algorithm. ==>prevent a connection from having multiple small packets outstanding at any time. Small packet => any packet smaller than MSS.

Nagle algorithm Default enabled. Reduce the number of small packet on the WAN. If given connection has outstanding data, then no small packet data will be sent on connection until the existing data is acknowledged.

h e l l o ! Nagle algorithm disabled

Nagle algorithm enabled h e l l o ! h el lo !

fcntl function File control This function perform various descriptor control operation. Provide the following features –Nonblocking I/O(chapter 15) –signal-driven I/O(chapter 22) –set socket owner to receive SIGIO signal. (chapter 21,22)

#include int fcntl(int fd, int cmd, …./* int arg */); Returns:depends on cmd if OK, -1 on error O_NONBLOCK : nonblocking I/O O_ASYNC : signal driven I/O notification

Nonblocking I/O using fcntl Int flags; /* set socket nonblocking */ if((flags = fcntl(fd, f_GETFL, 0)) < 0) err_sys(“F_GETFL error”); flags |= O_NONBLOCK; if(fcntl(fd, F_SETFL, flags) < 0) err_sys(“F_ SETFL error”); each descriptor has a set of file flags that fetched with the F_GETFL command and set with F_SETFL command.

Misuse of fcntl /* wrong way to set socket nonblocking */ if(fcntl(fd, F_SETFL,O_NONBLOCK) < 0) err_sys(“F_ SETFL error”); /* because it also clears all the other file status flags.*/

Turn off the nonblocking flag Flags &= ~O_NONBLOCK; if(fcntl(fd, F_SETFL, flags) < 0) err_sys(“F_SETFL error”);

F_SETOWN The integer arg value can be either positive(process ID) or negative (group ID)value to receive the signal. F_GETOWN => retrurn the socket owner by fcntl function, either process ID or process group ID.