Облачный сервер Nextcloud: различия между версиями

Материал из wolfram
Перейти к навигации Перейти к поиску
 
(не показано 25 промежуточных версий этого же участника)
Строка 273: Строка 273:
Your name: '''имя_пользователя'''  
Your name: '''имя_пользователя'''  


your server’s name: '''cloud'''  
your server’s name: '''nextcloud'''  


Pick a username: '''имя_пользователя'''  
Pick a username: '''имя_пользователя'''  
Строка 293: Строка 293:
'''Enter'''  
'''Enter'''  
<br />
<br />
===[https://onedrive.live.com/view.aspx?resid=1BA17484D0963ECC%211919&id=documents&wd=target%28%D0%9F%D0%B0%D1%80%D0%BE%D0%BB%D0%B8.one%7C8D326A63-2198-4CAE-BC1F-3D883FECEB4F%2F%D0%9C%D0%BE%D0%B8%20%D1%81%D0%B5%D1%80%D0%B2%D0%B8%D1%81%D1%8B%7CBC1C8534-C0AB-4BE4-B12F-E8197EF2D103%2F%29&#x20;onenote:https://d.docs.live.net/1ba17484d0963ecc/Документы/Записная%20книжка%20пользователя%20Владимир/Пароли.one#Мои%20сервисы&section-id={8D326A63-2198-4CAE-BC1F-3D883FECEB4F}&page-id={BC1C8534-C0AB-4BE4-B12F-E8197EF2D103}&end Информация, пароли, имена.]===


===Первичная настройка===
===Первичная настройка===
Строка 313: Строка 315:
ОС готова переходим к установке '''Nextcloud'''.
ОС готова переходим к установке '''Nextcloud'''.


<br />
== Настройка сети ==
Добавляем виртуальную сетевую карту '''ens19.''' Присвоим адрес этой машине номер 4.
nano /etc/netplan/00-installer-config.yaml
 
network:
  ethernets:
    ens18:
      dhcp4: true
    ens19:
      dhcp4: no
      dhcp6: no
      addresses: [192.168.2.4/24, ]
  version: 2
После чего нужно перезагружаться
reboot
 
== Подключение каталога Nextcloud по NFS ==
Создадим каталог для монтирования
mkdir /media/nextcloud
Установим клиент NFS
apt-get install nfs-common
после чего добавим в '''fstab''' автомонтирование
nano /etc/fstab
добив в конфиг строку
192.168.2.1:/mnt/meganas/nextcloud /media/nextcloud nfs defaults 0 2
сохраняем и выполняем авто монтирование
mount -a
каталог есть


==Установка Nextcloud==
==Подготовка к установке Nextcloud==
Начинается все с установки Apache web server
Начинается все с установки Apache web server


Строка 331: Строка 360:
</syntaxhighlight>Смотрим статус, должно быть '''Active: active (running)''':<syntaxhighlight lang="bash">
</syntaxhighlight>Смотрим статус, должно быть '''Active: active (running)''':<syntaxhighlight lang="bash">
systemctl status apache2
systemctl status apache2
</syntaxhighlight>Конфигурация:<syntaxhighlight lang="bash">
</syntaxhighlight>Узнаем ip адрес машины, чтобы вписать в конфиг
ip a
Конфигурация:<syntaxhighlight lang="bash">
nano /etc/apache2/sites-available/nc.mywolfram.ru.conf
nano /etc/apache2/sites-available/nc.mywolfram.ru.conf
</syntaxhighlight>Вставляем в документ это:<syntaxhighlight lang="apacheconf">
</syntaxhighlight>Вставляем в документ это:<syntaxhighlight lang="apacheconf">
<VirtualHost *:80>  
<VirtualHost *:80>
    DocumentRoot "/var/www/html/nextcloud" # Адрес машины с облаком.  
  DocumentRoot /var/www/nextcloud/
    ServerName 192.168.1.130
  ServerName  nc.mywolfram.ru
    Alias / "/var/www/html/nextcloud/" # Alias / Путь - то, что указано даст возможность попасть в веб интерфейс просто по домену, без дополнительных подкаталогов.
  RemoteIPHeader X-Forwarded-For
    <Directory /var/www/html/nextcloud/>  
  RemoteIPInternalProxy 192.168.3.47/24
        Options +FollowSymlinks
  <Directory /var/www/nextcloud/>
        AllowOverride All  
    Require all granted
        <IfModule mod_dav.c>  
    AllowOverride All
        Dav off  
    Options FollowSymLinks MultiViews
            </IfModule>  
    LimitRequestBody 10737418240
            SetEnv HOME /var/www/html/nextcloud
 
            SetEnv HTTP_HOME /var/www/html/nextcloud
    <IfModule mod_dav.c>
    </Directory>  
      Dav off
    TransferLog /var/log/apache2/nextcloud_access.log
    </IfModule>
    ErrorLog /var/log/apache2/nextcloud_error.log
  </Directory>
</VirtualHost>
</VirtualHost>


</syntaxhighlight>Сохранить изменения.
</syntaxhighlight>Сохранить изменения.
Строка 355: Строка 386:
Добавляем сайт, включаем реврайт, перезагружаем apache.<syntaxhighlight lang="bash">
Добавляем сайт, включаем реврайт, перезагружаем apache.<syntaxhighlight lang="bash">
a2ensite nc.mywolfram.ru
a2ensite nc.mywolfram.ru
a2enmod rewrite
a2enmod a2enmod rewrite headers env dir mime setenvif remoteip
a2enmod env
systemctl reload apache2
service apache2 reload && service apache2 restart
 
</syntaxhighlight>
===PHP===
 
С PHP все просто.
apt-get install php zip libapache2-mod-php php-gd php-json php-mysql php-curl php-mbstring php-intl php-imagick php-xml php-zip php-mysql php-bcmath php-gmp -y
Да - это установка всех нужных модулей одной командой.


</syntaxhighlight><br />
==== php.ini ====
===PHP 7===
Файл находится в директории '''/etc/php/7.4/apache2/'''
С PHP все просто.<syntaxhighlight lang="bash">
 
apt-get install -y php libapache2-mod-php php-common php-mbstring php-xmlrpc php-soap php-apcu php-smbclient php-ldap php-redis php-gd php-xml php-intl php-json php-imagick php-mysql php-cli php-ldap php-zip php-curl
Внесем в него некоторые изменения:
</syntaxhighlight>Да - это установка всех нужных модулей одной командой.
nano '''/etc/php/7.4/apache2/php.ini'''
лимит на загрузку файлов
upload_max_filesize = 10G
 
Изменить лимит памяти до 512
  nano /etc/php/7.4/apache2/php.ini
 
memory_limit = 512M
<br />
<br />
===MariaDB===
===MariaDB (Можно заменить на mysql)===
База данных.
База данных.


Устанавливаем из репозиториев:
Устанавливаем из репозиториев:
  apt-get install mariadb-server –y
  apt-get install mariadb-server –y
Запускаем процесс:
'''или mysql'''
apt-get install mysql-server -y
Запускаем процесс, mariadb или mysql
  systemctl start mariadb
  systemctl start mariadb
Делам так чтобы стартовал при перезапуске:
Делам так чтобы стартовал при перезапуске mariadb или mysql
  systemctl enable mariadb
  systemctl enable mariadb
Смотрим статус, должно быть '''Active: active (running)''':
Смотрим статус, должно быть '''Active: active (running) mariadb или mysql'''
  systemctl status mariadb
  systemctl status mariadb
Далее, настройка:
Далее, настройка для mariadb и mysql одинакова
  mysql_secure_installation
  mysql_secure_installation
''Set root password? [Y/n]'' '''Y'''  
''Set root password? [Y/n]'' '''Y'''  
Строка 395: Строка 441:
  mysql -u root -p
  mysql -u root -p
Вводим вышеуказанный пароль.
Вводим вышеуказанный пароль.
  CREATE DATABASE имя_базы;
  CREATE DATABASE nextclouddb;
  CREATE USER '<nowiki/>'''пользователь_базы'''<nowiki/>'@'localhost' IDENTIFIED BY ''''пароль_базы'''<nowiki/>';
  CREATE USER ''''nextcloud'''<nowiki/>'@'localhost' IDENTIFIED BY 'пароль базы';
  GRANT ALL PRIVILEGES ON '''имя_базы'''.* TO ''''пользователь_базы'''<nowiki/>'@'localhost';
  GRANT ALL PRIVILEGES ON '''nextclouddb'''.* TO ''''nextcloud'''<nowiki/>'@'localhost';
  FLUSH PRIVILEGES;
  FLUSH PRIVILEGES;
  \q
  \q
<br />
nextclouddb - имя базы
 
vovacloud - пользователь базы
 
service apache2 reload<br />
 
==Nextcloud==
==Nextcloud==
[[Файл:Облачный сервер Nextcloud - Демонстрация получения ссылки.png|мини|Демонстрация получения ссылки]]
[[Файл:Облачный сервер Nextcloud - Демонстрация получения ссылки.png|мини|Демонстрация получения ссылки]]
Строка 430: Строка 481:
===Первый запуск===
===Первый запуск===
Открываем Nextcloud в браузере:
Открываем Nextcloud в браузере:
  <nowiki>http://адрес__машины_nextcloud/nextcloud/</nowiki>
  <nowiki>http://адрес__машины_nextcloud/</nowiki>
Пример:
Пример:
  <nowiki>http://192.168.1.130/nextcloud/</nowiki>
  http://192.168.1.154<nowiki/>/
Нас приветствует первая настройка.
Нас приветствует первая настройка.


Строка 456: Строка 507:
  nano /var/www/html/nextcloud/config/config.php
  nano /var/www/html/nextcloud/config/config.php
В нем нужно прописать дополнительные доверенные адреса, чтобы он нас с них пускал:<syntaxhighlight lang="php">
В нем нужно прописать дополнительные доверенные адреса, чтобы он нас с них пускал:<syntaxhighlight lang="php">
<?php
$CONFIG = array (
$CONFIG = array (
....
  'instanceid' => 'ocuyjdpcoq7j',
  'passwordsalt' => '8SPnKr5RkCP0+EGp3hfSHU1Ypdw/EF',
  'secret' => '3P99k361V/tqX76GRVFoNJtwYTm8Mtsv8L782yJk+URFK5Uf',
  'trusted_domains' =>
  array (
    0 => '192.168.1.145',
    1 => '192.168.3.47',
    2 => 'nc.mywolfram.ru',
  ),
  'datadirectory' => '/media/nextcloud',
  'dbtype' => 'mysql',
  'version' => '31.0.0.18',
  'htaccess.RewriteBase' => '/',
  'overwrite.cli.url' => 'https://nc.mywolfram.ru',
  'dbname' => 'nextclouddb',
  'dbhost' => 'localhost',
  'dbport' => '',
  'dbtableprefix' => 'oc_',
  'mysql.utf8mb4' => true,
  'dbuser' => 'nextcloud',
  'dbpassword' => '01082008',
  'installed' => true,
  'maintenance' => false,
  'trusted_proxies' =>
  array (
    0 => '192.168.3.47',
  ),
  'overwriteprotocol' => 'https',
  'maintenance_window_start' => 1,
  'theme' => '',
  'loglevel' => 2,
  'app_install_overwrite' =>
   array (
   array (
     0 => '192.168.1.130',
     0 => 'keeweb',
    1 => '127.0.0.1',
  ),
    2 => 'vovaconst.ddns.net',
  'max_upload_size' => '10G',
    3 => '192.168.1.230',
  'max_chunk_size' => '10G',
    4 => 'nc.mywolfram.ru',
  'memcache.local' => '\\OC\\Memcache\\Memcached',
),
  'memcache.distributed' => '\\OC\\Memcache\\Memcached',
....
  'memcache.locking' => '\\OC\\Memcache\\Memcached',
'htaccess.RewriteBase' => '/',
  'default_phone_region' => 'RU',
'overwrite.cli.url' => 'https://nc.mywolfram.ru',
);
'overwritehost' => 'nc.mywolfram.ru',
'overwriteprotocol' => 'https',
),
</syntaxhighlight>Я добавляю много адресов, это уже с учётом того что есть прокси nginx и домен.
</syntaxhighlight>Я добавляю много адресов, это уже с учётом того что есть прокси nginx и домен.


1.230 - это машина nginx
1.230 - это машина nginx


1.130 - cам nextcloud
===Скрытие index.php===
Чтобы убрать index.php в адресной строке


Сохраняем.


<br />
в файле '''config.php''' исправить и добавит строку.
===Скрытие index.php===
'overwrite.cli.url' => '<nowiki>https://nc.mywolfram.ru'</nowiki>,
Чтобы убрать index.php в адресной строке


'htaccess.RewriteBase' => '/',
Обязательно не от '''root'''!
Обязательно не от '''root'''!


Строка 490: Строка 570:
  sudo -u www-data php occ maintenance:update:htaccess
  sudo -u www-data php occ maintenance:update:htaccess
Настройка Nextcloud закончена.
Настройка Nextcloud закончена.
=== Настройка Memcache ===
[https://abc-server.com/ru/blog/administration/caching-cloud/ источник с данными для установки]
[https://www.dmosk.ru/miniinstruktions.php?mini=nextcloud-apache-ubuntu источник с настройками для opcache]
Устанавливаем нужные модули
apt-get install memcached
apt-get install php-memcache
apt-get install php-memcached
''apt-get install php-apcu''
Добавляем в '''''config.php''''' строку '''''memcache.local' => '\OC\Memcache\APCu','''''
nano /var/www/html/nextcloud/config/config.php
<syntaxhighlight>
$CONFIG = array (
.... 
  array (
    0 => '192.168.1.130',
    1 => '192.168.1.230',
    2 => 'nc.mywolfram.ru',
),
....
  'memcache.local' => '\OC\Memcache\APCu',
....
),
</syntaxhighlight>в '''php.ini''' включить opcache
nano /etc/php/7.4/apache2/php.ini
opcache.enable=1
opcache.enable_cli=1
opcache.interned_strings_buffer=8
opcache.max_accelerated_files=10000
opcache.memory_consumption=128
opcache.save_comments=1
opcache.revalidate_freq=1
=== Включить строгую безопасность транспорта HTTP ===
Добавить в файл '''nc.mywolfram.ru.conf''' строки
nano /etc/apache2/sites-available/nc.mywolfram.ru.conf
<syntaxhighlight>
<VirtualHost *:80>
.....
    <IfModule mod_headers.c>
        Header always set Strict-Transport-Security "max-age=15552000; includeSubDomains"
    </IfModule>
</VirtualHost>
</syntaxhighlight>
еще команда
=== В базе данных отсутствуют некоторые индексы ===
sudo -u www-data php /var/www/html/nextcloud/occ db:add-missing-indices
== Не актуально в 20 ==
=== Настройка супер кодировки (Смайлики) ===
MariaDB 10.2 и старше - на момент установки была 10.1
в файле /etc/mysql/my.cnf
nano /etc/mysql/my.cnf
В конце добавляем блок
[mysqld]
innodb_large_prefix=true
innodb_file_format=barracuda
innodb_file_per_table=1
Если версия MariaDB 10.3 то:
[mysqld]
innodb_file_per_table=1
перезагружаем MariaDB
systemctl restart mariadb
далее идем в настройки базы;
mysql -u root -p
Вводим пароль базы и вводим;
SELECT NAME, SPACE, FILE_FORMAT FROM INFORMATION_SCHEMA.INNODB_SYS_TABLES WHERE NAME like "nextcloud%";
Все значения должны быть “Antelope”
Идем в папку с облаком;
cd /var/www/html/nextcloud/
Переходим в режим разработчика nextcloud
sudo -u www-data php occ maintenance:mode --on
Снова заходим в базу MariaDB и вводим пароль базы данных
mysql -u root -p
Вставляем;
ALTER DATABASE nextclouddb CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;
nextclouddb - это название базы данных, должен быть такой результат:
Query OK, 1 row affected (0.00 sec)
Выходим из базы
\q
Устанавливаем <code>mysql.utf8mb4</code> значение true в вашем config.php:
sudo -u www-data php occ config:system:set mysql.utf8mb4 --type boolean --value="true"
конвертируем все таблицы в новый формат, это не быстро:
sudo -u www-data php occ maintenance:repair
Отключить режим обслуживания:
sudo -u www-data php occ maintenance: mode --off
Ура!
== Решение проблемм ==
[https://adminunix.ru/ustranenie-problem-s-oblachny-m-hranilishhem-nextcloud/ ист 1]

Текущая версия от 15:38, 11 марта 2025

Nextcloud - презентация

Своими словами. Аналог Яндекс, Google дисков. То есть web доступ к файлам, и клиент на все платформы для синхронизации. Но есть одно маленькое, но. Размерность, скорость и фишки делаются на свое усмотрение. На собственном железе. Все данные рядом, или точно известно где они.


Настройка Proxmox для Nextcloud

Наше облако базируется на системном хранилище local-lvm, а вот сами данные будут храниться на SSD на 960 гигабайт из Китая. Пока без рейда (.

Поэтому после аппаратного подключения накопителя к серверу, нужно на нем создать раздел и отформатировать в ext4.

Самое интересное то, что Proxmox как бы конфигурируется через web, но работу с накопителями на низком уровне можно осуществить только из консоли.

Туда и переходим, в PowerShell конечно же.

ssh vova@192.168.1.130

Водим пароль.


Подключение накопителя к Proxmox


Просмотр разделов

Смотрим что там у нас по разделам.

lsblk

Тут должно быть несколько дисков. Может быть так что нужный sda или наоборот sdb. Наш тот у которого нет разделов.

Пример:

sda              	8:0 0 960G 0 disk 
sdb              	8:16 0 120G 0 disk 
├─sdb1           	8:17 0 1007K 0 part 
├─sdb2           	8:18 0 512M 0 part 
└─sdb3           	8:19 0 119.5G 0 part

sda и есть наша SSD на 960 гигабайт.


Создание раздела

На ней и создадим раздел.

fdisk /dev/sda

Запустилась программа по созданию разделов.

Смотрим информацию о командах.

m

Создаем новый раздел

n

Enter, Enter, Enter, Enter

Запишем изменения

w

Теперь если взглянуть на разделы.

lsblk

Видно, что

sda              	8:0	0	960G  0 disk
└─sda1           	8:1	0	960G  0 part 

появился раздел sda1.


Форматирование раздела

от его и нужно форматировать в ext4.

mkfs.ext4 /dev/sda1

Соглашаемся и дожидаемся окончания. Теперь у нас есть файловая система на накопителе SSD.

Осталось выполнить монтирование раздела в var/lib/ с нужным нам именем, без разницы каким.

Делать мы это будем не по букве диска, так как эта штука не статичная. Может меняться при следующем запуске системы. И вручную монтировать мы тоже не хотим.


ID разделов

Делать будем по ID накопителя. Узнаем:

blkid

Видим много чего, но нас интересует наш раздел /dev/sda1. Вот он:

/dev/sda1: UUID="2e51447b-2ed3-4380-b497-401114b7261f" TYPE="ext4" PARTUUID="23d0899a-01"

И нужный нам UUID накопителя.


Монтирование раздела

Создадим каталог, в который будет монтироваться раздел. Назовем его SATA2

mkdir /var/lib/SATA2

Монтируем чтобы не перезагружаться.

mount -t ext4 /dev/sda1 /var/lib/SATA2/


Авто монтирование раздела

Для авто монтирования в систему открываем в nano файл fstab.

nano /etc/fstab

В конце добавляем:

UUID=2e51447b-2ed3-4380-b497-401114b7261f /var/lib/SATA2 ext4 defaults 0 1
ctrl + o
ctrl + x

Цифры в конце указываю на то, что система не загрузится если не найдет данный накопитель.

Готово.


Создание виртуальной машины


Подключение хранилища

Подключение хранилища

Теперь web интерфейсе переходим в раздел Датацентр.

Выбираем: “Хранилище

Нажимаем: “Добавить”, в списке выбираем: “Каталог”.

В появившемся окне:

ID: SATA2

название нашего ранее созданного хранилища.

Каталог: /var/lib/SATA2/

физический путь к примонтированному разделу.

Содержимое: Резервная копия, ISO образ, Шаблон контейнера

то, что можно размещать в этом хранилище.

Добавить.


Демонстрация загруженный образов

Загрузка образа Ubuntu

Получается мы устанавливаем ubuntu server как виртуальную в среде Proxmox.

На данный момент это версия 18.04.4 LTS.

На этот раз ни на какие накопители ничего записывать не нужно.

Требуется загрузить образ в пространство Proxmox, в хранилище. В нашем случае подойдет local.

Выбираем local в узле pve, переходим в “Содержимое”.

Нажимаем “Загрузить” и выбираем наш образ.

Загружаем, ожидаем.

Создание VM

Нажимаем: создать VM:

В разделе Общее:

Узел: pve

VM ID: 100

Имя: cloud


В разделе ОС:

Хранилище: local

ISO образ: То, что загрузили с официального сайта Ubuntu.


В разделе Жесткий диск:

Шина: VirtIO Block

Хранилище: local-lvm

Размер: 20

Кэш: Write through


В разделе Процессор:

Ядра: 2


В разделе Память:

Память: 2048

Готово.


Появилась виртуальная машина с номером 100 и названием cloud в разделе pve.

Теперь сразу же подкинем этой машине наш накопитель SSD для хранения “облачных данных”.

Переходим в неё, в раздел Оборудование и нажимаем “Добавить”, выбираем Жесткий диск.

Хранилище: SATA2

Размер: 834

в моем случае, на пару гигабайт меньше, чем доступно.

Кэш: Write through

Добавить.

Нажимаем Запуск.

Установка Ubuntu

Установка точно такая же как на реальном железе. Но все буде рассказано.

Переходим в раздел Консоль нашей 100 виртуальной машины. Или если все на отдельном сервере, просто устанавливаем систему с USB накопителя.

Видим запуск ОС и выбор языка. Выбираем Русский.

Клавиатура остается на Английском.  

Готово.

Видим, что машина получила IP адрес от нашего DHCP сервера.

192.168.1.130/24 


Создание разделов

В разделе Filesystem setup выбираем Вручную. Мы же профессионалы.

Видим 2 накопителя:


Cначало swop: /dev/vda/ 20G

Жмем и выбираем: Add Partition

Size: 2

Format: swop

Create


Теперь создадим boot /dev/vda/ 20G

Size: 1

Format: ext4

Mount: /boot

Create


Теперь уже основной каталог: /dev/vda/ 20G

Size: ничего

Format: ext4

Mount: /

Create


Теперь диск хранилище: /dev/vdb/ 834G

Size: ничего

Format: ext4

Mount: other /media/nextcloud

Create

Идем в самый низ и выбираем: Готово. Продолжить: Да.

Начинается установка. При этом она идет в фоне.

В это время заполняем данные пользователя и машины:

Создание пользователя

Your name: имя_пользователя

your server’s name: nextcloud

Pick a username: имя_пользователя

Choose password: пароль_сервера_cloud

Confirm your password: пароль_сервера_cloud

Готово.

На вопрос установить ли ssh соглашаемся, поставив крестик пробелом.

Готово.

Ничего не выбираем и говорим Готово. Ждем окончания установки.  

По окончании: Reboot.

Enter

Информация, пароли, имена.

Первичная настройка

ОС перезагрузиться, но уже в установленном виде. С ней бы выполнить стандартный набор операций.  

PowerShell

ssh vova@192.168.1.130


Вот мы и в консоли будущего облака. Так как мы не root нужно выполнять все действия через команду sudo, или ввести sudo su и ввести пароль. Это сделает все наши операции от root.

обновляем репозитории.

apt-get update

выполняем обновление пакетов из репозиториев.

apt-get upgrade -y

устанавливаем файловый менеджер mc.

apt-get install mc -y 

устанавливаем архиватор.

apt-get install unzip -y

ОС готова переходим к установке Nextcloud.

Настройка сети

Добавляем виртуальную сетевую карту ens19. Присвоим адрес этой машине номер 4.

nano /etc/netplan/00-installer-config.yaml
network:
  ethernets:
    ens18:
      dhcp4: true
    ens19:
      dhcp4: no
      dhcp6: no
      addresses: [192.168.2.4/24, ]
  version: 2

После чего нужно перезагружаться

reboot

Подключение каталога Nextcloud по NFS

Создадим каталог для монтирования

mkdir /media/nextcloud

Установим клиент NFS

apt-get install nfs-common

после чего добавим в fstab автомонтирование

nano /etc/fstab

добив в конфиг строку

192.168.2.1:/mnt/meganas/nextcloud /media/nextcloud nfs defaults 0 2

сохраняем и выполняем авто монтирование

mount -a

каталог есть

Подготовка к установке Nextcloud

Начинается все с установки Apache web server


Apache

Устанавливаем из репозиториев apache:

apt-get -y install apache2

Запускаем процесс apache:

service apache2 start
#или по новому
systemctl start apache2

Делам так чтобы стартовал при перезапуске:

systemctl enable apache2

Смотрим статус, должно быть Active: active (running):

systemctl status apache2

Узнаем ip адрес машины, чтобы вписать в конфиг

ip a

Конфигурация:

nano /etc/apache2/sites-available/nc.mywolfram.ru.conf

Вставляем в документ это:

<VirtualHost *:80>
  DocumentRoot /var/www/nextcloud/
  ServerName  nc.mywolfram.ru
  RemoteIPHeader X-Forwarded-For
  RemoteIPInternalProxy 192.168.3.47/24
  <Directory /var/www/nextcloud/>
    Require all granted
    AllowOverride All
    Options FollowSymLinks MultiViews
    LimitRequestBody 10737418240

    <IfModule mod_dav.c>
      Dav off
    </IfModule>
  </Directory>
</VirtualHost>

Сохранить изменения. Добавляем сайт, включаем реврайт, перезагружаем apache.

a2ensite nc.mywolfram.ru
a2enmod a2enmod rewrite headers env dir mime setenvif remoteip
systemctl reload apache2

PHP

С PHP все просто.

apt-get install php zip libapache2-mod-php php-gd php-json php-mysql php-curl php-mbstring php-intl php-imagick php-xml php-zip php-mysql php-bcmath php-gmp -y

Да - это установка всех нужных модулей одной командой.

php.ini

Файл находится в директории /etc/php/7.4/apache2/

Внесем в него некоторые изменения:

nano /etc/php/7.4/apache2/php.ini

лимит на загрузку файлов

upload_max_filesize = 10G

Изменить лимит памяти до 512

nano /etc/php/7.4/apache2/php.ini
memory_limit = 512M


MariaDB (Можно заменить на mysql)

База данных.

Устанавливаем из репозиториев:

apt-get install mariadb-server –y

или mysql

apt-get install mysql-server -y

Запускаем процесс, mariadb или mysql

systemctl start mariadb

Делам так чтобы стартовал при перезапуске mariadb или mysql

systemctl enable mariadb

Смотрим статус, должно быть Active: active (running) mariadb или mysql

systemctl status mariadb

Далее, настройка для mariadb и mysql одинакова

mysql_secure_installation

Set root password? [Y/n] Y

Вводим пароль пользователя: пароль_для_sql

Remove anonymous users? [Y/n] Y

Disallow root login remotely? [Y/n] Y

Remove test database and access to it? [Y/n] Y

Reload privilege tables now? [Y/n] Y

Перезагружаем процесс:

systemctl restart mariadb

Настраиваем пользователя.

mysql -u root -p

Вводим вышеуказанный пароль.

CREATE DATABASE nextclouddb;
CREATE USER 'nextcloud'@'localhost' IDENTIFIED BY 'пароль базы';
GRANT ALL PRIVILEGES ON nextclouddb.* TO 'nextcloud'@'localhost';
FLUSH PRIVILEGES;
\q

nextclouddb - имя базы

vovacloud - пользователь базы

service apache2 reload

Nextcloud

Демонстрация получения ссылки

Нам нужно загрузить архив с nextcloud с официального сайта. Там жмем на северную версию и копируем ссылку с кнопки загрузить.

Как это сделать, идем на официальный сайт nextcloud, выбираем загрузку для сервера. И на кнопке скачать выполняем копирование ссылки. Это и есть прямой путь к получению архива.


Загрузка и распаковка

wget полученная_нами_ссылка

Пример:

wget https://download.nextcloud.com/server/releases/nextcloud-18.0.3.zip

Происходит загрузка в каталог, который сейчас открыт

Распаковываем скачанный архив в /var/www/html/

unzip nextcloud-18.0.1.zip -d /var/www/html/


Предоставление прав

Делам папку /nextcloud принадлежащей группе и пользователю www-data:

chown -R www-data:www-data /var/www/html/nextcloud

Так же у меня для хранения самих файлов есть каталог /media/nextcloud, создан был при установке, в него примонтирован раздел на SSD.

Делаю папку /media/nextcloud принадлежащей группе и пользователю www-data:

chown -R www-data:www-data /media/nextcloud

Даю папкам права на запись в соответствии со значением 755:

chmod 755 /var/www/html/nextcloud
chmod 755 /media/nextcloud


Первый запуск

Открываем Nextcloud в браузере:

http://адрес__машины_nextcloud/

Пример:

http://192.168.1.154/

Нас приветствует первая настройка.

Имя пользователя: Придумываем свое имя пользователя. (vova0108)

Пароль: Придумываем совой пароль

Каталог с данными: в моём случае выше упомянуты /media/nextcloud

Пользователь базы данных:

Пароль базы данных:

Название базы:

Готово.

Ожидаем первичной настройки.


Настройка config.php

После окончания осталось поправить config.php:

nano /var/www/html/nextcloud/config/config.php

В нем нужно прописать дополнительные доверенные адреса, чтобы он нас с них пускал:

<?php
$CONFIG = array (
  'instanceid' => 'ocuyjdpcoq7j',
  'passwordsalt' => '8SPnKr5RkCP0+EGp3hfSHU1Ypdw/EF',
  'secret' => '3P99k361V/tqX76GRVFoNJtwYTm8Mtsv8L782yJk+URFK5Uf',
  'trusted_domains' =>
  array (
    0 => '192.168.1.145',
    1 => '192.168.3.47',
    2 => 'nc.mywolfram.ru',
  ),
  'datadirectory' => '/media/nextcloud',
  'dbtype' => 'mysql',
  'version' => '31.0.0.18',
  'htaccess.RewriteBase' => '/',
  'overwrite.cli.url' => 'https://nc.mywolfram.ru',
  'dbname' => 'nextclouddb',
  'dbhost' => 'localhost',
  'dbport' => '',
  'dbtableprefix' => 'oc_',
  'mysql.utf8mb4' => true,
  'dbuser' => 'nextcloud',
  'dbpassword' => '01082008',
  'installed' => true,
  'maintenance' => false,
  'trusted_proxies' =>
  array (
    0 => '192.168.3.47',
  ),
  'overwriteprotocol' => 'https',
  'maintenance_window_start' => 1,
  'theme' => '',
  'loglevel' => 2,
  'app_install_overwrite' =>
  array (
    0 => 'keeweb',
  ),
  'max_upload_size' => '10G',
  'max_chunk_size' => '10G',
  'memcache.local' => '\\OC\\Memcache\\Memcached',
  'memcache.distributed' => '\\OC\\Memcache\\Memcached',
  'memcache.locking' => '\\OC\\Memcache\\Memcached',
  'default_phone_region' => 'RU',
);

Я добавляю много адресов, это уже с учётом того что есть прокси nginx и домен.

1.230 - это машина nginx

Скрытие index.php

Чтобы убрать index.php в адресной строке


в файле config.php исправить и добавит строку.

'overwrite.cli.url' => 'https://nc.mywolfram.ru',
'htaccess.RewriteBase' => '/',

Обязательно не от root!

Запустить из каталога /var/www/html/nextcloud/

cd /var/www/html/nextcloud/
sudo -u www-data php occ maintenance:update:htaccess

Настройка Nextcloud закончена.

Настройка Memcache

источник с данными для установки

источник с настройками для opcache

Устанавливаем нужные модули

apt-get install memcached
apt-get install php-memcache
apt-get install php-memcached
apt-get install php-apcu

Добавляем в config.php строку memcache.local' => '\OC\Memcache\APCu',

nano /var/www/html/nextcloud/config/config.php
$CONFIG = array (
....  
  array (
    0 => '192.168.1.130',
    1 => '192.168.1.230',
    2 => 'nc.mywolfram.ru',
),
....
   'memcache.local' => '\OC\Memcache\APCu',
....
),

в php.ini включить opcache

nano /etc/php/7.4/apache2/php.ini
opcache.enable=1
opcache.enable_cli=1
opcache.interned_strings_buffer=8
opcache.max_accelerated_files=10000
opcache.memory_consumption=128
opcache.save_comments=1
opcache.revalidate_freq=1

Включить строгую безопасность транспорта HTTP

Добавить в файл nc.mywolfram.ru.conf строки

nano /etc/apache2/sites-available/nc.mywolfram.ru.conf
<VirtualHost *:80>
.....
    <IfModule mod_headers.c>
        Header always set Strict-Transport-Security "max-age=15552000; includeSubDomains"
    </IfModule>
</VirtualHost>


еще команда

В базе данных отсутствуют некоторые индексы

sudo -u www-data php /var/www/html/nextcloud/occ db:add-missing-indices

Не актуально в 20

Настройка супер кодировки (Смайлики)

MariaDB 10.2 и старше - на момент установки была 10.1

в файле /etc/mysql/my.cnf

nano /etc/mysql/my.cnf

В конце добавляем блок

[mysqld]
innodb_large_prefix=true
innodb_file_format=barracuda
innodb_file_per_table=1

Если версия MariaDB 10.3 то:

[mysqld]
innodb_file_per_table=1

перезагружаем MariaDB

systemctl restart mariadb

далее идем в настройки базы;

mysql -u root -p

Вводим пароль базы и вводим;

SELECT NAME, SPACE, FILE_FORMAT FROM INFORMATION_SCHEMA.INNODB_SYS_TABLES WHERE NAME like "nextcloud%";

Все значения должны быть “Antelope”

Идем в папку с облаком;

cd /var/www/html/nextcloud/

Переходим в режим разработчика nextcloud

sudo -u www-data php occ maintenance:mode --on

Снова заходим в базу MariaDB и вводим пароль базы данных

mysql -u root -p

Вставляем;

ALTER DATABASE nextclouddb CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci;

nextclouddb - это название базы данных, должен быть такой результат:

Query OK, 1 row affected (0.00 sec)

Выходим из базы

\q

Устанавливаем mysql.utf8mb4 значение true в вашем config.php:

sudo -u www-data php occ config:system:set mysql.utf8mb4 --type boolean --value="true"

конвертируем все таблицы в новый формат, это не быстро:

sudo -u www-data php occ maintenance:repair

Отключить режим обслуживания:

sudo -u www-data php occ maintenance: mode --off

Ура!

Решение проблемм

ист 1