CentOS Stream 10

NextCloud : インストール2025/05/15

 

クラウドストレージサーバー NextCloud をインストールします。

[1]

こちらを参考に Apache httpd をインストールしておきます

[2]

こちらを参考に Apache httpd に SSL/TLS の設定を適用しておきます
(Web ミーティングで使用する カメラ/通話 の機能や 画面共有 の機能等は SSL/TLS 必須)

[3]

こちらを参考に PHP をインストールしておきます

[4]

こちらを参考に MariaDB サーバーをインストールしておきます

[5] 必要な PHP モジュールを追加インストールして、NextCloud 用に PHP の設定を調整します。
# EPEL を有効にしてインストール

[root@dlp ~]#
dnf --enablerepo=epel -y install php-pear php-mbstring php-pdo php-intl php-xml php-gd php-mysqlnd php-bcmath php-gmp php-soap php-sodium php-opcache php-devel php-pecl-zip php-pecl-json-post php-pecl-apcu php-pecl-redis6 php-pecl-imagick valkey
[root@dlp ~]#
vi /etc/php-fpm.d/nextcloud.conf
;; 新規作成

[nextcloud]
user = apache
group = apache

listen = /run/php-fpm/nextcloud.sock
listen.acl_users = apache
listen.allowed_clients = 127.0.0.1

pm = dynamic
pm.max_children = 50
pm.start_servers = 5
pm.min_spare_servers = 5
pm.max_spare_servers = 35

php_value[session.save_handler] = files
php_value[session.save_path]    = /var/lib/php/session

;; 以下はサーバースペックや NextCloud の使用状況に応じて要調整
php_value[max_execution_time] = 3600
php_value[memory_limit] = 2G
php_value[post_max_size] = 2G
php_value[upload_max_filesize] = 2G
php_value[max_input_time] = 3600
php_value[max_input_vars] = 2000
php_value[date.timezone] = Asia/Tokyo

php_value[opcache.memory_consumption] = 128
php_value[opcache.interned_strings_buffer] = 32
php_value[opcache.max_accelerated_files] = 10000
php_value[opcache.revalidate_freq] = 1
php_value[opcache.save_comments] = 1
php_value[opcache.jit] = 1255
php_value[opcache.jit_buffer_size] = 128M

[root@dlp ~]#
systemctl restart php-fpm

[6] NextCloud 用のユーザーとデータベースを作成しておきます。
[root@dlp ~]#
mysql

Welcome to the MariaDB monitor.  Commands end with ; or \g.
Your MariaDB connection id is 9
Server version: 10.11.11-MariaDB MariaDB Server

Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

MariaDB [(none)]> create database nextcloud; 
Query OK, 1 row affected (0.00 sec)

MariaDB [(none)]> grant all privileges on nextcloud.* to nextcloud@'localhost' identified by 'password'; 
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> exit 
Bye
[7] NextCloud Talk で高性能バックエンドが使用できるように設定しておきます。
# シークレット生成

[root@dlp ~]#
openssl rand --hex 32

3ec4aab1a04108c419d95940ccb676813108c7c099bdd357114aab7247ca45e3
[root@dlp ~]#
openssl rand --hex 32

762a5d6ebd9b8a8b095a82195f974ac589f09e2d1583f5efe9b6987cb62b6607
[root@dlp ~]#
openssl rand --hex 32

6bf93375d83dbac41a830b969bf0d05a233549fe78038a75b9b00eb2b4885b6c
[root@dlp ~]#
podman pull ghcr.io/nextcloud-releases/aio-talk:latest

[root@dlp ~]# podman run \
--name=nextcloud-talk-hpb \
--restart=always \
--detach \
-e NC_DOMAIN=dlp.srv.world \
-e TALK_PORT=3478 \
-e TURN_SECRET=3ec4aab1a04108c419d95940ccb676813108c7c099bdd357114aab7247ca45e3 \
-e SIGNALING_SECRET=762a5d6ebd9b8a8b095a82195f974ac589f09e2d1583f5efe9b6987cb62b6607 \
-e INTERNAL_SECRET=6bf93375d83dbac41a830b969bf0d05a233549fe78038a75b9b00eb2b4885b6c \
-p 127.0.0.1:8080:8081 \
ghcr.io/nextcloud-releases/aio-talk:latest 
148c13e45a9940ef6a0989a17b9186d4d595b6b7554778d0b41bcd0ec5317684

# 動作確認

[root@dlp ~]#
curl http://127.0.0.1:8080/api/v1/welcome

