File: INSTALL

package info (click to toggle)
inn2 2.2.2.2000.01.31-5
  • links: PTS
  • area: main
  • in suites: potato
  • size: 5,424 kB
  • ctags: 5,722
  • sloc: ansic: 61,219; perl: 9,939; sh: 5,644; makefile: 1,695; awk: 1,567; yacc: 1,548; lex: 249; tcl: 3
file content (774 lines) | stat: -rw-r--r-- 38,281 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
Welcome to INN 2.2.2!

  Please read this document thoroughly before trying to install INN. You'll be
  glad you did.

  If you are upgrading from a previous release of INN (pre-2.0) then it is
  recommended that you make copies of your old configuration files and use them
  as guides for doing a clean installation and configuration of 2.2.2. Many
  config files have changed, some have been added, and some have been removed.
  You'll find it much easier to start with a fresh install than to try to
  update your old installation.

Supported Systems

  < Should list all supported OS/hardware configurations >

  FreeBSD 2.2.x, 3.x
  Linux 2.0.x (with libc 5.4 or libc 6.0)
  OpenBSD ?.?
  SCO 5.0.4 (tested with gcc 2.8.1)
  Solaris 2.5.x
  Solaris 2.6.x
  SunOS 4.1.4
  UX/4800 R11 and up
  AIX 4.2

Before You Begin  <A note here about required packages>

  + INN requires Perl to build and to run several subsystems.  Though
    some perl scripts are compatible with Perl 4, some features (such as
    script embedded in the server) mandate Perl 5.  An audit has not yet
    been done on what the minimum version of Perl for all features is, so
    it is recommended that you have at least Perl version 5.004.  For
    instructions on obtaining and installing Perl, see
    http://language.perl.com/info/software.html.

  + The INN Makefiles use the syntax "include FILE", rather than the
    syntax common on BSDish systems of ".include <FILE>".  If your system
    expects the BSDish syntax, you can address this in two ways: change
    each Makefile's "include" lines, or install GNU Make from
    ftp://ftp.gnu.ai.mit.edu.  If you choose the latter route, make
    sure that the "make" command in site/do-subst.sh points to GNU Make.

  + If you want to enable support for authenticated control messages (this is
    NOT required) then you will need to install PGP.  There are some questions
    involving PGP's license if you are running a commercial installation of
    INN (i.e. you are an ISP).  See http://www.pgp.com for more information
    about PGP.

    <I'm completely confused by the PGP site now.  Someone more familiar with
     it needs to update this entry.  I always did a make install in FreeBSD
     ports dirs :)>

Unpacking the Distribution

  Obtain the INN source distribution from ftp.isc.org in directory
  /isc/inn/snapshots.  The files in the snapshots directory are snapshots of
  the current inn source taken daily.  They are stored in date format, i.e.
  0400 5 May 1998 GMT's file is named inn-1998-05-17_04-00.tar.gz.  Choose the
  newest file.  The distribution is in gzip compressed tar archive format.  To
  extract it, execute:

     gunzip -c <inn-src-file> | tar -xf -

  Extracting the source distribution will create a directory named inn where
  the source resides.

Choosing an Article Storage Format

  INN supports three methods of storing articles on your system. Each method
  has specific advantages and disadvantages. These storage methods are:

  traditional - This is the storage method used by all previous versions of
                INN.  Articles are stored as individual text files whose names
                are the same as the article number. The articles are divided up
                into directories based on the news group name. For example,
                article 12345 in news.software.nntp would be stored in the
                article spool under the path "news/software/nntp/12345".

                   Advantages: solid time-tested code, compatible with all of
                               the third-party INN add-ons available, gives you
                               fine control over article retention times.

                Disadvantages: takes a fast computer with a fast I/O system
                               to keep up with current USENET traffic volumes
                               due to file system overhead. Groups with heavy
                               traffic tend to create a bottleneck because of
                               inefficiencies in storing large numbers of
                               article files in a single directory.
                              
    timehash  - Articles are stored as files like in the traditional storage
                method, but are divided up into directories based on the
                arrival time so so that no directory contains enough files to
                cause a bottleneck.

                   Advantages: Heavy traffic groups do not cause bottlenecks,
                               fine control of article retention time still
                               possible.

                Disadvantages: Still suffers from speed degradation due to
                               filesystem overhead.

    cnfs      - CNFS stores articles sequentially in pre-configured buffer
                files.  When the end of the buffer is reached articles new
                articles are stored from the beginning of the buffer,
                overwriting older articles.
 
                   Advantages: Blazingly fast because no file creations or
                               deletions are necessary to store an article.
                               Does not require manual article expiration; old
                               articles are deleted to make room for new ones
                               when the buffers get too full. Also, with CNFS
                               your server will never throttle itself due to a
                               full spool disk, and you can restrict groups to
                               just certain buffer files so that they can never
                               use more than the amount of disk space you
                               allocate to them.

                Disadvantages: Article retention times are more difficult to
                               control because old articles are overwritten
                               automatically.

  In general, if you plan to carry a full news feed and want to actually have
  your server keep up with the traffic you should be using CNFS. If you just
  want to carry a subset of the full newsgroup hierarchy (such as everything
  but the binaries group) then we suggest the traditional storage method.

