Multiple sites single database - worth the hassle??

Author Message

Bruce Morrison

Monday 09 February 2004 11:57:12 pm

I'm aware that eZ Publish is capable of serving multiple web sites with a single database. I want to do this as I have a number of sites that will be using the same content classes. These sties are separate is all other aspects.

I've come up with the following pros and cons list for single database Vs a database per site.

Pros
+ only create content classes and related permissions once
+ easy setup for new sites
+ when new content types are created they are automatically available on all sites

Cons
+ risk of content "spilling" onto wrong site due to issue with poorly configured permissions.
+ difficult (impossible?) to backup single site content
+ database table size will grow as amount of content/sites increase

Can anyone shed further light on these issue?

Thanks
Bruce

My Blog: http://www.stuffandcontent.com/
Follow me on twitter: http://twitter.com/brucemorrison
Consolidated eZ Publish Feed : http://friendfeed.com/rooms/ez-publish

James Packham

Tuesday 10 February 2004 3:23:19 am

Pro - restrict data between sites more easily, for example use templates to make class "Hockey News" visible from sites "Sports Review" and "Hockey Review" but not "Football Review" or some such :) I know it's just a spin off from pro number 3, but thought I should point it out.

Also if you ever wanted to change these, so that two sites became one then you'd only need to change the templates (something you would have to do anyway) and not worry about importing data, which can get frustrating (voice of experience).

~James~

Lazaro Ferreira

Tuesday 10 February 2004 3:44:22 am

Hi,

I hardly can imagine any advantage in using the same database for more than one site (note: I'm talking about a site not a siteaccess )

I don't see reusing content classes as pros, you can use the import/export package functionality to do this professionally

For us, a website development company, it comes naturally that one dynamic site should use its own and unique database, imagine a corrupt database scenario, if we were sharing the same tables for three clients, chances are that table corruption is originated by operations in one site, but as a result you could end we three affected clients

Nevertheless, I would like to hear of more PROS for using the same database

Lazaro
http://www.mzbusiness.com

Alex Jones

Tuesday 10 February 2004 6:40:46 am

Pro: Shared user accounts across the sites - assuming they are related - so users do not have to register more than once. Though perhaps this could be construed as a con if the sites are not related.

Alex

Alex
[ bald_technologist on the IRC channel (irc.freenode.net): #eZpublish ]

<i>When in doubt, clear the cache.</i>

Balazs Halasy

Tuesday 10 February 2004 7:01:00 am

The acoounts could have been synced to an LDAP server, so the last argument kinda falls apart. But still - this is a taste & style issue. How to do it "right" is a bit difficult to say without knowing more about the problem domain. However, running too many different sites within one database is a bit risky.. I agree with Lazaro.. :-)

Balazs

Bruce Morrison

Tuesday 10 February 2004 2:54:10 pm

Thanks for all the feedback.

Cheers
Bruce

My Blog: http://www.stuffandcontent.com/
Follow me on twitter: http://twitter.com/brucemorrison
Consolidated eZ Publish Feed : http://friendfeed.com/rooms/ez-publish

Georg Franz

Wednesday 11 February 2004 12:33:49 am

Hi,

we are currently developing "multi-sites in one db" and I want to share my experience.

The sites contains different content (a comedy web-site, an internet-magazine, a "corporate web-site" etc.). At the end, around 10 different sites are using one db.

The main reasons:
-) Saving marketing costs for the site owners. Or in other words: Sharing of user accounts. (It's hard and expensive to get new, registered users and it's a big benefit, if a user only needs to register once to get access to e.g. 10 sites.)

So you can also share the marketing costs between the site owners. (e.g.: A new user comes to site A. At site A you give the possibility to get the newsletter of site B. Or to sell products of site C. At site C you also give the possibility to subscribte the newsletter of site A etc.)

-) Sharing of content increases the visits of all sites. All sites have e.g. a "search" feature. If a user don't find what he is searching for at one site, maybe another site could provide the information.
You can also share the "forum" or the "shop" (and so on).

The big disadvantages:
-) Performance. (Currently, our ez db has the size of 300 MB. Before we used ez 3, the ez 2 installations only need around 40 MB all in all.) If you save content, you need patience. If the cache is empty, too. At the moment you need a very strong server if you plan to use ez3 for "big sites". (Big = many users (over 10.000 users) and much content (over 30.000 articles / content objects))

