irclogger is a simple irc logger with a fluid web interface, search function, and a live streaming mode where new messages automatically appear in today's log.
- A Debian-based system (any other *nix can be used, but init scripts are written for Debian)
- Ruby >= 1.9.3
- MySQL >= 5 or PostgreSQL >= 9.3
- Redis >= 2.7
- Nginx
- Make sure all dependencies are installed and configured.
- Create a MySQL database and import the schema from
config/sql/mysql-schema.sql
, or, create a PostgreSQL database and import the schema fromconfig/sql/postgresql-schema.sql
. - Run
bundle install --deployment --without postgresql
if you use MySQL, orbundle install --deployment --without mysql
if you use PostgreSQL. - Copy
config/application.yml.example
toconfig/application.yml
. - Edit
config/application.yml
. The fields should be self-documenting. - Copy
config/nginx.conf.example
to/etc/nginx/sites-enabled/irclogger
. Edit theserver_name
,root
andupstream
directives to match your setup. - Copy
config/init.d/*
to/etc/init.d/*
. Edit theROOT
andSTART_ARGS
fields to match your setup. - Run
update-rc.d irclogger-logger defaults && update-rc.d irclogger-viewer defaults
. - Reload nginx confguration.
- Start logger and viewer with
service irclogger-logger start && service irclogger-viewer start
.
- Edit
config/application.yml
. - Restart logger with
service irclogger-logger restart
.
Make sure that whatever method you use for restarting the logger does not leave old instances around.
The channel list only appears on the domain that matches the "domain" field in application.yml. This is done to allow pointing other domains to the main one via CNAME, e.g. see logs.jruby.org.
git pull
- Read the git log. I will mention if the updates change the schema, include breaking changes, etc.
- Run
bundle install --deployment
. - Restart logger and viewer with
service irclogger-logger restart && service irclogger-viewer restart
.
After updating Gemfile.lock
, run bundix -l
to update gemset.nix
. At the moment bundix
must be run on Nix or from this branch.