Postgresql fix (#6441)

* Assume maintenance mode is *on* if database is inaccessible

* Specify ash shell

* Update psycopg requirements

* Style fixes

* style fix - backends.py
This commit is contained in:
Oliver 2024-02-07 22:33:37 +11:00 committed by GitHub
parent edd6f25411
commit 22af3e2f59
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
4 changed files with 20 additions and 11 deletions

View File

@ -84,7 +84,7 @@ RUN if [ `apk --print-arch` = "armv7" ]; then \
COPY tasks.py docker/gunicorn.conf.py docker/init.sh ./ COPY tasks.py docker/gunicorn.conf.py docker/init.sh ./
RUN chmod +x init.sh RUN chmod +x init.sh
ENTRYPOINT ["/bin/sh", "./init.sh"] ENTRYPOINT ["/bin/ash", "./init.sh"]
FROM inventree_base as prebuild FROM inventree_base as prebuild

View File

@ -28,11 +28,16 @@ class InvenTreeMaintenanceModeBackend(AbstractStateBackend):
Returns: Returns:
bool: True if maintenance mode is active, False otherwise. bool: True if maintenance mode is active, False otherwise.
""" """
value = InvenTree.helpers.str2bool( try:
common.models.InvenTreeSetting.get_setting( setting = common.models.InvenTreeSetting.objects.get(key=self.SETTING_KEY)
self.SETTING_KEY, backup_value=False, create=False, cache=False value = InvenTree.helpers.str2bool(setting.value)
) except common.models.InvenTreeSetting.DoesNotExist:
) # Database is accessible, but setting is not available - assume False
value = False
except (IntegrityError, OperationalError, ProgrammingError):
# Database is inaccessible - assume we are not in maintenance mode
logger.warning('Failed to read maintenance mode state - assuming True')
value = True
logger.debug('Maintenance mode state: %s', value) logger.debug('Maintenance mode state: %s', value)
@ -50,10 +55,13 @@ class InvenTreeMaintenanceModeBackend(AbstractStateBackend):
if self.get_value() == value: if self.get_value() == value:
break break
except (IntegrityError, OperationalError, ProgrammingError): except (IntegrityError, OperationalError, ProgrammingError):
logger.warning( # In the database is locked, then
'Failed to set maintenance mode state in database (%s retries left)', logger.debug(
retries, 'Failed to set maintenance mode state (%s retries left)', retries
) )
time.sleep(0.1) time.sleep(0.1)
retries -= 1 retries -= 1
if retries == 0:
logger.warning('Failed to set maintenance mode state')

View File

@ -1,4 +1,5 @@
#!/bin/sh #!/bin/ash
# exit when any command fails # exit when any command fails
set -e set -e

View File

@ -7,7 +7,7 @@ setuptools>=69.0.0
wheel>=0.41.0 wheel>=0.41.0
# Database links # Database links
psycopg[binary]>=3.1.18 psycopg[binary, c, pool]
mysqlclient>=2.2.0 mysqlclient>=2.2.0
mariadb>=1.1.8 mariadb>=1.1.8