Troubleshooting Production

Summary: Known issues regarding running in production.

Known gotchas

displaying default admin set raises exception

Hyrax creates a default admin set that has a slash in its id (ā€œadmin_set/defaultā€). This means that unless your webserver is configured to allow encoded slashes, features that refer to the default admin set in the url will raise an exception. If you are using passenger on Ubuntu, you can fix this by adding this line to /etc/apache2/conf-enabled/passenger.conf:

PassengerAllowEncodedSlashes on

The actual syntax might vary depending on your webserver configuration.

ā€˜Failed to upgrade to WebSocketā€™ ERROR for Hyrax notifications

Itā€™s a known issue that Hyrax notifications donā€™t work with Apache and Passenger.

An alternative approach is to use puma and have Apache reverse proxy to the puma port. In this configuration, you may find that notifications still donā€™t work, with ERROR: Failed to upgrade to WebSocket repeatedly appearing in the logs.

The following configuration example has been successfully used as a fix for this issue in Centos7. Note, you will need mod_proxy and mod_proxy_wstunnel enabled.

Please note that this configuration MAY also work with Passenger, but has not been tested.

<VirtualHost *:80> ServerName localhost DocumentRoot /var/lib/hyku/public ProxyPreserveHost On # Needed for RIIIF image server AllowEncodedSlashes NoDecode <Directory /var/lib/hyku/public> Options Indexes FollowSymLinks AllowOverride None Require all granted </Directory> # Hyrax notifications require the following re-write configuration # otherwise notifications won't work and the log will contain lots of: # "ERROR: Failed to upgrade to WebSocket" # Enable the rewrite engine # Requires: sudo a2enmod proxy rewrite proxy_http proxy_wstunnel # In the rules/conds, [NC] means case-insensitve, [P] means proxy # See https://stackoverflow.com/questions/27526281/websockets-and-apache-proxy-how-to-configure-mod-proxy-wstunnel RewriteEngine On # socket.io 1.0+ starts all connections with a HTTP polling request RewriteCond %{QUERY_STRING} notifications/endpoint [NC] RewriteRule /(.*) http://localhost:3000/$1 [P] # When socket.io wants to initiate a WebSocket connection, it sends an # "upgrade: websocket" request that should be transferred to ws:// RewriteCond %{HTTP:Upgrade} websocket [NC] RewriteRule /(.*) ws://localhost:3000/$1 [P] ProxyPass / http://127.0.0.1:3000/ ProxyPassReverse / http://127.0.0.1:3000/ </VirtualHost>