I saw this today:
Applying maasserver.0131_update_event_model_for_audit_logs...Traceback (most recent call last):
File "/usr/lib/python3/dist-packages/django/db/backends/utils.py", line 64, in execute
return self.cursor.execute(sql, params)
psycopg2.IntegrityError: insert or update on table "maasserver_event" violates foreign key constraint "maasserver_event_node_id_dd4495a7_fk_maasserver_node_id"
DETAIL: Key (node_id)=(16) is not present in table "maasserver_node".
The above exception was the direct cause of the following exception:
Traceback (most recent call last):
File "/usr/lib/python3.6/runpy.py", line 193, in _run_module_as_main
"__main__", mod_spec)
File "/usr/lib/python3.6/runpy.py", line 85, in _run_code
exec(code, run_globals)
File "/usr/lib/python3/dist-packages/maasserver/__main__.py", line 9, in <module>
raise SystemExit(execute_from_command_line())
File "/usr/lib/python3/dist-packages/maasserver/__init__.py", line 56, in execute_from_command_line
management.execute_from_command_line()
File "/usr/lib/python3/dist-packages/django/core/management/__init__.py", line 364, in execute_from_command_line
utility.execute()
File "/usr/lib/python3/dist-packages/django/core/management/__init__.py", line 356, in execute
self.fetch_command(subcommand).run_from_argv(self.argv)
File "/usr/lib/python3/dist-packages/django/core/management/base.py", line 283, in run_from_argv
self.execute(*args, **cmd_options)
File "/usr/lib/python3/dist-packages/django/core/management/base.py", line 330, in execute
output = self.handle(*args, **options)
File "/usr/lib/python3/dist-packages/maasserver/management/commands/dbupgrade.py", line 426, in handle
fake_initial=self._south_was_performed(database))
File "/usr/lib/python3/dist-packages/django/core/management/__init__.py", line 131, in call_command
return command.execute(*args, **defaults)
File "/usr/lib/python3/dist-packages/django/core/management/base.py", line 330, in execute
output = self.handle(*args, **options)
File "/usr/lib/python3/dist-packages/django/core/management/commands/migrate.py", line 204, in handle
fake_initial=fake_initial,
File "/usr/lib/python3/dist-packages/django/db/migrations/executor.py", line 115, in migrate
state = self._migrate_all_forwards(state, plan, full_plan, fake=fake, fake_initial=fake_initial)
File "/usr/lib/python3/dist-packages/django/db/migrations/executor.py", line 145, in _migrate_all_forwards
state = self.apply_migration(state, migration, fake=fake, fake_initial=fake_initial)
File "/usr/lib/python3/dist-packages/django/db/migrations/executor.py", line 244, in apply_migration
state = migration.apply(state, schema_editor)
File "/usr/lib/python3/dist-packages/django/db/migrations/migration.py", line 129, in apply
operation.database_forwards(self.app_label, schema_editor, old_state, project_state)
File "/usr/lib/python3/dist-packages/django/db/migrations/operations/fields.py", line 221, in database_forwards
schema_editor.alter_field(from_model, from_field, to_field)
File "/usr/lib/python3/dist-packages/django/db/backends/base/schema.py", line 515, in alter_field
old_db_params, new_db_params, strict)
File "/usr/lib/python3/dist-packages/django/db/backends/postgresql/schema.py", line 112, in _alter_field
new_db_params, strict,
File "/usr/lib/python3/dist-packages/django/db/backends/base/schema.py", line 779, in _alter_field
self.execute(self._create_fk_sql(model, new_field, "_fk_%(to_table)s_%(to_column)s"))
File "/usr/lib/python3/dist-packages/django/db/backends/base/schema.py", line 120, in execute
cursor.execute(sql, params)
File "/usr/lib/python3/dist-packages/django/db/backends/utils.py", line 64, in execute
return self.cursor.execute(sql, params)
File "/usr/lib/python3/dist-packages/django/db/utils.py", line 94, in __exit__
six.reraise(dj_exc_type, dj_exc_value, traceback)
File "/usr/lib/python3/dist-packages/django/utils/six.py", line 685, in reraise
raise value.with_traceback(tb)
File "/usr/lib/python3/dist-packages/django/db/backends/utils.py", line 64, in execute
return self.cursor.execute(sql, params)
django.db.utils.IntegrityError: insert or update on table "maasserver_event" violates foreign key constraint "maasserver_event_node_id_dd4495a7_fk_maasserver_node_id"
DETAIL: Key (node_id)=(16) is not present in table "maasserver_node".
dpkg: error processing package maas-region-controller (--configure):
installed maas-region-controller package post-installation script subprocess returned error exit status 1
This looks like a very problematic failure!
Digging in there is an old record for what must be an old node:
maasdb=> select * from maasserver_event where node_id=16; +------ ------- ------- ------- ----+-- ------- ------- ------- ------- -+----- ---+--- ------- ------- ------- --+---- -----+- ------- -
id | created | updated | action | description | node_id | type_id
-------
96387 | 2016-07-01 17:03:36.883757+01 | 2016-07-01 17:03:36.883757+01 | | Power state queried: off | 16 | 6
(1 row)
I will try deleting that record and proceeding from there, but we should nonetheless have an upgrade strategy to deal with loose ends in the event table.