Installing INN

  Before beginning installation you should make sure that there is a user
  on your system named 'news', and that this user's primary group is set to
  a group called 'news'. The home directory of this user should be set to
  the directory under which you wish to install INN ("/usr/local/news" is the
  default and is a good choice).  INN will install itself as this user and
  group. You can change these if you want but these are the defaults and it's
  easier to stick with them on a new installation.

  INN now uses the GNU 'configure' program to make configuration rather
  painless.  Unless you have a rather abnormal setup configure should be able
  to completely configure INN for your setup. If you want to change the
  defaults you can invoke the configure script with one or more command line
  options. The most commonly used options are described below.

  Note for SCO 5.0.4... configure insists that syslog doesn't work for SCO
  and so sets the following as missing: syslog.3 syslog.c syslog.o in the 
  config/config.data file. You need to manually delete those entries before
  trying to make the distribution.

  --prefix=PATH           Sets the installation prefix for INN. The default
                          is /usr/local/news. All of INN's programs and support
                          files will be installed under this directory. You
                          should set this to the home directory of your "news"
                          user (it will make installation and maintenance
                          easier). Defaults to "/usr/local/news".

  --enable-tagged-hash    Use tagged hash table for the history database.
                          The tagged hash format uses much less memory but is
                          somewhat slower. This option is recommended if you
                          have less than 256 MB of RAM on your news server.
                          If your server disables tagged hash and expire takes
                          many hours, you should check the amount of RAM to
                          satisfy the following formula.  If it doesn't
                          satisfy, you should enable tagged hash and rebuild
                          dbz files.

                          n > (6 + extendeddbz ? 12 : 4) * tablesize

                          n:           amount of RAM
                          extendeddbz: extendeddbz in inn.conf
                          tablesize:   value in 3rd field on the 1st line in
                                       history.dir
                          NOTE: --with-largefiles can not be used with
                          --enable-tagged-hash

  --with-perl             Enables support for Perl, allowing you to install
                          filter scripts written in Perl. Highly recommended,
                          because many of the really good spam filters are
                          written in Perl. You will need Perl 5.004 or later
                          installed on your system to enable this option.

  --with-tcl              Enables support for TCL (Tool Command Language). This
                          allows you to install filter scripts written in TCL.
                          Most available filters seem to be written in Perl
                          these days, so you can safely leave out TCL support.
                          If you choose to enable this then you will need to
                          have a suitable TCL distribution installed.

  --disable-shared        Do not create shared libraries

  --disable-static        Do not create static libraries

  A suggested set of options, provided you have the necessary software
  installed, is "./configure --with-perl".

  If the configure program runs successfully, then you are ready to build the
  distribution. From the root of the INN source tree, type:

        make

  Again, please note that for SCO 5.0.4, you need to edit the 
  config/config.data file to delete the references to syslog.3 syslog.c and 
  syslog.o before running the make command.

  At this point you can step away from the computer for a little while and have
  a quick snack while INN compiles.  On a decently fast system it should only
  take five or ten minutes at the most to build.

  Once the build has completed successfully, you are ready to install INN into
  its final home. Type:

        make install

  This will install INN under the install directory (/usr/local/news, unless
  you specified something else to the configure script.) You are now ready for
  the really fun part: configuring your copy of INN!

