Skip to content
This repository
Fetching contributors…

Cannot retrieve contributors at this time

file 106 lines (70 sloc) 3.273 kb
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

This is yaws, a webserver for dynamic content written in Erlang.


To build and install


0. Get and install an erlang system (http://www.erlang.org)

1. If you've cloned the source from github, there is no ./configure
   script in the source, create one:

# autoconf


1.b Install build-deps. On Ubuntu/debian this is pretty much equal to
# apt-get build-dep yaws

:-)



2. ./configure --prefix=/usr/local
   This will install everything under /usr/local including var files
   in /usr/local/var/run/yaws and etc files in
   /usr/local/etc/yaws.*

  A plain ./configure will install executables under
  /usr/local/bin and libs in /usr/local/lib/yaws etc and
  var files will end up under /usr/local/etc and /usr/local/var


Note: We can also change the target directory for etc and var
      directories by using:

  --localstatedir=DIR for files that should go in /var
  --sysconfdir=DIR for files that should go in /etc
  --disable-pam If we for some reason do not want pam support
  --with-extrainclude=DIR Will add DIR to the include path
                      May be useful if e.g. pam is installed
somewhere where its usually not found
  --with-defaultcharset=String Will set the default charset used
                        in generated page headers. Usually never needed.
                        
This way you can precisely control where you install Yaws (This is
usefull for computers where you do not have right access to the
standard systemdirs).

For example:
./configure --prefix=/home/install/yaws --localstatedir=/home/install/yaws/var --sysconfdir=/home/install/etc


2b. Note to packagers (rpm, deb ...) All install targets support the
    DESTDIR variable.
    Thus, if we do ./configure --prefix=/usr; make
    we can subsequently do:
    DESTDIR=/foo/bar make install
    All yaws files will be installed under DESTDIR, but all
    code will assume yaws should be installed under /usr


3. make
     This will build the system

  make docs
     (Optional) You can issue this command if you want to build Yaws
     documentation.

  make local_install
     and perform something we call a
     local install. It will create an executable script in the $HOME/bin
     directory and a config file in $HOME/yaws.conf. This is for developers
     only

4. To test the build, Start as bin/yaws -i
     This will start a webserver at http://0.0.0.0:8000
     Terminate through ^C or
     > init:stop()

5. as root make install

6. as root start as /usr/local/bin/yaws -i
   (this starts an interactive system)

7. This will create a webserver at http://${host} and one at https://${host}

8. as root edit /usr/local/etc/yaws/yaws.conf

9. Create content in /usr/local/var/yaws

10a. Start as /usr/local/bin/yaws --daemon --heart
     This will start a daemon (--daemon) which will be autorestarted when/if
     it crashes or hangs (--heart)
     Also, for most unices, we create proper start scripts in
     /etc/init.d (sysconfdir)

10b. Or start interactive system as /usr/local/bin/yaws -i


11. Example: Here is how I compile/start the yaws system that runs
     at http://yaws.hyber.org (Ubuntu server system)

     # autoconf
     # ./configure --sysconfdir=/etc
     # make && make install
     # /etc/init.d/yaws start
Something went wrong with that request. Please try again.