I am going to start this blog with this article, which describes the needed steps to install Pydio on a CentOS 7.
Right now there is no howto in http://pyd.io regarding this OS version, so I think it may be interesting. It is based on this existing howto. However you need to change some small things in order for it to work with CentOS 7.
I have used the minimal install from the iso named CentOS-7.0-1406-x86_64-DVD.iso .
First things first,
Next step is providing the installation dependencies for Pydio,
The following command will install PHP and its dependencies:
Now you have to edit /etc/php.ini to change some parameters for Pydio to work properly. With vi or your preferred editor,
Next is installing and configuring MariaDB. It will start on boot.
Last find commands are not going to be very useful as Apache will write files with 644 mask. Have a look at this to configure SELinux.
Right now there is no howto in http://pyd.io regarding this OS version, so I think it may be interesting. It is based on this existing howto. However you need to change some small things in order for it to work with CentOS 7.
I have used the minimal install from the iso named CentOS-7.0-1406-x86_64-DVD.iso .
First things first,
yum install wget
Next step is providing the installation dependencies for Pydio,
wget http://dl.fedoraproject.org/pub/epel/7/x86_64/e/epel-release-7-5.noarch.rpm
wget http://rpms.famillecollet.com/enterprise/remi-release-7.rpm
rpm -Uvh remi-release-7.rpm epel-release-7*.rpm
yum update
yum install php php-apc php-mbstring php-pecl-apc php-mysql php-cli php-devel php-gd php-ldap php-pecl-memcache php-pspell php-snmp php-xmlrpc php-xml php-imap php-mcrypt*
Now you have to edit /etc/php.ini to change some parameters for Pydio to work properly. With vi or your preferred editor,
- Change output_buffering = 4096 to output_buffering = Off
- Change post_max_size = 8M to post_max_size = 1024M
- Change upload_max_filesize = 2M to upload_max_filesize = 1024M
Next is installing and configuring MariaDB. It will start on boot.
yum install mariadb-server
systemctl start mariadb.service
systemctl enable mariadb.service
/usr/bin/mysql_secure_installation
The last command is a wizard in which you can set the MySQL root password and some security settings more, like removing the anonymous user. The first question is the current root password, which is none so just press Enter.
Then you have to create the Pydio database, with the mysql command tool.
It will ask you for the password you have just set, hopefully.
Then enter the following SQL commands at the prompt to create the database and the Pydio user for the database.
... where mysqlpassword is the Pydio database user password. CTRL-d to exit.
Next step is installing Apache and mod_ssl. In my CentOS minimal installation Apache was already installed. And enabling the service to start on boot.
Then you have to create the Pydio database, with the mysql command tool.
mysql -u root -p
It will ask you for the password you have just set, hopefully.
Then enter the following SQL commands at the prompt to create the database and the Pydio user for the database.
create database pydio;
create user pydio@localhost identified by 'mysqlpassword';
grant all privileges on pydio.* to pydio@localhost identified by 'mysqlpassword' with grant option;
Next step is installing Apache and mod_ssl. In my CentOS minimal installation Apache was already installed. And enabling the service to start on boot.
yum install httpd
yum install openssl mod_ssl
systemctl start httpd.service
systemctl enable httpd.service
The following command will create a self-signed certificate for Pydio. As it is self-signed, browsers will issue a warning but whatever. It will last for 3650 days.
openssl req -x509 -nodes -days 3650 -newkey rsa:2048 -keyout /etc/pki/tls/private/pydio.key -out /etc/pki/tls/certs/pydio.crt
You will be prompted with some questions about location, organization name and so on.
Next commands are to tell Apache about the paths to the certificate files we have just created.
sed -i "s/localhost.crt/pydio.crt/g" /etc/httpd/conf.d/ssl.conf
sed -i "s/localhost.key/pydio.key/g" /etc/httpd/conf.d/ssl.conf
Next commands are for installing Pydio.
rpm -Uvh http://dl.ajaxplorer.info/repos/pydio-release-1-1.noarch.rpm
yum update
yum --disablerepo=pydio-testing install pydio
Now we have to edit the Pydio .conf file for Apache because CentOS 7 installs Apache 2.4, and the default .conf has two directives which are no longed valid. If you don't to this, you will get a 403 Forbidden error if you try to access Pydio.
Edit /etc/httpd/conf.d/pydio.conf and delete the following lines:
Order allow,deny
Allow from all
... and put this one instead of them:
Require all granted
Restart Apache:
systemctl restart httpd.service
And some commands to harden the file security. /usr/share/pydio is the default Pydio installation path.
chown -R root:apache /usr/share/pydio
cd /usr/share/pydio
find ./ -type d -exec chmod u=rwx,g=rx,o= '{}' \;
find ./ -type f -exec chmod u=rw,g=r,o= '{}' \;
chown -R apache:apache /var/lib/pydio
cd /var/lib/pydio
find ./ -type d -exec chmod u=rwx,g=rx,o= '{}' \;
find ./ -type f -exec chmod u=rw,g=r,o= '{}' \;
And that's all! Browse to http://yourserver/pydio or better https://yourserver/pydio . If you are browsing from another computer you will need to open the web server ports in the firewall, or if you are in a hurry to test just disable the firewall service,
systemctl stop firewalld.service \;
No comments:
Post a Comment