Support #861
Updated by Daniel Curtis about 9 years ago
{{>toc}}
This is a guide on setting up Piwigo with Nginx on FreeBSD 10.
h1. Prepare the Environment
* Before installation of the components, make sure everything is up to date using the following command:
<pre>
pkg update -f && pkg upgrade
</pre>
* Install a couple dependencies:
<pre>
pkg install git ImageMagick-nox11
</pre>
* Create the piwigo user:
<pre>
pw user add -n piwigo -s /sbin/nologin -c "Piwigo"
</pre>
---
h1. Install Nginx
* Install Nginx
<pre>
pkg install nginx
</pre>
* Start and enable nginx at boot:
<pre>
echo 'nginx_enable="YES"' >> /etc/rc.conf
service nginx start
</pre>
* Create a configuration directory to make managing individual server blocks easier
<pre>
mkdir /usr/local/etc/nginx/conf.d
</pre>
* Edit the main nginx config file:
<pre>
vi /usr/local/etc/nginx/nginx.conf
</pre>
#* And strip down the config file and add the include statement at the end to make it easier to handle various server blocks:
<pre>
load_module /usr/local/libexec/nginx/ngx_mail_module.so;
load_module /usr/local/libexec/nginx/ngx_stream_module.so;
worker_processes 1;
error_log /var/log/nginx-error.log;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
# Load config files from the /etc/nginx/conf.d directory
include /usr/local/etc/nginx/conf.d/*.conf;
}
</pre>
---
h1. Install MySQL Server
* Start by installing the mariadb100-server and mariadb100-client packages:
<pre>
pkg install mariadb100-{server,client}
</pre>
* Copy a base MySQL configuration to use:
<pre>
cp /usr/local/share/mysql/my-small.cnf /var/db/mysql/my.cnf
</pre>
* Enable and start mysql at boot:
<pre>
echo 'mysql_enable="YES"' >> /etc/rc.conf
service mysql-server start
</pre>
* Prepare the database for use by running the secure installation:
<pre>
mysql_secure_installation
</pre>
#* *NOTE*: +Choose a strong root password+ and answer +yes+ to all questions.
h2. Create Databases and Users
* Login to MySQL and create appropriate databases and users.
<pre>
mysql -u root -p
</pre>
#* and run the following SQL queries to create the *piwigodb* database and *piwigouser* user:
<pre>
CREATE DATABASE piwigodb CHARACTER SET utf8;
CREATE USER 'piwigouser'@'localhost' IDENTIFIED BY 'SuperSecretPassword';
GRANT ALL PRIVILEGES ON piwigodb.* TO 'piwigouser'@'localhost';
FLUSH PRIVILEGES;
quit
</pre>
---
h1. Install PHP
* Install PHP 5.6 and a few extensions:
<pre>
pkg install php56 php56-{exif,filter,gd,hash,mbstring,mysqli,json,session,zip} php56-{mbstring,session,exif,gd,mysqli,json,zip}
</pre>
* Configure the default PHP settings
<pre>
cp /usr/local/etc/php.ini-production /usr/local/etc/php.ini
</pre>
* Edit the php config file:
<pre>
vi /usr/local/etc/php.ini
</pre>
#* And make sure the following values are set:
<pre>
date.timezone = "America/Los_Angeles"
max_execution_time = 200
post_max_size = 100M
upload_max_filesize = 100M
memory_limit = 256M
</pre>
* Create a directory for the php-fpm configs:
<pre>
mkdir /usr/local/etc/php-fpm.d
</pre>
* Edit the php-fpm config file:
<pre>
vi /usr/local/etc/php-fpm.conf
</pre>
#* Make the following changes:
<pre>
include=/usr/local/etc/php-fpm.d/*.conf
</pre>
* Enable PHP-FPM at boot:
<pre>
echo 'php_fpm_enable="YES"' >> /etc/rc.conf
</pre>
* Restart nginx:
<pre>
service nginx restart
</pre>
---
h1. Install Piwigo
* Download Piwigo version 2.8 from GitHub:
<pre>
cd /usr/local/www
git clone -b 2.8 https://github.com/Piwigo/Piwigo.git
</pre>
* Create an *piwigo.example.com server block* config file:
<pre>
vi /usr/local/etc/nginx/conf.d/piwigo.example.com.conf
</pre>
#* Add the following:
<pre>
upstream piwigo-handler {
server unix:/var/run/piwigo.example.com-php-fpm.sock;
}
server {
listen 80;
server_name piwigo.example.com;
root /usr/local/www/Piwigo/;
index index.html index.php;
# Set size for max uploaded content
client_max_body_size 0;
client_header_timeout 30m;
client_body_timeout 30m;
location = /robots.txt {
allow all;
log_not_found off;
access_log off;
}
location ~ ^/(?:CHANGELOG\.md|config|README.md|.git){
deny all;
}
location / {
try_files $uri $uri/ =404;
}
location ~ \.php(?:$|/) {
fastcgi_split_path_info ^(.+\.php)(/.+)$;
fastcgi_index index.php;
include fastcgi_params;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param PATH_INFO $fastcgi_path_info;
fastcgi_pass piwigo-handler;
fastcgi_intercept_errors on;
}
}
</pre>
* Create the piwigo php-fpm pool config file:
<pre>
vi /usr/local/etc/php-fpm.d/piwigo.example.com.conf
</pre>
#* And add the following:
<pre>
[piwigo.example.com]
user = piwigo
group = www
listen = /var/run/piwigo.example.com-php-fpm.sock
listen.owner = piwigo
listen.group = www
pm = dynamic
pm.max_children = 5
pm.start_servers = 2
pm.min_spare_servers = 1
pm.max_spare_servers = 3
</pre>
* Change the ownership of the piwigo directory:
<pre>
chown -R piwigo:www /usr/local/www/Piwigo
</pre>
* Restart nginx and start php-fpm:
<pre>
service nginx restart
service php-fpm start
</pre>
* Now open up a web browser and go to http://piwigo.example.com to finish the setup process.
h2. Resources
* http://piwigo.org/doc/doku.php
* http://piwigo.org/doc/doku.php?id=user_documentation:learn:install:installation
* http://piwigo.org/basics/installation_manual