{"nextcloud-spreed-signaling":"Welcome","version":"2.0.3~docker"}
[8] Apache httpd に NextCloud サイトの設定をします。
ダウンロードする NextCloud のバージョンは以下から確認できます。
⇒ https://download.nextcloud.com/server/releases/
[root@dlp ~]#
vi /etc/httpd/conf.d/nextcloud.conf
# 新規作成
# サーバ名や SSL/TLS 証明書のパスは自身の環境に合わせて変更

Timeout 3600
ProxyTimeout 3600
DirectoryIndex index.php index.html
Header set Strict-Transport-Security "max-age=15768000; includeSubDomains; preload"

<VirtualHost *:80>
    DocumentRoot /var/www/nextcloud
    ServerName dlp.srv.world

    RewriteEngine On
    RewriteCond %{HTTPS} off
    RewriteRule ^(.*)$ https://%{HTTP_HOST}%{REQUEST_URI} [R=301,L]
</VirtualHost>

<VirtualHost *:443>
    DocumentRoot /var/www/nextcloud
    ServerName dlp.srv.world
    SSLEngine on
    SSLCertificateFile      /etc/letsencrypt/live/dlp.srv.world/cert.pem
    SSLCertificateKeyFile   /etc/letsencrypt/live/dlp.srv.world/privkey.pem
    SSLCertificateChainFile /etc/letsencrypt/live/dlp.srv.world/chain.pem

    ProxyPass /standalone-signaling/ ws://127.0.0.1:8080/
    RequestHeader set X-Real-IP %{REMOTE_ADDR}s

    RewriteEngine On
    RewriteRule ^/standalone-signaling/spreed/$ - [L]
    RewriteRule ^/standalone-signaling/api/(.*) http://127.0.0.1:8080/api/$1 [L,P]
</VirtualHost>

<Directory "/var/www/nextcloud">
    Options FollowSymLinks MultiViews
    AllowOverride All
    Require all granted

    <FilesMatch \.(php|phar)$>
        SetHandler "proxy:unix:/run/php-fpm/nextcloud.sock|fcgi://localhost"
    </FilesMatch>
</Directory>

[root@dlp ~]#
wget https://download.nextcloud.com/server/releases/latest.zip -P /var/www/

[root@dlp ~]#
unzip /var/www/latest.zip -d /var/www/

[root@dlp ~]#
chown -R apache:apache /var/www/nextcloud

[root@dlp ~]#
systemctl reload httpd

[root@dlp ~]#
systemctl enable --now valkey

[9] SELinux を有効にしている場合は、許可ルールの追加が必要です。
[root@dlp ~]#
setsebool -P httpd_can_network_connect on

[root@dlp ~]#
setsebool -P httpd_unified on

[root@dlp ~]#
setsebool -P httpd_execmem on

[root@dlp ~]#
setsebool -P httpd_use_fusefs on

[root@dlp ~]#
setsebool -P nis_enabled on

[root@dlp ~]#
vi nextcloud.te
# 以下の内容で新規作成

module nextcloud 1.0;

require {
        type configfs_t;
        type httpd_t;
        type redis_t;
        type rpm_t;
        type fusefs_t;
        type httpd_sys_script_t;
        type fuse_device_t;
        type httpd_sys_rw_content_t;
        type kernel_t;
        type lib_t;
        type init_t;
        type unconfined_t;
        type local_login_t;
        type crond_t;
        type policykit_t;
        type lsmd_t;
        type mcelog_t;
        type firewalld_t;
        type systemd_logind_t;
        type irqbalance_t;
        type udev_t;
        type sshd_t;
        type NetworkManager_t;
        type virt_qemu_ga_t;
        type unconfined_service_t;
        type syslogd_t;
        type setroubleshootd_t;
        type rhsmcertd_t;
        type getty_t;
        type mysqld_t;
        type auditd_t;
        type chronyd_t;
        type sysctl_net_t;
        type system_dbusd_t;
        type proc_t;
        type container_t;
        class file { create unlink write open read execute execute_no_trans getattr };
        class dir { add_name write read remove_name rmdir getattr setattr mounton search };
        class lnk_file unlink;
        class chr_file { open read write };
        class process setrlimit;
        class system module_request;
        class capability dac_read_search;
        class filesystem { mount unmount associate };

}

#============= httpd_t ==============
allow httpd_t configfs_t:dir getattr;
allow httpd_t lib_t:dir { add_name remove_name setattr write };
allow httpd_t lib_t:file { create unlink write };