Configuring INN

  From this point on we will assume that you have set up the news user on your
  system as suggested in the Installation section above so that the root of the
  INN installation on your system is accessible as "~news/".

  All of INN's configuration files are located in the ~news/etc directory. 
  Unless noted otherwise, any files referred to below are in this directory.

  Before we begin, it is worth mentioning the wildmat pattern matching syntax
  used in many configuration files. These are simple wildcard matches using
  the asterisk ("*") as the wildcard character, much like the simple wildcard
  expansion used by Unix shells (but unlike Unix shells, you cannot do full
  regular expressions; only the asterisk is supported).

  In many cases, wildmat patterns can be specified in a comma-separated list
  to indicate a list of newsgroups.  When used in this fashion, each pattern
  is checked in turn to see if it matches, and the last pattern in the line
  that matches the group name is used. Patterns beginning with "!" mean to
  exclude groups matching that pattern. For example:

        *, !comp.*, comp.os.*

  In this case, we're saying we match everything ("*"), except that we don't
  match anything under comp ("!comp.*"), unless it is actually under the
  comp.os hierarchy ("comp.os.*"). This is because non-comp groups will
  match only the first pattern (so we want them), comp.os groups will match
  all three patterns (so we want them too, because the third pattern counts
  in this case), and all other comp groups will match the first and second
  patterns and will be excluded by the second pattern.

  In most INN configuration files, lines beginning with a "#" symbol
  are considered comments and are ignored. Any deviations from this
  practice will be noted in the description for that particular file.
  
  1. inn.conf (REQUIRED)

  The first, and most important file is inn.conf. This file is organized as
  a series of parameter-value pairs, one per line.  The parameter is first,
  followed by a colon and one or more whitespace characters and the value
  itself. For some parameters the value is a string or a number; for others
  it is "yes" or "no."

  The inn.conf file contains dozens of changeable parameters, but only a few
  really need to be edited during normal operation:

  organization         Set to the name of your organization as you want it to
                       appear in the Organization: header of all local posts.
                       This will be overridden by the value of the ORGANIZATION
                       environment variable (if it exists). If neither this
                       parameter nor the environment variable or set then no
                       Organization: header will be added.

  pathhost             This is the name of your news server as you wish it to
                       appear in the Path header of all postings which travel
                       through your server (this includes local posts and
                       incoming posts that you forward out to other sites).
                       If no pathhost is specified then the FQDN of the
                       machine will be used instead.

  domain               Sets the domain name for your server. Normally this
                       is determined automatically by INN, but in some cases
                       it is necessary to set it manually. For example, if you
                       are running NIS on a SunOS system -and- your hostnames
                       are not fully-qualified (ie, your systems are named
                       xxxx instead of xxxx.domain.com) then you will need to
                       use this option to set your domain name manually. If in
                       doubt, leave this option commented out or remove it
                       completely.

  complaints           If present this address is used to add an
                       X-Complaints-To: header to all local posts. The usual
                       value would be something like "abuse@your.domain" or
                       "postmaster@your.domain". If not specified then the
                       newsmaster email address will be used.

  allownewnews         If set to "yes" then INN will support the NEWNEWS
                       command for news readers. This will really kill your
                       server performance and it is strongly suggested that
                       you set this to "no".

  status
  timer                Determines how often status and timer updates are
                       written to the log files. The value is specified in
                       seconds with a value of 0 disabling logging. The
                       suggested value is 300 seconds (5 minutes.)

  storageapi           Set to "yes" if articles should be stored using the
                       Storage Manager API. You must set this to "no" if you
                       are using the traditional article storage method or
                       "yes" if you are using timehash or cnfs.  See the 
                       section "Choosing an Article Storage Format" for more
                       information.

  extendeddbz          This is only used if you did not configure INN for
                       tagged hash and you are using the storage API. If set
                       to "yes", then overview offset information for articles
                       is stored in the DBZ history hash file as well as in the
                       history text file. This will make the hash file three
                       times larger, but should increase performance for news
                       readers when they retrieve article overview information.
                       If you don't mind using 200-300 MB of extra space for
                       your history database and memory then you should set
                       this to "yes".

  nnrpdoverstats       If set to "yes" then nnrpd will log statistics about
                       how much time was spent during the various stages of
                       reading article overview information. Not terribly
                       useful unless you are trying to track down news reader
                       performance problems.

  hiscachesize         The size in kilobytes to use for caching recently used
                       history file entries. Setting this to 0 disables history
                       caching. History caching can greatly increase the
                       number of articles per second that your server is
                       capable of processing.  A value of 16384 (16 MB) is a
                       good choice if you can spare the RAM.

  overviewmmap         Overview data is mmaped and reading overview would be
                       faster with this.  Note that on some systems (NextStep
                       and IRIX-6.5 are reported so far) it would be worse than
                       ever.  For those systems overviewmmap should be "no".

  usecontrolchan       All control messages except for the cancel will never
                       processed by external program fork'ed by innd.  To
                       reduce excessive load when many control messages arrive
                       in a short time, this is useful and recommended.
                       Controlchan will log its error to syslog, if Sys::Syslog
                       is available.  Otherwise it logs to errlog.  To enale
                       Sys::Syslog, you need to do following:

                          # cd /usr/include
                          # h2ph *
                          # cd /usr/include/sys
                          # h2ph *

  logipaddr            Set false, if controlchan is used and ihave/sendme setup
                       is required.  Or ihave and sendme cannot get correct
	               name, then the messages are incorrect.

  innflags             This allows you pass flags to the INN server process
                       when it starts up.  If you use the `crosspost' feed
                       (which is recommended) then you must set this to `-L'.

  2. newsfeeds (REQUIRED)

  The newsfeeds file determines how incoming articles are redistributed to
  your peers and to other INN processes. The newsfeeds file is very
  versatile and contains dozens of options; we will touch on just the
  basics here. The newsfeeds(5) man page contains more detailed
  information.

  The newsfeeds file is organized as a series of feed entries. Each feed
  entry is composed of four fields separated by colons. Entries may span
  multiple lines by using the backslash (\) to indicate that the next line
  is a continuation of the current line.

  The first field in an entry is the name of the feed. It must be unique,
  and for feeds to other news servers it is usually set to the actual
  hostname of the remote server (this makes things easier). The name can
  optionally be followed by a slash and an exclude list. If the feed name
  or any of the names in the exclude list appear in the Path line of an
  article, then that article will not be forwarded to the feed as it is
  assumed that it has passed through that site once already. The exclude list
  is useful when a news server's hostname is not the same as what it puts in
  the Path header of its articles, or when you don't want a feed to receive
  articles from a certain source.

  The second field specifies a set of desired newsgroups and distribution
  lists, given as newsgroup-pattern/distribution-list. The distribution list
  is not described here; see the newsfeeds(5) man page for information. The
  newsgroup pattern is a wildmat-style pattern list as described above, with
  one minor addition: patterns beginning with "@" will cause any articles
  posted to groups matching that pattern to be dropped, even if they match
  patterns for groups that ARE wanted. Otherwise, articles that match both
  "want" and "don't want" patterns are sent.

  The third field is a comma-separated list of flags that determine both the
  type of feed entry and sets certain parameters for the entry. See the
  newsfeeds(5) man page for information on the flag settings.

  The fourth field is a multi-purpose parameter. Its usage depends on the
  settings of the flags in the third field. Again, see the man pages for
  more information.

  Now that you have a rough idea of the file layout, we'll begin to add the
  actual feed entries.  First we'll set up the special ME entry. This entry is
  required and serves two purposes. First, the newsgroup pattern specified
  for this entry is prepended to the newsgroup list of all other feeds; second,
  the ME entry's distribution pattern determines what distributions are
  accepted from remote sites by your server. The default ME entry in the
  newsfeeds file probably won't suit your tastes; a good starting point would
  be a subscription pattern of "*,!junk,!local*" and a distribution list of
  "!local". This will mean that by default all sites will receive all groups
  except the junk group and groups in the local.* hierarchy, and that you will
  receive any distributions except those marked as "local" (any such articles
  are probably being leaked out by a misconfigured server).

  Next we'll set up special entries for the overchan, innfeed, controlchan(if
  you set 'usecontrolchan: true' in inn.conf) and (if you're not using cnfs or
  timehash) crosspost programs. There are already entries for these programs in
  the default newsfeeds file; you need only uncomment them and edit the
  pathnames to the programs to match your setup (there are two entries for
  overchan, one for use with the Storage Manager API and one for use without
  it; uncomment only the one matching your setup) . Assuming you installed INN
  under the default path of /usr/local/news then the appropriate feed entries
  would look like this:

  For traditional storage method:

        overview!:*:Tc,WO:/usr/local/news/bin/overchan

        crosspost:*:Tc,Ap,WR:/usr/local/news/bin/crosspost

        innfeed!:\
                !*\
                :Tc,Wnm*,S16384:/usr/local/news/bin/startinnfeed -y

  For cnfs or timehash storage method:

        overview!:*:Tc,Ao,WhR:/usr/local/news/bin/overchan

        innfeed!:\
                !*\
                :Tc,Wnm*,S16384:/usr/local/news/bin/startinnfeed -y

  If the server will not be supporting readers (a transit news server only),
  it's not necessary to run overchan.  If you do that, however, and you're
  using CNFS or timehash, be sure to leave overview.ctl empty so that INN
  doesn't generate overview information either.  See the information about
  overview.ctl below.

  Finally, you need to add entries for any actual sites to which you will
  be feeding articles. They will all have the same general format:

        my-feed-site.domain.com/exclude-list\
                :newsgroup-list\
                :Tm:innfeed!

  Set the feed name to the name of the remote site, and if the site uses a
  name other than its host name for Path headers then put that in the
  exclude-list (if your exclude list is empty, leave out the "/" after the
  site name as well). The newsgroup list can be left empty if the default
  newsgroup pattern from your ME entry is sufficient; otherwise, set the
  newsgroup pattern appropriately. The last line should not be modified.

  As for controlchan, this is useful and strongly recommended to setup.
  Processing by controlchan can reduce excessive load if many control messages
  arrive in a short time.  To enable controlchan:

         controlchan!\
                 :!*,control,control.*,!control.cancel\
                 :Tc,Wnsm:/usr/local/news/bin/controlchan

  3. incoming.conf (REQUIRED)

  The incoming.conf file describes what machines are allowed to connect to
  your host to feed articles. In previous versions of INN a different
  file (hosts.nntp) was used to do some of what incoming.conf can do.

  You can get started for a single feed by adding an entry like this:

         peer my-feed-site.domain.com {
         }

  ..assuming that you will be receiving articles from 
  my-feed-site.domain.com.  Note that this doesn't cause remote sites
  to start feeding you news - it merely allows them to do so if they so
  choose.

  See the incoming.conf man page for full details.

  4. cycbuff.conf (Required only if using the CNFS article storage method)

  CNFS stores articles in logical objects called "metacycbuffs." Each of the
  metacycbuffs is in turn composed of one or more physical buffers called
  "cycbuffs." As articles are written to the metacycbuff each article is
  written to the next cycbuff in the list in a round-robin fashion. This is
  so that you can distribute the individual cycbuffs across multiple physical
  disks and balance the load between them.

  There are two ways to create your cycbuffs:

      1. Use a raw disk partition (best). This will give you the most speed,
         but it required that your OS support mmap()'ing a block device.
         Solaris supports this, FreeBSD and Linux do not. Also on many PC-
         based Unixes it is difficult to create more than eight partitions,
         which severely limits your options.

      2. Use a real file on a filesystem. This will be a bit slower than using
         a raw disk partition, but it should work on any Unix system.

  If you're having doubts, use option #2.

  Now you need to decide on the sizes of your cycbuffs and metacycbuffs. You'll
  probably want to separate the heavy-traffic groups (alt.binaries.* and maybe
  even the rest of alt.*) into their own metacycbuff so that they don't
  overrun the server and push out articles on the more useful groups. If you
  have any local groups that you want to stay around for a while then you
  should put them in their own metacycbuff as well.
   
  For each metacycbuff, you now need to determine how many cycbuffs will
  make up the metacycbuff, the size of those cycbuffs and where they will
  be stored. Some OSs do not support files larger than 2 GB which will force
  all of your cycbuffs to be < 2GB (even if they are stored on raw disk
  partitions). Linux is known to have this limitation, FreeBSD does not. If in
  doubt, keep your cycbuffs smaller than 2 GB. Also when laying out your
  cycbuffs you will want to try to arrange them across as many physical disks
  as possible (or use a striped disk array and put them all on that).

  For each cycbuff you will be creating, add a line to the cycbuff.conf file
  like the following:

        cycbuff:BUFFNAME:/path/to/buffer:SIZE

  BUFFNAME must be unique and must be < 8 characters in length. Something
  simple like "BUFF00", "BUFF01", etc. is a decent choice. SIZE is the buffer
  size in kilobytes (1000000 KB is approximately one GB, so if you are
  trying to stay under 2 GB then cap your sizes at 2000000).

  Now, you need to tell INN how to group your cycbuffs into metacycbuffs.
  This is similar to creating cycbuff entries:

        metacycbuff:BUFFNAME:CYCBUFF,CYCBUFF,CYCBUFF

  BUFFNAME is the name of the metacycbuff, and like cycbuff names must be
  unique and <= 8 characters long. These should be a bit more meaningful than
  the cycbuff names since they will be used in other config files as well.
  Try to name them after what will be stored in them; for example if this
  metacycbuff will hold alt.binaries postings, then "BINARIES" would be a good
  choice. Finally, the last part of the name is a comma-separated list of all
  of the cycbuffs that should be used to build this metacycbuff. Each cycbuff
  should only appear in -one- metacycbuff line.

  5. storage.conf (Required only if using the CNFS or timehash storage methods)

  The storage.conf file maps newsgroups into storage classes, which determine
  where and how the article is stored. This file has a very simple format;
  each line defines a storage class for articles. The first matching storage
  class is used to store the article; if no storage class matches then INN will
  reject that article.

  A storage class is defined as a grouped entry consisting of size, expires and
  other parameters:

        methodname:newsgroup pattern:storage class #:minsize:maxsize:options

        method <methodname> {
            newsgroups: <wildmat>
            class: <storage_class>
            size: <minsize>[,<maxsize>]
            expires: <mintime>[,<maxtime>]
            options: <options>
        }
  
  The grouped, "methodname", is the name of the storage method used to
  store articles in this storage class. It should be set to "cnfs", "timehash",
  or the special storage method "trash" (which accepts the article but does
  not actually store it anywhere). Note that "traditional" is not a valid
  method name; the Storage Manager does not support traditional article
  storage, and if you are using traditional method then you should skip to the
  next section.

  The first parameter is a wildmat pattern in the same format used by the
  newsfeeds file, and determines what newsgroups are accepted by this storage
  class.

  The second parameter is a unique number identifying this storage class and
  should be between 0 and 255. It is used primarily to control article
  expiration.

  The third parameter can be used to accept only articles in a certain
  size range into this storage class. A maxsize of zero means no upper limit
  (and of course a minsize of 0 would mean no lower limit, because an article
  is always great than zero bytes long.)

  The fourth parameter can be used to accept only articles in a certain
  Expire range into this storage class. A maxtime of zero means no upper limit
  (and a mintime of non-zero would mean article never falls in this class, if 
  it includes Expires header.)

  The fifth parameter is the options parameter. Currently only CNFS uses this
  field; it should contain the name of the metacycbuff used to store articles
  in this storage class.

  For CNFS users, create one storage class for each metacycbuff that you have
  defined, listing what newsgroups are to be stored in that buffer.

  For timehash, the storage class IDs are used to store articles in separate
  directory trees so that different expiration policies can be applied to
  each storage class. You will need to divide up your newsgroups based on how
  long you want to retain articles in those groups, and create a storage class
  for each such collection of newsgroups. Make note of the storage class IDs
  you assign as they will be needed when you edit the expire.ctl file a bit
  later.

  6. overview.ctl (Required only if using the CNFS or timehash storage methods)

  The overview.ctl file determines where article overview information will be
  stored for each newsgroup. Overview is stored in one more more storage files
  identified by unique numbers between 0 and 254. Each line consists of the
  storage file number followed by a single colon and a wildmat pattern list
  of which newsgroups are to be stored in that file. As with storage.conf, the
  first matching line is used.

  If your server will not be supporting any readers (if it's for news transit
  only), you can leave this file empty and not run an overchan process (see
  above under newsfeeds).  As a result, no overview information will be
  generated and reading from the server will be impossible, but the server may
  run faster.  If you choose to do this, you won't be able to set expire times
  on a newsgroup by newsgroup basis, and if you're using timehash you'll have
  to use a different syntax in expire.ctl.  See the expire.ctl man page for
  details.

  The way in which you distribute articles across multiple overview storage
  areas is not an exact science; the goal is to spread access out across a
  number of smaller files rather than one large file. As a start we suggest
  creating 27 storage areas; the first 26 will be for newsgroups "a*" through
  "z*", and the 27th will be for "*" (thus catching any groups that start with
  a non-letter, of which there are several). You can change the layout in the
  future by modifying this file and then waiting for the daily news expiration
  to run, at which time the overview data will be re-arranged for you during
  the expiration process.

  7. expire.ctl (REQUIRED)

  The expire.ctl file is the configuration for the expiration policy. See
  the expire.ctl man page for more details.

  8. nnrp.access (REQUIRED)

  The nnrp.access file is the configuration for access to readers.

  Each line should have this format:

    host:access:user:password:groups

  The `host' field can take one of four forms:

    * an IP address, e.g. 192.168.0.1

    * an address range, e.g. 192.168.0.0/24

    * a hostname, e.g. userbox.example.com

    * a wildmat pattern that the hostname must match, e.g. *.example.com

  When checking the access rights for a particular host the last match
  is used.

  The `access' field shuold contain an "R" to allow read access and/or
  a "P" to allow posting access.  You can expand these to "Read" and
  "Post" as in the example that comes with INN.  See the man page for
  other things that can go here.

  See the man page for details of how to user the `user' and
  `password' fields.  Leave them blank to use solely host-based
  authentication.

  The `groups' field defines the newsgroups that a matching host may
  read as a comma-separated list of wildmat patterns.

  See the nnrp.access man page for more information.

Creating the article spool (CNFS only)

  If you are using actual files as your CNFS buffers then you will need to
  pre-create these files with the Unix "dd" program.  For each cycbuff in your
  cycbuff.conf file, create the buffer with the following commands as the news
  user:

        dd if=/dev/zero of=/path/to/buffer bs=1k count=BUFFERSIZE
        chmod 0664 /path/to/buffer

   Substitute the buffer pathname and the buffer size (as listed in the
   cycbuff.conf file) in the appropriate spots in the commands. This will
   create a zero- filled file of the correct length; it may take a while to
   run, so be prepared to wait.

   Once you have created all of your cycbuffs, you are ready to continue with
   the next step of the installation.

Creating the db files

  At this point you need to set up the news database directory (~news/db).
  To make things easier you should su to your news user; otherwise the files
  you create will be owned by root and you'll have to change the owner and
  group IDs on the files manually. You should also have your working directory
  set to the ~news/db directory, and ~news/bin should be in your PATH so that
  you can execute INN support commands without typing full pathnames.

  To begin you'll need current active and newsgroups files. These may be
  downloaded from the following location:

        ftp.isc.org:/pub/usenet/CONFIG

  Download the files "active" and "newsgroups" and place them in your ~news/db
  directory.

  Next you need to create an empty history database. This can be accomplished
  by running the following command:

        makehistory -i

  When it finished, you need to move history.n* to history*.
  Finally, set the file permissions on all of the files you just created:

        chmod 0664 *

  Your news database files are now ready to go.

Setting up the news.daily cron job

  INN requires a special cron job to be set up on your system to run the
  news.daily script, which performs daily server maintenance tasks such as
  article expiration and the processing and rotation of the server logs.
  Since it will slow the server down while it is running, it should be run
  during periods of low server usage, such as in the middle of the night. To
  run it at 3 am, for example, add the following entry to the news user's
  crontab file:

        0 3 * * * /usr/local/news/bin/news.daily expireover lowmark

  or, if your system does not have per-user crontabs, put the following line
  into your system crontab instead:

        0 3 * * * su -c "/usr/local/news/bin/news.daily expireover lowmark" news

  Also, a cron job should be set up to transmit to your upstream site any
  articles that have have been posted locally and queued for transmission,
  for example:

        1,11,21,31,41,51 * * * * /usr/local/news/bin/nntpsend

  The pathnames and user ID used above are the installation defaults; change
  them to match your installation if you used something other than the
  defaults.

  The parameters passed to news.daily in the above example are the most
  common (and usually the most efficient) ones to use. More information on what
  these parameters do can be found in the news.daily man page.

Starting the system

  INN is normally started via the shell script rc.news. This must be run as
  the news user and not as root. Put the following command (or something
  similar) into the system boot script:

	su news -c /usr/local/news/bin/rc.news

  If innd gets stopped or killed and you want to restart it without
  re-running rc.news, then run inndstart

	/usr/local/news/bin/inndstart

  If you added any values to the innflags variable in inn.conf, then you'll
  need to add the same values to the command line of inndstart if you run it
  by hand.