Ubuntu Server 17.10 64-bit with Zoneminder 1.30.4 the easy way

From ZoneMinder Wiki
Jump to navigationJump to search

<Home

Ubuntu 17.10 with LAMP

This is an interim procedure to install Zoneminder 1.30.4 on Ubuntu 17.10

Note: There have been several reports of things, like the API, not working with Zoneminder and Ubuntu 17.10. You are better off to use Ubuntu 16.04!

Note - installing Zoneminder this way will not prevent it from being overwritten when you do "apt upgrade" To prevent Zoneminder from being upgraded enter "sudo apt-mark hold zoneminder"

There are some issues with the Zoneminder package provided with Ubuntu 17.10. This is an alternate install procedure that uses the install package from the iconnor PPA for Zesty (Ubuntu 17.04)

This assumes you have installed Ubuntu 17.10 with LAMP.

You will need to make a settings change to MySQL as follows:

This removes the current symbolic link

rm /etc/mysql/my.cnf  

This moves the MYSQL Configuration file

cp /etc/mysql/mysql.conf.d/mysqld.cnf /etc/mysql/my.cnf

To change MySQL settings:

nano /etc/mysql/my.cnf

In the [mysqld] section add the following

sql_mode = NO_ENGINE_SUBSTITUTION

Note: if you are installing on an existing database server you can use the following as an alternate (Thanks to "bodom" for this alternate):

init_connect = 'SET @@sql_mode = CASE CURRENT_USER() WHEN \'zmuser@localhost\' THEN \'NO_ENGINE_SUBSTITUTION\' ELSE @@sql_mode END;'


Ctrl+o Enter to save

CTRL+x to exit

Restart MySQL

systemctl restart mysql

Download the Zoneminder install package from the iconnor PPA. Note this is for the 64 bit version.

wget https://launchpad.net/~iconnor/+archive/ubuntu/zoneminder/+build/12557069/+files/zoneminder_1.30.4-zesty1_amd64.deb

Install Zoneminder - Note: Change (user) to the user in the home directory on your system

apt install vlc-plugin-base /home/(user)/zoneminder_1.30.4-zesty1_amd64.deb

Note - installing Zoneminder this way will not prevent it from being overwritten when you do "apt upgrade" To prevent Zoneminder from being upgraded enter "sudo apt-mark hold zoneminder"

Create a new user

adduser www-data video

Enable CGI, Zoneminder and rewrite configuration in Apache.

a2enmod cgi
a2enconf zoneminder
a2enmod rewrite

Fix Permissions

chown -R www-data:www-data /usr/share/zoneminder/

Enable and start Zoneminder

systemctl enable zoneminder
service zoneminder start

Add timezone to PHP

nano /etc/php/7.1/apache2/php.ini

Search for [Date] (Ctrl + w then type Date and press Enter) and make changes as follows for your time zone. Make sure to remove the ; from the front of date.timezone

[Date]
; Defines the default timezone used by the date functions
; http://php.net/date.timezone
date.timezone = America/New_York

Ctrl+o Enter to save

CTRL+x to exit

Restart Apache

service apache2 reload