#============= httpd_sys_script_t ==============
allow httpd_sys_script_t fuse_device_t:chr_file { open read write };
allow httpd_sys_script_t httpd_sys_rw_content_t:dir mounton;
allow httpd_sys_script_t httpd_sys_rw_content_t:file { execute execute_no_trans };
allow httpd_sys_script_t lib_t:dir setattr;
allow httpd_sys_script_t self:process setrlimit;
allow httpd_sys_script_t kernel_t:system module_request;
allow httpd_sys_script_t NetworkManager_t:dir search;
allow httpd_sys_script_t NetworkManager_t:file { getattr open read };
allow httpd_sys_script_t auditd_t:dir search;
allow httpd_sys_script_t auditd_t:file { getattr open read };
allow httpd_sys_script_t chronyd_t:dir search;
allow httpd_sys_script_t chronyd_t:file { getattr open read };
allow httpd_sys_script_t crond_t:dir search;
allow httpd_sys_script_t crond_t:file { getattr open read };
allow httpd_sys_script_t firewalld_t:dir search;
allow httpd_sys_script_t firewalld_t:file { getattr open read };
allow httpd_sys_script_t getty_t:dir search;
allow httpd_sys_script_t getty_t:file { getattr open read };
allow httpd_sys_script_t httpd_t:dir search;
allow httpd_sys_script_t httpd_t:file { getattr open read };
allow httpd_sys_script_t init_t:dir search;
allow httpd_sys_script_t init_t:file { getattr open read };
allow httpd_sys_script_t irqbalance_t:dir search;
allow httpd_sys_script_t irqbalance_t:file { getattr open read };
allow httpd_sys_script_t kernel_t:dir search;
allow httpd_sys_script_t kernel_t:file { getattr open read };
allow httpd_sys_script_t local_login_t:dir search;
allow httpd_sys_script_t local_login_t:file { getattr open read };
allow httpd_sys_script_t lsmd_t:dir search;
allow httpd_sys_script_t lsmd_t:file { getattr open read };
allow httpd_sys_script_t mcelog_t:dir search;
allow httpd_sys_script_t mcelog_t:file { getattr open read };
allow httpd_sys_script_t mysqld_t:dir search;
allow httpd_sys_script_t mysqld_t:file { getattr open read };
allow httpd_sys_script_t policykit_t:dir search;
allow httpd_sys_script_t policykit_t:file { getattr open read };
allow httpd_sys_script_t rhsmcertd_t:dir search;
allow httpd_sys_script_t rhsmcertd_t:file { getattr open read };
allow httpd_sys_script_t setroubleshootd_t:dir search;
allow httpd_sys_script_t setroubleshootd_t:file { getattr open read };
allow httpd_sys_script_t sshd_t:dir search;
allow httpd_sys_script_t sshd_t:file { getattr open read };
allow httpd_sys_script_t syslogd_t:dir search;
allow httpd_sys_script_t syslogd_t:file { getattr open read };
allow httpd_sys_script_t system_dbusd_t:dir search;
allow httpd_sys_script_t system_dbusd_t:file { getattr open read };
allow httpd_sys_script_t systemd_logind_t:dir search;
allow httpd_sys_script_t systemd_logind_t:file { getattr open read };
allow httpd_sys_script_t udev_t:dir search;
allow httpd_sys_script_t udev_t:file { getattr open read };
allow httpd_sys_script_t unconfined_service_t:dir search;
allow httpd_sys_script_t unconfined_service_t:file { getattr open read };
allow httpd_sys_script_t unconfined_t:dir search;
allow httpd_sys_script_t unconfined_t:file { getattr open read };
allow httpd_sys_script_t virt_qemu_ga_t:dir search;
allow httpd_sys_script_t virt_qemu_ga_t:file { getattr open read };
allow httpd_sys_script_t redis_t:dir search;
allow httpd_sys_script_t redis_t:file { getattr open read };
allow httpd_sys_script_t rpm_t:dir search;
allow httpd_sys_script_t rpm_t:file { getattr open read };
allow httpd_sys_script_t fusefs_t:file { execute execute_no_trans };
allow httpd_sys_script_t fusefs_t:filesystem mount;
allow httpd_sys_script_t fusefs_t:filesystem unmount;
allow httpd_sys_script_t self:capability dac_read_search;

#============= chronyd_t ==============
allow chronyd_t sysctl_net_t:dir search;

#============= init_t ==============
allow init_t httpd_sys_rw_content_t:dir { read remove_name rmdir write };
allow init_t httpd_sys_rw_content_t:file unlink;
allow init_t httpd_sys_rw_content_t:lnk_file unlink;

