dhcrelay(8)


NAME

   dhcrelay - Dynamic Host Configuration Protocol Relay Agent

SYNOPSIS

   dhcrelay  [ -4 ] [ -dqaD ] [ -p port ] [ -c count ] [ -A length ] [ -pf
   pid-file ] [ --no-pid ] [ -m append | replace | forward | discard  ]  [
   -i interface0 [ ...  -i interfaceN ] ] server0 [ ...serverN ]

   dhcrelay  -6 [ -dqI ] [ -p port ] [ -c count ] [ -pf pid-file ] [ --no-
   pid ] [ -s subscriber-id ] -l lower0 [ ...  -l lowerN ] -u upper0 [ ...
   -u upperN ]

DESCRIPTION

   The  Internet Systems Consortium DHCP Relay Agent, dhcrelay, provides a
   means for relaying DHCP and BOOTP requests from a subnet  to  which  no
   DHCP  server is directly connected to one or more DHCP servers on other
   subnets.  It supports both DHCPv4/BOOTP and DHCPv6 protocols.

OPERATION

   The DHCP Relay Agent listens for DHCPv4 or DHCPv6 queries from  clients
   or  other relay agents on one or more interfaces, passing them along to
   ``upstream'' servers or relay agents as specified on the command  line.
   When a reply is received from upstream, it is multicast or unicast back
   downstream to the source of the original request.

