Skip to content

Commit

Permalink
Merge branch 'hotfix/10.2.1'
Browse files Browse the repository at this point in the history
  • Loading branch information
Guy Elsmore-Paddock committed Mar 31, 2023
2 parents d650799 + 71b9cca commit 9f90487
Show file tree
Hide file tree
Showing 4 changed files with 109 additions and 13 deletions.
90 changes: 90 additions & 0 deletions docker/nextcloud-common/bundled-patches/config-disable-flock.patch
Original file line number Diff line number Diff line change
@@ -0,0 +1,90 @@
From c2ac41b7911a75c7b46eddad48e083a31d176281 Mon Sep 17 00:00:00 2001
From: Guy Elsmore-Paddock <guy.paddock@gmail.com>
Date: Thu, 30 Mar 2023 11:01:59 -0400
Subject: [PATCH] [IT-91] QF: Disable `flock()` on Config Files

After upgrading to K8s from `1.23.9` to `1.25.5` and the SMB CSI driver
from `1.9.0` to `1.10.0`, `flock()` appears to be causing this error on
cron runs and on any Nextcloud pod other than the first one that
launches:

```
Uncaught Error: Call to a member function getLogger() on null in /var/www/html/index.php:71
```

Caused by:
```
Exception: Could not acquire a shared lock on the config file /var/www/html/config/apcu.config.php in /var/www/html/lib/private/Config.php:216
```

File locking on config files was added in 2014 and was recently removed
and then re-added in Nextcloud so I doubt a change in Nextcloud caused
this issue to appear.
---
lib/private/Config.php | 28 ++++++++++++++++++++--------
1 file changed, 20 insertions(+), 8 deletions(-)

diff --git a/lib/private/Config.php b/lib/private/Config.php
index 0e3a9b22a7..e1420d55b5 100644
--- a/lib/private/Config.php
+++ b/lib/private/Config.php
@@ -224,10 +224,13 @@ class Config {
continue;
}

+ // GAP on 2023-03-30: File locking does not appear to work reliably on
+ // SMB-mounted volumes in AKS.
+ //
// Try to acquire a file lock
- if (!flock($filePointer, LOCK_SH)) {
- throw new \Exception(sprintf('Could not acquire a shared lock on the config file %s', $file));
- }
+ //if (!flock($filePointer, LOCK_SH)) {
+ // throw new \Exception(sprintf('Could not acquire a shared lock on the config file %s', $file));
+ //}

unset($CONFIG);
include $file;
@@ -235,8 +238,11 @@ class Config {
$this->cache = array_merge($this->cache, $CONFIG);
}

+ // GAP on 2023-03-30: File locking does not appear to work reliably on
+ // SMB-mounted volumes in AKS.
+ //
// Close the file pointer and release the lock
- flock($filePointer, LOCK_UN);
+ //flock($filePointer, LOCK_UN);
fclose($filePointer);
}

@@ -277,16 +283,22 @@ class Config {
'This can usually be fixed by giving the webserver write access to the config directory.');
}

+ // GAP on 2023-03-30: File locking does not appear to work reliably on
+ // SMB-mounted volumes in AKS.
+ //
// Try to acquire a file lock
- if (!flock($filePointer, LOCK_EX)) {
- throw new \Exception(sprintf('Could not acquire an exclusive lock on the config file %s', $this->configFilePath));
- }
+ //if (!flock($filePointer, LOCK_EX)) {
+ // throw new \Exception(sprintf('Could not acquire an exclusive lock on the config file %s', $this->configFilePath));
+ //}

+ // GAP on 2023-03-30: File locking does not appear to work reliably on
+ // SMB-mounted volumes in AKS.
+ //
// Write the config and release the lock
ftruncate($filePointer, 0);
fwrite($filePointer, $content);
fflush($filePointer);
- flock($filePointer, LOCK_UN);
+ //flock($filePointer, LOCK_UN);
fclose($filePointer);

if (function_exists('opcache_invalidate')) {
--
2.40.0.windows.1

18 changes: 12 additions & 6 deletions overlays/00-sample/configure-storage.nextcloud.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -51,8 +51,10 @@ spec:
- uid=33
- gid=33
- dir_mode=0770
- file_mode=0770
- actimeo=2
- file_mode=0660
- vers=3.1.1
- nosharesock
- cache=strict
name:
prefix: "pv-nextcloud-sample-"
suffix: ~
Expand Down Expand Up @@ -124,8 +126,10 @@ spec:
- uid=33
- gid=33
- dir_mode=0770
- file_mode=0770
- actimeo=2
- file_mode=0660
- vers=3.1.1
- nosharesock
- cache=strict
name:
prefix: "pv-nextcloud-sample-"
suffix: ~
Expand Down Expand Up @@ -201,8 +205,10 @@ spec:
- uid=33
- gid=33
- dir_mode=0770
- file_mode=0770
- actimeo=2
- file_mode=0660
- vers=3.1.1
- nosharesock
- cache=strict
name:
prefix: "pv-nextcloud-sample-"
suffix: ~
Expand Down
12 changes: 6 additions & 6 deletions overlays/00-sample/kustomization.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
# folder and customize manifests in each one to match your environments.
#
# @author Guy Elsmore-Paddock (guy@inveniem.com)
# @copyright Copyright (c) 2022, Inveniem
# @copyright Copyright (c) 2022-2023, Inveniem
# @license GNU AGPL version 3 or any later version
#
apiVersion: kustomize.config.k8s.io/v1beta1
Expand Down Expand Up @@ -96,20 +96,20 @@ images:

- name: inveniem/nextcloud-cron
newName: your-acr-instance.azurecr.io/inveniem/nextcloud-cron
newTag: 10.2.0
newTag: 10.2.1

- name: inveniem/nextcloud-apache
newName: your-acr-instance.azurecr.io/inveniem/nextcloud-apache
newTag: 10.2.0
newTag: 10.2.1

- name: inveniem/nextcloud-fpm
newName: your-acr-instance.azurecr.io/inveniem/nextcloud-fpm
newTag: 10.2.0
newTag: 10.2.1

- name: inveniem/nextcloud-nginx-middleware
newName: your-acr-instance.azurecr.io/inveniem/nextcloud-nginx-middleware
newTag: 10.2.0
newTag: 10.2.1

- name: inveniem/sftp-ws-server
newName: your-acr-instance.azurecr.io/inveniem/sftp-ws-server
newTag: 10.2.0
newTag: 10.2.1
2 changes: 1 addition & 1 deletion overlays/00-sample/publish.profile
Original file line number Diff line number Diff line change
Expand Up @@ -70,7 +70,7 @@ NEW_RELIC_KEY=""
#
# Leave blank if you do not use New Relic monitoring.
#
NEW_RELIC_AGENT_URL="https://download.newrelic.com/php_agent/release/newrelic-php5-10.2.0.314-linux.tar.gz"
NEW_RELIC_AGENT_URL="https://download.newrelic.com/php_agent/release/newrelic-php5-10.8.0.323-linux.tar.gz"

##
# The name by which you would like Nextcloud to identify itself in New Relic.
Expand Down

0 comments on commit 9f90487

Please sign in to comment.