home *** CD-ROM | disk | FTP | other *** search
/ GEMini Atari / GEMini_Atari_CD-ROM_Walnut_Creek_December_1993.iso / files / telecomm / nhclb120 / readme.2 < prev    next >
Text File  |  1993-09-26  |  15KB  |  337 lines

  1. KA9Q TCP is an implementation of TCP/IP for the PC.  This is a Unix
  2. port based on a version from mid-1989.  Unfortunately the more recent
  3. versions of KA9Q are harder to port to Linux.
  4.  
  5. I don't have a manual for this exact version.  There's builtin help.
  6. The commands primarily set parameters (the ip and tcp commands), or
  7. start services.  In general the same command is used to set and
  8. examine parameters.  When you type the command with no value, it shows
  9. the current value. 
  10.  
  11. To use KA9Q, put startup.net and possibly domain.txt in your home
  12. directory, and run "net".  You will probably need to tailor
  13. startup.net for your configuration.  See the section at the end of
  14. this document on configuration.  Note that you can give an argument to
  15. the "net" command.  It will be used as the startup file in place of
  16. startup.net.  By default, startup.net and other files are in your home
  17. directory (the value of the environment variable HOME).  You can put
  18. them somewhere else by using the environment variable NETHOME.
  19.  
  20. If you are using SLIP, note that you must first dial the modem and
  21. establish a SLIP connection.  The exact details on doing this are
  22. different at each site.  Unfortunately you're probably going to need
  23. help from system or network support staff in order to use SLIP.
  24. Because SLIP effectively connects you to someone's local network,
  25. using it normally requires logging in with a password.  I recommend
  26. using kermit's script facility to dial and set up SLIP.  It did not
  27. seem work adding a similar facility to KA9Q.
  28.  
  29. If your site does not current support SLIP, they will probably have to
  30. do a bit of systems work.  For Unix systems, typically this will
  31. involve adding a SLIP device driver, and then enabling routing.  (An
  32. appropriate driver is available for the Sun, although I don't know
  33. where.  I believe it can be installed without Sun source.)  Many
  34. terminal servers will support SLIP directly, so enabling it will
  35. merely involve changing a configuration file.
  36.  
  37. Aside from configuration commands (which typically go into
  38. startup.net), the most common commands are probably telnet and ftp.
  39. Both take a host name.  Once you are connected, the "escape character"
  40. (initially ^]) lets you do some special things.  You type it followed
  41. by another character. Except for the escape character, the characters
  42. are folded, so that c, C, and ^C are equivalent.  Here's a list of the
  43. special characters:
  44.  
  45.   escape character (i.e. two in a row) - send a real escape character
  46.   x or ^x - return to command mode
  47.   b or ^b - send break
  48.   c or ^c - send interrupt process
  49.   o or ^c - abort output
  50.   t or ^t - are you there?
  51.   h or ^h - send telnet erase character
  52.   u or ^u - send telnet erase line
  53.   ?       - print this help message
  54.   
  55. Once you return to command mode, the "session" command can be used to
  56. switch between connections.  With no arguments, it shows the current
  57. sessions.  With a number, it will reconnect you to that session.
  58. There's a disconnect command to kill a session (also some stronger
  59. ways of doing it).
  60.  
  61. Telnet normally operates in full duplex, with the other system
  62. echoing.  However if that system refuses echoing, or if you use the
  63. command "echo refuse", KA9Q will echo locally.  In this case you have
  64. the normal line editing functions.  Several control characters have
  65. special functions.  Note that in local echo mode, you do not need to
  66. hit the escape character first.
  67.  
  68.   escape character - return to command mode
  69.   ^v - quote the next character
  70.   ^b - send break
  71.   ^c - send interrupt process
  72.   ^o - abort output
  73.   ^t - are you there?
  74.  
  75. Telnet will pass your TERM environment variable as the terminal type
  76. if the other end asks for it.  It will implement flow control locally
  77. if the other end understand the remote flow control option.  If the
  78. other end does a "telnet sync" correctly, it will suppress output when
  79. appropriate.  E.g. when talking to a Unix system, if you type ^C or ^O
  80. in the middle of a large output, output should stop immediately.
  81. However there may be a pause before getting the next prompt, as some
  82. previously buffered data is probably still going to be transmitted.
  83.  
  84. The "ip stat" and "tcp stat" commands are useful to get statistics.
  85. "Ip stat" shows both the IP and SLIP level.  If header compression is
  86. being used, it will show how many packets were compressed and how many
  87. were oot.
  88.  
  89. FTP is sort of odd.  It looks like you are in an interactive
  90. conversation with the FTP server at the other end, with no local
  91. command prompt.  Most commands are passed directly to the remote
  92. server, but in fact there is a local command parser, which will
  93. intervene for a few commands:
  94.  
  95.    cd, dir, list, get, ls, mkdir, nlst, rmdir, put, type
  96.  
  97. get and put should be used to transfer files.
  98.  
  99. It's possible to run a server which others can connect to, though I
  100. haven't tried it except for ftp.  The command is "start ftp", etc.
  101. For ftp, a login is required.  The file ftpusers, in your home
  102. directory, contains a list of users and passwords.
  103.  
  104. Here's a list of commands:
  105.  
  106.    ! - call a recursive shell
  107.    arp - set arp parameters
  108.    ax25 - configure ham interface
  109.    attach - define an interface - must be used for each interface
  110.    bootp - request our IP address from a server
  111.    connect - for AX25, define call sign for interface
  112.    cd
  113.    close
  114.    disconnect
  115.    dir - do a directory on the local system
  116.    domain - configure domain name system
  117.    eaglestat
  118.    echo - refuse or accept - request to disable telnet remote echo
  119.    eol - Unix or standard end of line options [standard is recommended,
  120.     even for use on Unix systems]
  121.    escape - change escape character
  122.    etherstat
  123.    exit
  124.    finger
  125.    forward - divert packets from one interface to another
  126.    ftp - open an ftp connection
  127.    hapnstat
  128.    help - print command list
  129.    hostname - set/examine host name
  130.    kick
  131.    log
  132.    ip - set/examine IP level parameters
  133.    memstat
  134.    mbox, mode - AX25 commands
  135.    mulport
  136.    netrom
  137.    nrstat
  138.    param - set/examine interafce parameters
  139.    ping - send ping to a host
  140.    pwd 
  141.    rdate [offset] [host] - set date/time from UDP time daemon.  see below
  142.    record
  143.    remote
  144.    reset - kill connection
  145.    route - set up routes
  146.    session - see above: move to a different session
  147.    shell - call a subshell
  148.    smtp - mail handling
  149.    start - start server
  150.    stop - stop server
  151.    tcp - set/examine tcp parameters
  152.    telnet - open telnet connection
  153.    trace - enable low-level debugging (no arguments - show current status)
  154.     trace to <file> - put trace output on file (use "con" for console)
  155.     trace <device> [<bits>] - trace packets on device
  156.         device is typically "sl0" or "loopback"
  157.         bits are in hex:
  158.             1 - output, 10 - input (else no tracing)
  159.             100 - dump data in ascii, 200 - hex (else headers only)
  160.     trace cmdmode|allmode - show trace just when at command level?
  161.     trace telnet [on | off] - show telnet options and urgent data
  162.    udp - set/examine udp parameters
  163.    upload
  164.    wait - control mail select
  165.  
  166. The rdate command uses the old-style time protocol (often known as
  167. "rdate"), on UDP port 37, to get the date and time, and then sets the
  168. system clock.  Note that the protocol always gives time in GMT.  If
  169. your system clock is running on GMT (which is the normal way Unix
  170. should run), this is fine.  Otherwise, you'll need to specify the
  171. offset in minutes.  For time zones west of GMT, this should be a
  172. negative number. For the Eastern U.S., when not in daylight time, the
  173. offset is -300, because EST is 5 hours (300 minutes) west of GMT.
  174. If no host is specified, a UDP broadcast is used.
  175.  
  176. This configuration of KA9Q has been tested only with SLIP.  Code is
  177. also included for the KISS device (for ham radio) and Linux generic
  178. Ethernet support using /dev/eth.  /dev/eth should either work or come
  179. close to working: it's based on diffs made from a recent version of
  180. KA9Q.  I don't know of anyone who has tested KISS.  Past experience
  181. suggests that users will prefer Kermit to SLIP unless you use SLIP
  182. with header compression.
  183.  
  184. Note that this program depends up non-blocking I/O and the select
  185. system call.  In Linux 0.12, these did not work.  There are patches,
  186. nonblock.tar.Z and select.patch, on the major distribution machines.
  187. Don't forget: after patching a kernel source file, you must do a make
  188. in each directory where you changed a file.  The main make file
  189. doesn't rebuild things all the time when it should.  Linux 0.95
  190. and later has all the necessary patches.
  191.  
  192.  
  193. CONFIGURATION:
  194.  
  195. Here's some advice on preparing a configuration file.  I assume you're
  196. planning to use SLIP (dialup IP) or Ethernet.  I'm going to explain my
  197. configuration file line by line, as it's likely to be close to what
  198. you need:
  199.  
  200.    attach asy 0 /dev/tty64 cslip sl0 2048 1500 9600
  201.  
  202. You must include an attach command in every configuration file.  It
  203. defines the device.  For SLIP, the line above should be about right.
  204. Some variationos:
  205.    - /dev/tty64 is the serial line.  Obviously you can adjust this
  206.     to use a different line.
  207.    - cslip specifies SLIP with Van Jacobsen header compression.
  208.     If you're using normal slip, use "slip" instead of "cslip".
  209.     In my opinion, response on normal SLIP is too slow for it
  210.     to be very useful.
  211.    - 9600 is the line speed.  Use whatever speed you are set for.
  212.     If you have a "smart" modem, we recommend turning off
  213.     any error correction or compression.  These features
  214.     introduce enough delay to be objectionable.
  215.  
  216. The following attach command could be used for Linux generic
  217. Ethernet (/dev/eth)
  218.   attach linux arpa eth0 1500 1.2.3.fa.fb.fc
  219. The last item is your Ethernet hardware address, in hex.  It should
  220. be printed when your system boots.  E.g. if it prints 01 02 03 04 05 06
  221. then you put in 1.2.3.4.5.6.  Each of the six numbers is in hex, and
  222. may be one or two digits.
  223.  
  224.   wait 0
  225.  
  226. This should only be needed with older version of the kernel.  It
  227. disables the select system call.  Instead, runs in a tight loop
  228. continuously testing for input.  Unfortunately select has a history of
  229. problems under Linux.  It appears to be fine in version 0.96.  However
  230. in earlier version, select did not work properly when there was
  231. another program running.  (In some cases it works OK unless the other
  232. program uses select.  E.g.  if you enter emacs in another window, your
  233. FTP comes to a halt.)  If you are trying to use KA9Q while another
  234. program is running, and you find that the connection hangs, you might
  235. try "wait 0".  Otherwise, you should leave the default setting, which
  236. is "wait 100".  The argument to wait is in milliseconds.  It's the
  237. amount of time to wait in the main loop.  The select will trigger if
  238. input arrives on the serial line, or you hit a key.  Otherwise it
  239. waits this amount of time.  I don't recommend values larger than 100.
  240. Smaller values might possibly be useful in some siuations.
  241.  
  242.   route add default sl0
  243.  
  244. This says that all packets should be sent out the SLIP line.  Presumably
  245. this is what you want.  If you are using Ethernet, of course you'd
  246. use the name of your Ethernet device instead of sl0, e.g.
  247.   route add default eth0
  248.  
  249.   bootp
  250.  
  251. This says that the system will find out its IP address by sending a
  252. BOOTP request out the serial line.  Since dialups are normally  
  253. in "hunt groups", you will probably get a different line each time
  254. you dial up.  Thus your IP address will probably not be the same.
  255. BOOTP is a way of asking the terminal server (or whatever else
  256. you're connected to) to tell you your IP address.  If your terminal
  257. server does not support BOOTP, you explicitly set your IP address
  258. using a command of the form
  259.    ip address [1.2.3.4]
  260. where 1.2.3.4 is your IP address.  You would use this command
  261. instead of the BOOTP command.
  262.  
  263.   tcp mss 64
  264.   tcp window 256
  265.  
  266. These commands set TCP performance parameters.  These control a
  267. tradeoff between overall throughput, jerkiness of output, etc.  These
  268. parameters seem to give good performance for interactive connectionos.
  269. For FTP you might want larger values, particularly if you are going
  270. over a long-haul network like the Internet.  For FTP the best value
  271. for mss is at least 512, and probably more like 1024, with window
  272. between 2 and 4 times mss.  However Linux has fairly small buffers for
  273. the serial line, so you may not be able to get away with parameters
  274. much larger than the ones shown here.  If you are using Ethernet,
  275. of course you'll want larger values.  I suggest starting with
  276.   tcp mss 1460
  277.   tcp window 5840
  278. This should work for traffic on the local Ethernet.  If your 
  279. traffic tends to go through routers, a safer set of values is
  280.   tcp mss 512
  281.   tcp window 2048
  282.  
  283.   domain suffix rutgers.edu
  284.   domain add [128.6.4.4]
  285.  
  286. These parameters control the domain system.  That's the set of servers
  287. you use to look up host names.  You'll need to adjust these for your
  288. campus.  The suffix is tacked onto all host names you type, unless
  289. they already have a dot in them.  This lets you type "athos" instead
  290. of "athos.rutgers.edu".  Set it for the domain you most commonly use.
  291. The address 128.6.4.4 should be the address of a domain server on your
  292. campus.  All name lookups will be directed to that server.  You can
  293. define more than one, by using several "domain add" lines.
  294.  
  295. If your campus does not support the domain system, you can use a host
  296. table instead.  In that case you would omit the "domain" commands.
  297. The host table is called "domain.txt", in your home directory.  It's
  298. in the format of a domain master file.  The most important entries
  299. look like
  300.    athos.rutgers.edu. IN A 128.6.4.4
  301. Note that IN and A must be in upper case, and the name must include
  302. the whole suffix, and end in a dot. 
  303.  
  304. Note that this is a very old domain implementation, and is not up to
  305. the level of the current MS/DOS version.  It does not use TTL's.
  306. Every time you type a name, it first looks in domain.txt.  If there's
  307. an entry there, it will be used.  Otherwise, it will query the domain
  308. server you specified.  If it gets an answer, that information will be
  309. added to domain.txt.  If a host changes its address, you'll be in
  310. trouble, because you'll continue getting the old information from
  311. domain.txt.  Thus it's probably a good idea to remove domain.txt now
  312. and then.
  313.  
  314.   start finger
  315.   start telnet
  316.  
  317. These start daemons to respond to incoming finger and telnet
  318. connections.  This is optional, but most people will probably find
  319. them useful to help people find you.  The finger server uses files
  320. stored in a subdirectory "finger" of your home directory.  Files
  321. should have names of the form xxx.txt, where xxx is a user name.
  322. Finger with no arguments will list all users on the system (i.e.  it
  323. will look for all files ~/finger/*.txt, and list the names).  Finger
  324. with a specific user name will display the text of that file, i.e.
  325. ~/finger/xxx.txt.
  326.  
  327. The telnet server is really more like a talk link.  When someone
  328. telnets to your machine, you'll get a message saying that there is an
  329. incoming telnet connection.  At that point you should escape to the
  330. coommand level (using ^] or whatever your escape character is), do
  331. "session" to see the session number of the incoming connection and do
  332. "session NN" to connect to it.  At that point you'll be in an
  333. interactive link with the person.  There is also a server designed to
  334. allow "real" telnet connections, i.e. connections that create a real
  335. login session.  It is activated with the command "start telunix".
  336. However that code is incomplete, and currently does nothing useful.
  337.