COMMAND LINE

   Protocol selection options:

   -6     Run dhcrelay as a DHCPv6 relay agent.  Incompatible with the  -4
          option.

   -4     Run dhcrelay as a DHCPv4/BOOTP relay agent.  This is the default
          mode of operation, so the argument is not necessary, but may  be
          specified for clarity.  Incompatible with -6.

   Specifying DHCPv4/BOOTP servers

   In  DHCPv4  mode,  a  list  of  one  or  more  server addresses must be
   specified on the command line, to which DHCP/BOOTP  queries  should  be
   relayed.

   Options available for both DHCPv4 and DHCPv6:

   -c COUNT
          Maximum  hop  count.  When forwarding packets, dhcrelay discards
          packets which have reached a hop count of COUNT.  Default is 10.
          Maximum is 255.

   -d     Force  dhcrelay  to  run  as  a foreground process.  Useful when
          running dhcrelay under a debugger, or running out of inittab  on
          System V systems.

   -p PORT
          Listen  and  transmit  on  port PORT.  This is mostly useful for
          debugging purposes.  Default is port  67  for  DHCPv4/BOOTP,  or
          port 547 for DHCPv6.

   -q     Quiet  mode.   Prevents  dhcrelay6  from  printing  its  network
          configuration on startup.

   -pf pid-file
          Path to alternate pid file.

   --no-pid
          Option to disable writing pid files.   By  default  the  program
          will write a pid file.

   Options available in DHCPv4 mode only:

   -a     Append  an  agent option field to each request before forwarding
          it to the server.  Agent option fields in  responses  sent  from
          servers  to  clients  will  be  stripped  before forwarding such
          responses back to the  client.   The  agent  option  field  will
          contain  two  agent  options:  the  Circuit ID suboption and the
          Remote ID suboption.  Currently, the  Circuit  ID  will  be  the
          printable  name of the interface on which the client request was
          received.   The  client  supports  inclusion  of  a  Remote   ID
          suboption as well, but this is not used by default.

   -A LENGTH
          Specify  the  maximum  packet  size  to  send  to a DHCPv4/BOOTP
          server.  This might  be  done  to  allow  sufficient  space  for
          addition  of  relay  agent  options while still fitting into the
          Ethernet MTU size.

   -D     Drop packets from upstream servers if they contain  Relay  Agent
          Information   options  that  indicate  they  were  generated  in
          response to a query that came via a different relay  agent.   If
          this  option  is  not  specified,  such  packets will be relayed
          anyway.

   -i ifname
          Listen for DHCPv4/BOOTP queries on interface  ifname.   Multiple
          interfaces  may  be  specified by using more than one -i option.
          If no interfaces are specified on  the  command  line,  dhcrelay
          will  identify all network interfaces, eliminating non-broadcast
          interfaces if possible, and attempt to listen on all of them.

   -m append|replace|forward|discard
          Control the handling of incoming DHCPv4  packets  which  already
          contain  relay  agent  options.   If such a packet does not have
          giaddr set in its header, the DHCP standard  requires  that  the
          packet be discarded.  However, if giaddr is set, the relay agent
          may handle the situation in four ways:  It may  append  its  own
          set  of relay options to the packet, leaving the supplied option
          field intact; it may replace the existing agent option field; it
          may forward the packet unchanged; or, it may discard it.

          To use this option you must also enable the -a option.

   Options available in DHCPv6 mode only:

   -I     Force  use  of  the  DHCPv6 Interface-ID option.  This option is
          automatically  sent  when  there  are  two  or  more  downstream
          interfaces  in use, to disambiguate between them.  The -I option
          causes dhcrelay to send the option even if  there  is  only  one
          downstream interface.

   -s subscriber-id
          Add  an option with the specified subscriber-id into the packet.
          This feature is for testing rather than production  as  it  will
          put the same subscriber-id into the packet for all clients.

   -l [address%]ifname[#index]
          Specifies the ``lower'' network interface for DHCPv6 relay mode:
          the interface on which queries will be received from clients  or
          from  other  relay  agents.   At  least  one  -l  option must be
          included in the command line when running in DHCPv6  mode.   The
          interface  name  ifname  is  a  mandatory  parameter.   The link
          address can be specified by address%; if it isn't, dhcrelay will
          use   the   first   non-link-local  address  configured  on  the
          interface.   The  optional  #index   parameter   specifies   the
          interface index.

   -u [address%]ifname
          Specifies the ``upper'' network interface for DHCPv6 relay mode:
          the interface to which queries  from  clients  and  other  relay
          agents  should  be  forwarded.   At  least one -u option must be
          included in the command line when running in DHCPv6  mode.   The
          interface  name ifname is a mandatory parameter. The destination
          unicast or multicast address can be specified  by  address%;  if
          not  specified,  the  relay  agent  will  forward  to the DHCPv6
          All_DHCP_Relay_Agents_and_Servers multicast address.

   It is possible to specify the same interface with  different  addresses
   more  than once, and even, when the system supports it, to use the same
   interface as both upper and lower interfaces.

SEE ALSO

   dhclient(8), dhcpd(8), RFC3315, RFC2132, RFC2131.

BUGS

   Using the same interface on both upper and lower sides may cause loops,
   so  when running this way, the maximum hop count should be set to a low
   value.

   The loopback interface is not (yet) recognized as a valid interface.

AUTHOR

   dhcrelay(8) To  learn  more  about  Internet  Systems  Consortium,  see
   https://www.isc.org

                                                               dhcrelay(8)





Opportunity


Personal Opportunity - Free software gives you access to billions of dollars of software at no cost. Use this software for your business, personal use or to develop a profitable skill. Access to source code provides access to a level of capabilities/information that companies protect though copyrights. Open source is a core component of the Internet and it is available to you. Leverage the billions of dollars in resources and capabilities to build a career, establish a business or change the world. The potential is endless for those who understand the opportunity.

Business Opportunity - Goldman Sachs, IBM and countless large corporations are leveraging open source to reduce costs, develop products and increase their bottom lines. Learn what these companies know about open source and how open source can give you the advantage.





Free Software


Free Software provides computer programs and capabilities at no cost but more importantly, it provides the freedom to run, edit, contribute to, and share the software. The importance of free software is a matter of access, not price. Software at no cost is a benefit but ownership rights to the software and source code is far more significant.


Free Office Software - The Libre Office suite provides top desktop productivity tools for free. This includes, a word processor, spreadsheet, presentation engine, drawing and flowcharting, database and math applications. Libre Office is available for Linux or Windows.





Free Books


The Free Books Library is a collection of thousands of the most popular public domain books in an online readable format. The collection includes great classical literature and more recent works where the U.S. copyright has expired. These books are yours to read and use without restrictions.


Source Code - Want to change a program or know how it works? Open Source provides the source code for its programs so that anyone can use, modify or learn how to write those programs themselves. Visit the GNU source code repositories to download the source.





Education


Study at Harvard, Stanford or MIT - Open edX provides free online courses from Harvard, MIT, Columbia, UC Berkeley and other top Universities. Hundreds of courses for almost all major subjects and course levels. Open edx also offers some paid courses and selected certifications.


Linux Manual Pages - A man or manual page is a form of software documentation found on Linux/Unix operating systems. Topics covered include computer programs (including library and system calls), formal standards and conventions, and even abstract concepts.