-) ez 3 don't support "multi sites / domains in one db" fully. So, it's impossible to assign content to one domain without doing some extra programming. Example: If you do a search at site A and the search result contains content of site B, it's hard to get the "domain B" in the link of the result and the information, that the content is from site B. Same thing with "related content objects" / keyword feature.

Moreover, the cron-jobs don't support "multi-sites in one db" at the moment.
Example: Notification system: If new content is published at site A, I want to send the the notification e-mail with header and footer of site A. If content is published at site B, the header / footer of site B should be provided.

Another small flaw:
Content of site A is also "reachable" at site B. Or in another words:
http://www.site-a.com/content/view/full/123 and
http://www.site-b.com/content/view/full/123
shows the same content.

You can't prevent this without doing some extra programming.

This isn't a problem, if a user don't know this. But - maybe - there could happen some "law problems".

Example: The content object (article / forum post etc.) with the id 123 contains something which disturbs somebody. And Mr. Somebody is able to sue all domain owners if he knows that the content object is reachable at each domain which uses the same db.

Why Mr. Somebody should know about the other domains? Because he uses a popular search engine like google.

There are many other (small) things to mention and I am sure there are many pro's and con's at all.

My conclusion is: Only use "multiple sites in one db" if you are able to adjust ez3 at a "deeper level" and if all "site / domain owners" have the knowledge of all possible advantages and disadvantages. (Otherwise you can run into some big troubles. And always remember Mister Murphy's law! ;-)

Kind regards,
Emil.

Best wishes,
Georg.

--
http://www.schicksal.com Horoskop website which uses eZ Publish since 2004

Lazaro Ferreira

Wednesday 11 February 2004 6:55:32 am

Hi Emil,

Very Interesting your experience with multiples sites sharing one database

As I understand of your recomendation (it is our advice to), this is probably a last resource solution

Currently we face a similar problem regarding user account sharing, our preference here is for LDAP server to manage user accounts across multiple sites

Regarding the search engine, probably a better approach is using an external search engine capable of indexing pages from all of the ezp3 sites involved

I don't be sure if ezpublish 3 external search engine plugin feature is suitable for searching multiples EZP3 databases at the same time

Lazaro
http://www.mzbusiness.com

Lauren Matheson

Tuesday 24 February 2004 9:42:09 pm

An advantage to eZ's internal search is that results shown depend on the user's permissions. An external search index would not work well on a site with varied levels of access.

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 20:51:27
Script start
Timing: Jan 18 2025 20:51:27
Module start 'layout'
Timing: Jan 18 2025 20:51:27
Module start 'content'
Timing: Jan 18 2025 20:51:28
Module end 'content'
Timing: Jan 18 2025 20:51:28
Script end

Main resources:

Total runtime1.1938 sec
Peak memory usage4,096.0000 KB
Database Queries85

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0051 588.1641152.6563
Module start 'layout' 0.00510.0029 740.820339.5078
Module start 'content' 0.00801.1841 780.3281825.7656
Module end 'content' 1.19210.0017 1,606.093824.1094
Script end 1.1938  1,630.2031 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00340.2852160.0002
Check MTime0.00140.1169160.0001
Mysql Total
Database connection0.00070.059510.0007
Mysqli_queries1.088691.1823850.0128
Looping result0.00100.0853830.0000
Template Total1.160697.220.5803
Template load0.00220.184220.0011
Template processing1.158497.033320.5792
Template load and register function0.00010.008210.0001
states
state_id_array0.00080.066410.0008
state_identifier_array0.00130.105320.0006
Override
Cache load0.00200.1650780.0000
Sytem overhead
Fetch class attribute can translate value0.00080.064070.0001
Fetch class attribute name0.00130.1090140.0001
XML
Image XML parsing0.00350.293970.0005
class_abstraction
Instantiating content class attribute0.00000.0020150.0000
General
dbfile0.00150.1253400.0000
String conversion0.00000.000740.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
6content/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
19content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
10content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
1print_pagelayout.tpl<No override>extension/community/design/community/templates/print_pagelayout.tplEdit templateOverride template
 Number of times templates used: 46
 Number of unique templates used: 6

Time used to render debug report: 0.0001 secs