OwnCloud9: различия между версиями

Материал из ALT Linux Wiki
м (php5 -> php7)
м (upd memcached)
Строка 27: Строка 27:
PORT="11211"
PORT="11211"
# Start as memcached daemon
# Start as memcached daemon
USER="memcached"
RUNAS="memcached"
# Set max simultaneous connections to 1024
# Set max simultaneous connections to 1024
MAXCONN="1024"
MAXCONN="1024"
Строка 33: Строка 33:
CACHESIZE="2048"
CACHESIZE="2048"
#Set server IP address
#Set server IP address
OPTIONS="-l 127.0.0.1"
LISTEN="127.0.0.1"
</pre>
</pre>
*добавьте сервис в автозагрузку и запустите его:
*добавьте сервис в автозагрузку и запустите его:

Версия от 10:40, 13 декабря 2018

Запуск облачного сервиса ownCloud 9 версии

Первый этап: установка и настройка ПО

Настройка с использованием web-сервера Apache2

1. Установите соответствующий пакет:

apt-get install owncloud9-apache2

Частью его установки является дефолтный файл настроек виртуального хоста owncloud9. Ознакомиться с ним можете здесь. Изменить его под свои нужды нужно здесь - /etc/httpd2/conf/sites-available/owncloud9.conf

Также он автоматически включает этот хост в разрешенные, открывает порт 443 для доступа по HTTPS, и включает все необходимые модули (для оптимальной работы сервиса):

a2ensite owncloud9
a2enport https
a2enmod ssl
a2enmod rewrite
a2enmod env
a2enmod headers

2. Добавьте сервис Apache2 в автозагрузку:

chkconfig httpd2 on

3. Настройка сервиса кэширования memcached:

  • приведите файл /etc/sysconfig/memcached к виду:
# Running on Port 11211
PORT="11211"
# Start as memcached daemon
RUNAS="memcached"
# Set max simultaneous connections to 1024
MAXCONN="1024"
# Set Memory size to 2048 - 4GB(4096)
CACHESIZE="2048"
#Set server IP address
LISTEN="127.0.0.1"
  • добавьте сервис в автозагрузку и запустите его:
chkconfig memcached on && service memcached start

4. Настройка доступа по https.

Так как модули rewrite и ssl включены, остается только сгенерировать самоподписанный сертификат для сервера (CN обязательно нужно указать - IP или FQDN вашего сервера):

openssl req -x509 -nodes -days 3650 -newkey rsa:2048 -keyout /var/lib/ssl/private/owncloud.key -out /var/lib/ssl/certs/owncloud.pem

5. Запускаем web-сервер (service httpd2 start) и открываем в браузере страницу сервера - www.example.com (должно автоматически переадресовать на 443 порт).

Настройка с использованием web-сервера nginx

1. Установите соответствующий пакет:

apt-get install owncloud9-nginx

Частью его установки является дефолтный файл настроек виртуального хоста owncloud9, который был взят с сайта документации и актуализирован под Альт и имеющийся пакет owncloud9. Ознакомиться с ним можете здесь.

2. Добавьте сервис nginx в автозагрузку:

chkconfig nginx on

Так как php7-fpm-fcgi не обязан быть на той же машине, что и nginx, пункты 3-5 необходимы только в случае связки nginx+PHP-FPM на одном и том же хосте. В противном случае нужно изменить php-handler в /etc/nginx/sites-available.d/owncloud9.conf на необходимый.

3. Добавьте сервис php7-fpm в автозагрузку (php7-fpm-fcgi должен быть установлен):

chkconfig php7-fpm on

4. Для ownCloud необходимо подправить настройки php7-fpm. Для этого раскомментируйте в файле /etc/fpm/php7-fpm.conf следующие строчки:

env[HOSTNAME] = $HOSTNAME
env[PATH] = /usr/local/bin:/usr/bin:/bin
env[TMP] = /tmp
env[TMPDIR] = /tmp
env[TEMP] = /tmp

5. Запускаем службу php7-fpm:

service php7-fpm start
Примечание: Может потребоваться добавление пользователя _php_fpm в группу _webserver или в группу _nginx (на Восьмой платформе не нужно)


6. Настраиваем сервис memcached (см. выше пункт 3 настройки apache2)

7. Сгенерируйте сертификат для использования https (см. выше пункт 4 настройки apache2)

8. Измените под свой сервер файл настроек - /etc/nginx/sites-available.d/owncloud9.conf. И подключите данную конфигурацию:

ln -s /etc/nginx/sites-available.d/owncloud9.conf /etc/nginx/sites-enabled.d/

9. Запустите web-сервер service nginx start и откройте в браузере страницу сервера, например, cloud.example.com - HTTP должно автоматически переадресовать на HTTPS (443 порт).

Второй этап: настройка в браузере

6. После ввода логина/пароля администратора необходимо выбрать тип используемой БД - по умолчанию это SQLite. Однако при этом ownCloud выдаст предупреждение о производительности:

В качестве базы данных будет использована SQLite. Для крупных проектов мы советуем выбрать другой тип базы данных. В частности не рекомендуется использовать SQLite при синхронизации файлов с использованием клиента для ПК.

Примечание: На Восьмой платформе пакет pdo-sqlite отсутствует в зависимостях к owncloud9 и его нужно установить вручную:
apt-get install pdo-sqlite


Другими вариантами являются MySQL/MariaDB и PostgreSQL. Однако они будут доступны только при установленных PHP-модулях: php7-pdo_mysql для MySQL/MariaDB и php7-pgsql, php7-pdo_pgsql для PostgreSQL - по этому поводу также будет сообщение:

"Доступен только SQLite. Установите и активируйте дополнительные модули PHP для возможности выбора других типов баз данных."

MySQL/MariaDB для ownCloud:

apt-get install MySQL[mariadb]-server php7-pdo_mysql # устанавливаем необходимые пакеты для MySQL или для MariDB
chkconfig mysqld on && service mysqld start # добавляем сервис в автозагрузку и запускаем его
mysql -u root # запускаем консоль mysql для установки пароля на пользователя root
mysql> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('111111');
mysql> quit;

Донастройка ownCloud 9

Откройте файл /etc/owncloud9/config/config.php и внесите в него необходимые изменения.

Настраиваем кэширование
  'maintenance' => false,
  'loglevel' => '3',
  'memcache.local' => '\OC\Memcache\Memcached',
  'memcache.distributed' => '\OC\Memcache\Memcached',
  'memcached_servers' => array(
     array('localhost', 11211),
     ),
Для использования модуля шифрования в OwnCloud (ownCloud Default Encryption Module) необходимо доустановить php7-openssl
Желательно указать временную папку (предварительно ее нужно создать - mkdir -m666 /tmp/cloud_tmp_dir)
  'tempdirectory' => '/tmp/cloud_tmp_dir',
Можно настроить "красивый урл" (www.example.com/apps/files/ вместо www.example.com/index.php/apps/files/) - актуально только для apache2, в nginx так "из коробки"
  'overwrite.cli.url' => 'https://www.example.com',
  'htaccess.RewriteBase' => '/',
Примечание: Для быстрого применения данной настройки нужно с правами вебсервера выполнить команду /var/www/webapps/owncloud9/occ maintenance:update:htaccess:


sudo -u apache2 /var/www/webapps/owncloud9/occ maintenance:update:htaccess
или
su -l -s /bin/bash apache2 -c "/var/www/webapps/owncloud9/occ maintenance:update:htaccess"


Подробнее о тонкой настройке см. в документации

Nextcloud 12

Установка и настройки производятся аналогично. В Sisyphus и в ветке p8 присутствуют аналогичные пакеты - nextcloud-apache2 и nextcloud-nginx. Разница при настройке только в имени owncloud⇾nextcloud. Также убраны из зависимостей пакеты для настройки кэширования (memcached php7-memcache php7-memcached), так как использование именно memcached не обязательно.

См. также