#============= container_t ==============
allow container_t proc_t:filesystem associate;

[root@dlp ~]#
checkmodule -m -M -o nextcloud.mod nextcloud.te

[root@dlp ~]#
semodule_package --outfile nextcloud.pp --module nextcloud.mod

[root@dlp ~]#
semodule -i nextcloud.pp

[10] 任意のクライアントコンピューターから Webブラウザーで [https://(サーバーのホスト名)/] へアクセスすると以下のような画面が表示されます。 管理者アカウントとデータベース接続の設定をします。 任意の管理者ユーザー名とパスワードを入力します。 データベースは [6] で作成した MariaDB データベースを指定します。 入力後、画面下部の [Install] をクリックします。 なお、以下の画面例は英語表示となっていますが、日本語 OS でアクセスすれば日本語で表示されます。
[11] NextCloud 推奨のアプリケーションをインストールするか選択します。
当例ではインストールで進めます。
[12] スタートページが表示されます。
[13] セットアップ完了後は [https://(サーバーのホスト名)/] へアクセスすることで、ログイン画面から利用可能となります。
[14] 日本語 OS でアクセスすれば自動で日本語表示になります。自動で切り替わらなない場合でも、設定から日本語表示に切り替えることもできます。
[15] 初期セットアップ後、NextCloud 推奨要件であるメモリーキャッシュを有効にしておきます。 また、推奨設定である [default_phone_region] 設定も追加しておきます。
[root@dlp ~]#
vi /var/www/nextcloud/config/config.php
.....
.....
  // セクション内の最終行に追記
  // [default_phone_region] には自身の国コードを指定 (ISO 3166-1) 
  'installed' => true,
  'memcache.local' => '\OC\Memcache\APCu',
  'default_phone_region' => 'JP',
  'maintenance_window_start' => 1,
  'memcache.locking' => '\OC\Memcache\Redis',
  'memcache.distributed' => '\OC\Memcache\Redis',
  'redis' => array(
    'host' => '127.0.0.1',
    'port' => 6379,
    'timeout' => 0.0,
  ),
);

[root@dlp ~]#
sudo -u apache php --define apc.enable_cli=1 /var/www/nextcloud/occ db:add-missing-indices

The current PHP memory limit is below the recommended value of 512MB.
Adding additional mail_messages_strucanalyz_idx index to the oc_mail_messages table, this can take some time...
oc_mail_messages table updated successfully.
Adding additional mail_acc_prov_idx index to the oc_mail_accounts table, this can take some time...
oc_mail_accounts table updated successfully.
Adding additional mail_alias_accid_idx index to the oc_mail_aliases table, this can take some time...
oc_mail_aliases table updated successfully.
Adding additional mail_messages_mb_id_uid_uidx index to the oc_mail_messages table, this can take some time...
Removing mail_messages_mb_id_uid index from the oc_mail_messages table
oc_mail_messages table updated successfully.
Adding additional mail_smime_certs_uid_email_idx index to the oc_mail_smime_certificates table, this can take some time...
Removing mail_smime_certs_uid_idx index from the oc_mail_smime_certificates table
oc_mail_smime_certificates table updated successfully.
Adding additional mail_trusted_senders_idx index to the oc_mail_trusted_senders table, this can take some time...
Removing mail_trusted_senders_type index from the oc_mail_trusted_senders table
oc_mail_trusted_senders table updated successfully.
Adding additional mail_coll_idx index to the oc_mail_coll_addresses table, this can take some time...
Removing mail_coll_addr_userid_index index from the oc_mail_coll_addresses table
Removing mail_coll_addr_email_index index from the oc_mail_coll_addresses table
oc_mail_coll_addresses table updated successfully.

[root@dlp ~]#
sudo -u apache php --define apc.enable_cli=1 /var/www/nextcloud/occ maintenance:repair --include-expensive

[root@dlp ~]#
systemctl reload httpd

[16] NextCloud Talk 用の高性能バックエンドを設定しておきます。
管理ユーザーでログインして [Administration settings] を開きます。
[17] 左ペインで [Talk] をクリックします。
[18] 右ペインで [Add High-performance backend server] をクリックします。
[19] [High-performance backend] の項目には [https://(自身のサーバー名)/standalone-signaling/] を入力し、[Shared secret] の項目には、[7] でコンテナーに設定した [SIGNALING_SECRET] の値を入力します。
設定に問題なければ以下のように [OK] と表示されます。
以上で設定完了です。
関連コンテンツ