Object/node health check

Author Message

Piotrek Karaś

Tuesday 01 July 2008 2:55:17 am

Hi there,

Would there be any reliable method of checking if a content object of given ID and its nodes are in a consistent shape? For example, by querying the database and checking if certain columns have proper values, that certain relations exist, etc...

Thanks,
Piotrek

--
Company: mediaSELF Sp. z o.o., http://www.mediaself.pl
eZ references: http://ez.no/partners/worldwide_partners/mediaself
eZ certified developer: http://ez.no/certification/verify/272585
eZ blog: http://ez.ryba.eu

Björn Dieding@xrow.de

Friday 04 July 2008 4:03:57 am

no sorry doesn`t exist yet

Looking for a new job? http://www.xrow.com/xrow-GmbH/Jobs
Looking for hosting? http://hostingezpublish.com
-----------------------------------------------------------------------------
GMT +01:00 Hannover, Germany
Web: http://www.xrow.com/

Hans Melis

Friday 04 July 2008 4:29:57 am

And that goes for the whole database. There are no sanity check utilities.

Hans
http://blog.hansmelis.be

Piotrek Karaś

Friday 04 July 2008 4:50:10 am

Do you guys mean: they haven't been put together yet or they are impossible to come up with? ;)

--
Company: mediaSELF Sp. z o.o., http://www.mediaself.pl
eZ references: http://ez.no/partners/worldwide_partners/mediaself
eZ certified developer: http://ez.no/certification/verify/272585
eZ blog: http://ez.ryba.eu

Hans Melis

Friday 04 July 2008 6:06:27 am

I'm quite sure it's not a question of it being possible, but complexity might be an issue.

I think part of the problem would be solved if there were constraints to make sure there is at least referential integrity. Too bad MyISAM is around or it would be possible to add contraints.

Hans
http://blog.hansmelis.be

André R.

Friday 04 July 2008 7:17:57 am

Took me a while to find it, but the closest thing I know about is this:
http://ez.no/developer/forum/general/problem_corrupt_contentobjects

eZ Online Editor 5: http://projects.ez.no/ezoe || eZJSCore (Ajax): http://projects.ez.no/ezjscore || eZ Publish EE http://ez.no/eZPublish/eZ-Publish-Enterprise-Subscription
@: http://twitter.com/andrerom

Piotrek Karaś

Friday 04 July 2008 4:46:40 pm

Thanks, André!

I think part of the problem would be solved if there were constraints to make sure there is at least referential integrity. Too bad MyISAM is around or it would be possible to add contraints.

Actually - we only use InnoDB, but no constraints seem to be there out of the box. Shouldn't transactions take care of the problem, though?

Cheers,
Piotrek

--
Company: mediaSELF Sp. z o.o., http://www.mediaself.pl
eZ references: http://ez.no/partners/worldwide_partners/mediaself
eZ certified developer: http://ez.no/certification/verify/272585
eZ blog: http://ez.ryba.eu

Hans Melis

Sunday 06 July 2008 10:17:05 pm

Actually - we only use InnoDB, but no constraints seem to be there out of the box.

No, because (a) eZ Publish started with MyISAM only for MySQL and (b) I think MyISAM is still supported.

Shouldn't transactions take care of the problem, though?

Transactions say nothing about the data entered. It's just a protection in case it goes wrong so you don't get half of the data in the db while the other half failed. As long as all database conditions are met (not null columns, datatypes, query syntax, ...) there is nothing to stop bad data from going in.

To illustrate the difference:
You create your own query to add a row in the ezcontentobject_tree table and you wrap it in a transaction. Unfortunately, you introduced a bug somewhere in the code resulting in multiplied parent node ids (which is a foreign key in that table). Two situations: node id A is double of its expected value, but still exists in the db; node id B does not exist at the moment.

The database with only transactions:
- A: The query will be executed and the row added
- B: The query will be executed and the row added

The database with transactions and foreign key constraints:
- A: The query will be executed and the row added
- B: The query will be executed and will fail, triggering a rollback due to the transaction.

So you can see that contraints don't give full protection, but they do take out bogus entries where foreign keys would point to a big void. They also come into play when you're deleting stuff to make sure the database remains in a consistent state.

Hans
http://blog.hansmelis.be

Piotrek Karaś

Sunday 06 July 2008 11:00:00 pm

Hello Hans,

From what you described, what I had known about transactions and constraints was quite right. You're right though - constraints would provide additional level of bogus data elimination, even though I guess in order to have a complete integrity, everything would have to be constrained and isolation level would have to be raised to serializable, right? Wouldn't this all make db heavy and "picky"?

Just to compare the practices, in my own code I used to run my own PHP-level integrity checks, and manually rolled-back, even if DB would allow commit on the physical level. Of course, I realize that would only be a slight enhancement, not a replacement of constraints.

Last thing. Isn't there another reason for which constrains aren't used? I've heard of this approach for application architecture where db, which uses the smallest possible amount of functionality of particular db engine, serves merely as a data storage, and all other functions and integrity are controlled by the application layer. We now hear more eZ Publish supporting more database engines, isn't that a mean of being able to deliver that?

Thanks,
Piotrek

--
Company: mediaSELF Sp. z o.o., http://www.mediaself.pl
eZ references: http://ez.no/partners/worldwide_partners/mediaself
eZ certified developer: http://ez.no/certification/verify/272585
eZ blog: http://ez.ryba.eu

Powered by eZ Publish™ CMS Open Source Web Content Management. Copyright © 1999-2014 eZ Systems AS (except where otherwise noted). All rights reserved.

eZ debug

Timing: Jan 18 2025 16:17:40
Script start
Timing: Jan 18 2025 16:17:40
Module start 'layout'
Timing: Jan 18 2025 16:17:40
Module start 'content'
Timing: Jan 18 2025 16:17:41
Module end 'content'
Timing: Jan 18 2025 16:17:41
Script end

Main resources:

Total runtime1.0277 sec
Peak memory usage4,096.0000 KB
Database Queries79

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0061 587.9141152.6250
Module start 'layout' 0.00620.0025 740.539139.4453
Module start 'content' 0.00871.0172 779.9844714.3047
Module end 'content' 1.02590.0018 1,494.289124.1641
Script end 1.0277  1,518.4531 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00320.3121160.0002
Check MTime0.00130.1309160.0001
Mysql Total
Database connection0.00060.061110.0006
Mysqli_queries0.944291.8695790.0120
Looping result0.00070.0712770.0000
Template Total0.997197.020.4985
Template load0.00230.220220.0011
Template processing0.994896.794620.4974
Template load and register function0.00010.009810.0001
states
state_id_array0.00060.054410.0006
state_identifier_array0.00140.138820.0007
Override
Cache load0.00200.1993550.0000
Sytem overhead
Fetch class attribute can translate value0.00070.070940.0002
Fetch class attribute name0.00140.1344130.0001
XML
Image XML parsing0.00210.206740.0005
class_abstraction
Instantiating content class attribute0.00000.0032180.0000
General
dbfile0.00150.1429350.0000
String conversion0.00000.000840.0000
Note: percentages do not add up to 100% because some accumulators overlap

Templates used to render the page:

UsageRequested templateTemplateTemplate loadedEditOverride
1node/view/full.tplfull/forum_topic.tplextension/sevenx/design/simple/override/templates/full/forum_topic.tplEdit templateOverride template
9content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
9content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
17content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
7content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
3content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 47
 Number of unique templates used: 7

Time used to render debug report: 0.0001 secs