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 postgresqlif you use MySQL, orbundle install --deployment --without mysqlif you use PostgreSQL. - Copy
config/application.yml.exampletoconfig/application.yml. - Edit
config/application.yml. The fields should be self-documenting. - Copy
config/nginx.conf.exampleto/etc/nginx/sites-enabled/irclogger. Edit theserver_name,rootandupstreamdirectives to match your setup. - Copy
config/init.d/*to/etc/init.d/*. Edit theROOTandSTART_ARGSfields 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.