IMPORTANT FINAL STEP: Open Zoneminder in a web browser (http://server-ip/zm). Click on Options - Paths and change PATH_ZMS to /zm/cgi-bin/nph-zms

Ubuntu 17.10 with LEMP (NGINX, Mariadb and PHP)

Ubuntu 17.10 Nginx Mariadb PHP Zoneminder 1.30.4

Note - installing Zoneminder this way will not prevent it from being overwritten when you do "apt upgrade" To prevent Zoneminder from being upgraded enter "sudo apt-mark hold zoneminder"

Start with an install of Ubuntu 17.10, server, desktop or bare bones basic. Do not install LAMP!

Become root

sudo su

Install Nginx and Mariadb

apt install nginx
apt install mariadb-server

Secure Mariadb

mysql_secure_installation

Remove the symbolic link for Mariadb

rm /etc/mysql/my.cnf

Copy a basic config file to replace the symbolic link

cp /etc/mysql/mariadb.conf.d/50-server.cnf /etc/mysql/my.cnf

Edit the Mariadb config file

nano /etc/mysql/my.cnf

Locate entries like the following and replace them

character-set-server = latin1
collation-server = latin1_swedish_ci

Note: The above settings are actually the Mariadb default. Changing back to default is necessary to avoid errors when logging into Zoneminder. This was added on 01APR17 but is not an April Fool! It may be necessary to align these settings with your regional language.

Ctrl+o Enter to save

CTRL+x to exit

Restart Mariadb

systemctl restart mysql

Install PHP components

apt install php-fpm php-mysql fcgiwrap

Edit the PHP ini file

nano /etc/php/7.1/fpm/php.ini

Locate (Ctrl+w) cgi.fix_pathinfo=1 and change to

cgi.fix_pathinfo=0

Also fix date. Search for [Date] (Ctrl + w then type Date and press Enter) and make changes as follows for your time zone. Make sure to remove the ; from the front of date.timezone

[Date]
; Defines the default timezone used by the date functions
; http://php.net/date.timezone
date.timezone = America/New_York

Ctrl+o Enter to save

CTRL+x to exit

Restart php-fm

systemctl restart php7.1-fpm

Download the Zoneminder .deb file from the iconnor repository

wget https://launchpad.net/~iconnor/+archive/ubuntu/zoneminder/+build/12557069/+files/zoneminder_1.30.4-zesty1_amd64.deb

Install Zoneminder. Change (user) as shown below to your user name on your Ubuntu install

apt install vlc-plugin-base /home/(user)/zoneminder_1.30.4-zesty1_amd64.deb

Note - installing Zoneminder this way will not prevent it from being overwritten when you do "apt upgrade" To prevent Zoneminder from being upgraded enter "sudo apt-mark hold zoneminder"

Add a user to enable local cameras

adduser www-data video

Change permissions

chown -R www-data:www-data /usr/share/zoneminder/

Enable and start Zoneminder

systemctl enable zoneminder
service zoneminder start

Edit the Nginx default config file

nano /etc/nginx/sites-available/default

Locate the line "index index.html index.htm index.nginx-debian.html;" and add "index.php"

index index.php index.html index.htm index.nginx-debian.html;

Ctrl+o Enter to save

Somewhere in the "server" section add

include /etc/nginx/zoneminder.conf;

Ctrl+o Enter to save

CTRL+x to exit

Create a Zoneminder config file

nano /etc/nginx/zoneminder.conf

Copy the following into it

location /zm/cgi-bin {
    gzip off;
    alias /usr/lib/zoneminder/cgi-bin;

    include /etc/nginx/fastcgi_params;
    fastcgi_param SCRIPT_FILENAME $request_filename;
    fastcgi_pass  unix:/var/run/fcgiwrap.socket;
}

location /zm {
#   if ($scheme ~ ^http:){
#       rewrite ^(.*)$  https://$host$1 permanent;
#   }

    gzip off;
    alias                   /usr/share/zoneminder/www;
    index                   index.php;

    location ~ \.php$ {
        if (!-f $request_filename) { return 404; }
        expires             epoch;
        include             /etc/nginx/fastcgi_params;
        fastcgi_param       SCRIPT_FILENAME         $request_filename;
        fastcgi_index       index.php;
        fastcgi_pass        unix:/var/run/php/php7.1-fpm.sock;
    }


    location ~ \.(jpg|jpeg|gif|png|ico)$ {
        access_log          off;
        expires         33d;
    }

    location /zm/api/ {
        alias                   /usr/share/zoneminder/www/api;
        rewrite ^/zm/api(.+)$ /zm/api/index.php?p=$1 last;
    }
}

Ctrl+o Enter to save

CTRL+x to exit

Restart Nginx

service nginx restart

IMPORTANT FINAL STEP: Open Zoneminder in a web browser (http://server-ip/zm). Click on Options - Paths and change PATH_ZMS to /zm/cgi-bin/nph-zms

Note: To avoid problems with feeds from multiple cameras "fcgiwrap" should be configured to start at least as many processes as there are cameras. It can be done by adjusting DAEMON_OPTS in "/etc/default/fcgiwrap".

nano /etc/default/fcgiwrap

Enter (change the 1 to the number of cameras)

DAEMON_OPTS="-f -c 1"

Ctrl+o Enter to save

CTRL+x to exit