-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathREADME
102 lines (71 loc) · 2.92 KB
/
README
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
# GoFish
data:image/s3,"s3://crabby-images/dbd93/dbd935bb8e4aaec132e526479cd509e23068a2c3" alt="C/C++ CI"
## What is this?
GoFish is my attempt to boost the performance of the current
gopherds. However, I do have some design goals. I am running GoFish on
my 'Winder <http://seanm.ca/>. While it is a great machine, it is not
the most powerful machine in the world.
### Design Goals
1) Secure. I do not plan on letting the server run executables.
2) Fast. At least as fast as a web server. I am using thttpd as my
benchmark.
3) Low resource usage. Single process.
4) Simple. The daemon will only serve files. Directory listings will
be read from the .cache files verbatim. I think this is an
important decision. It gives maximum flexibility to the
users. They can go from the exteme of writing all the cache files
by hand, to having some form of custom, fully automated file
insertion program. I plan on providing one such program called
`mkcache', but it will not be required.
## Where can I get it?
GoFish is hosted on SourceForge. Go to
[the project page](http://gofish.sourceforge.net)
and follow the instructions.
GoFish has also been forked on GitHub. Go to
[the project page](http://github.com/ludwhe/gofish)
and follow the instructions.
## Current assumptions
I am currently using the Linux mmap(2) call to write out the
files. Because of this, I do not process the files. The following
assumption must hold:
**Files must not have any lines containing only a ".".**
There is a script called check-files that will verify that the above
is true. If you have changed the GOPHER_ROOT, you must change it in
the check-files script also.
## How to build it
### From RPMs
If you are using the RPMS, you don't have to build it! Just install
the gofish rpm. If this is a first time install, backup anything in
your gopher root directory and install the gofish-setup rpm.
### From tarball
1) Untar the tarball. You should get a gofish-`version` directory.
2) cd gofish-`version`
3) `./configure`
or
`./configure --disable-http`
or for a redhat style install
`./configure --prefix=/usr --sysconfdir=/etc --localstatedir=/var`
4) `make`
5) `sudo make install`
## Optional features
GoFish contains a gopher to http gateway. This feature is enabled by
default. To disable the feature:
```sh
./configure --disable-http
```
The http gateway will honour favicon.ico requests. Drop a favicon.ico
file in the gopher root. mkcache ignores this file.
## Log rotation
GoFish supports log rotation. Move the log to a new name. Then send a
USR1 signal to GoFish. It will close the old log and create a new
file. No log entries will be lost. After the signal, the old log
should be up to date.
Example: (note that kill line uses backwards ticks, not single quotes)
```sh
mv /var/log/gopherd.log /var/log/gopherd.log.1
kill -USR1 `cat /var/run/gopherd.pid`
```
## Contact
You can contact me about problems/suggestions/donations.
Sean MacLennan