Forums / Setup & design / One subdomain per each user blog?

One subdomain per each user blog?

Author Message

Carlos Revillo

Saturday 25 October 2008 7:38:09 am

Hi.

We're working in a community site. Registered users can create a blog by themselves.
When the blog is created, blog can be reached at http://www.domain.com/Blogs/username.

But customer wants these blogs can be reached at http://username.domain.com.

I don't really know if this can be suitable with eZ.

I'm working with hostmatchtype=map for this site, so solution here could be like this...

- there's an extension to create blogs.
- when a user creates another one, we need to created a new siteaccess for this blog (?)
in this new siteaccess we will need to setup db connection and also root node for it (pointing to the new blog node created at the content tree...)
we will also need to add lines to HostMatchMapItems setting. Something like
HostMatchMapItems[]=user1;user1

but now my doubts.
i don't think the best option is modifying settings/override file... i'm afraid that something could fail and maybe settings/override could became empty or something. we'll get the ez installation process then...

i don't think that having a siteacces per user could be the best option. suppose we have 10.000 users and a blog per each... we will have 10.000 siteaccess... that could be crazy...

Do you have any other ideas here?
Thank you

Andrew Duck

Saturday 25 October 2008 11:18:28 am

Hi Carlos,

It depends whether each new blog receives it's own database, or whether you are happy to house all content objects within your instance and use roles and privileges to lock down what they can edit.

If everyone needs separate databases, then custom siteaccesses is the only way forward. In which case check out HostMatchType, you can do element, text and regular expression matching to prevent making changes to override.ini. It's probably safer to match than having some automated process editing your override file.

If you don't need separate databases, then you could do some server side redirection using apache rewrite rules to map subdomains to the appropriate path. The rest can then be taken care of with roles and policies.

Regards,
Andrew.

Andrew Duck, Executive Director, Quiqcorp Limited
eZ Certified Developer and Trainer.
Member of the Community Project Board
http://quiqcorp.com | http://twitter.com/andrewduck

Carlos Revillo

Saturday 25 October 2008 12:07:21 pm

Thank you Andrew.

i don't need separate databases for the blogs. I've tried some rewrite rules... d
if i do something like

RewriteCond %{HTTP_HOST} ^(www\.)?username\.domain\.com
RewriteRule .* /Blogs/username [L] 

it works perfectly, but if the user types in browser http://username.domain.com he will be redirected to http://www.domain.com/Blogs/username. You will get this in browser. customer doesn't want that the url changes. he always wants to see username.domain.com/blablalb in browser.

If i do the "reverse way", like

redirectMatch 301 ^/Blogs/username(.+)$ http://username.domain.com

then, when visitor goes to a blog user he will be redirected to http://userdomain.domain.com as expected, but i need to add a hostMatchItem line to map default page of this userdomain.com to a node. and also i will need to create a siteaccess for this domain...

am i missing something here?
thanks again.

Andrew Duck

Saturday 25 October 2008 12:55:37 pm

Hi Carlos,

You should be able to get it working with mod_rewrite, provided you only use relative urls for the blog templates. Absolute urls generated inside templates would not be aware of your mod_rewrite implementation.

Another alternative, and perhaps more solid would be to look at the mod_proxy implementation in Apache.

Andrew Duck, Executive Director, Quiqcorp Limited
eZ Certified Developer and Trainer.
Member of the Community Project Board
http://quiqcorp.com | http://twitter.com/andrewduck

Carlos Revillo

Saturday 25 October 2008 1:17:08 pm

thanks Andrew.

i'm not really an expert with apache. i think i would try with mod_rewrite... but i don't completely understand you with "provided you only use relative urls for the blog templates. "...
could you please clarify me this?
thanks for your time.

Andrew Duck

Saturday 25 October 2008 11:54:38 pm

Absolute urls will include the domain name in the href tag, which would introduce complexity as it would likely point to mydomain.com rather than username.mydomain.com, which pushes you back to the wrong style of URL.

I haven't had chance to sit down and try it out, but I imagine you could:

Catch incoming request for "username.mydomain.com", rewrite it is mydomain.com/Blogs/username, without a redirect. This should preserve the original requested URL "username.mydomain.com" in the browser address bar.

The issue you run into now is that you have to catch the links to blog posts, and ensure they are properly handled. If they are in the format "mydomain.com/Blogs/username/my-post" then you need to rewrite your templates. You have two options.

1. You could try and use the template language to evaluate the HTTP_HOST and provide the appropriate domain in an absolute URL, OR

2. You could use relative urls, ie "/Blogs/username/my-post" (preferred I think)

At that point when you click on a link it should request "username.mydomain.com/Blogs/username/my-post" which you can catch with your rewrite rule.

One thing you likely cannot do with the above system, is force a redirect on an incoming request for "mydomain.com/Blogs/username" and redirect it to "username.mydomain.com" or you will end up in an endless loop of redirects with a nice 500 error from Apache.

You will have to live with the fact that mydomain.com/Blogs/username/my-post is accessible, it has to be to handle requests for your rewrite rule anyway, but your subdomains should work for the blog and deeper links.

Andrew Duck, Executive Director, Quiqcorp Limited
eZ Certified Developer and Trainer.
Member of the Community Project Board
http://quiqcorp.com | http://twitter.com/andrewduck

Carlos Revillo

Sunday 26 October 2008 3:31:04 am

Andrew, thanks a lot for your wonderful explanation.

I'm not really an expert in apache, so i'm going to do some searching for getting redirects from username.domain to domain/Blogs/username preserving the url.

If we have to live with also urls like /Blogs/username we'll do like this. anyway, i'll need to talk with our seo people because maybe we'll get duplicate content for Google, and it seems Google doesn't like this...

But this is other part.

If customer doesn't want like this, i'll tell about the dander of writing the settings/override/site.ini.append.php from a php file...

thank you again.

Andrew Duck

Sunday 26 October 2008 3:55:29 am

Duplicate content could be an unwanted side effect, not sure how subdomains play into that space.

I wouldn't advise automatically writing to your override/site.ini.append.php, but with HostMatchType it isn't necessary. Use text, element or regular expression matching instead of map.

It still leaves you with potentially 10,000 siteaccesses, but you don't have 10,000 entries in override/site.ini.append.php which is nice.

If you head down that path, you can of course work with IndexPage to set relative content tree roots for your blog siteaccesses which is a nicer way to work, but I haven't tested out the performance of element of regular expression matching against 10,000 siteaccesses and a large number of concurrent users. It is definitely something I would encourage you simulate before pushing too far into development to ensure you don't hit scalability or performance issues.

Andrew Duck, Executive Director, Quiqcorp Limited
eZ Certified Developer and Trainer.
Member of the Community Project Board
http://quiqcorp.com | http://twitter.com/andrewduck

eZ debug

Timing: Jan 19 2025 06:14:15
Script start
Timing: Jan 19 2025 06:14:15
Module start 'content'
Timing: Jan 19 2025 06:14:16
Module end 'content'
Timing: Jan 19 2025 06:14:16
Script end

Main resources:

Total runtime0.8791 sec
Peak memory usage4,096.0000 KB
Database Queries209

Timing points:

CheckpointStart (sec)Duration (sec)Memory at start (KB)Memory used (KB)
Script start 0.00000.0059 588.9766180.8281
Module start 'content' 0.00590.7532 769.8047623.7656
Module end 'content' 0.75910.1199 1,393.5703345.0859
Script end 0.8790  1,738.6563 

Time accumulators:

 Accumulator Duration (sec) Duration (%) Count Average (sec)
Ini load
Load cache0.00390.4382210.0002
Check MTime0.00140.1614210.0001
Mysql Total
Database connection0.00070.083510.0007
Mysqli_queries0.791089.98182090.0038
Looping result0.00210.23382070.0000
Template Total0.846596.320.4232
Template load0.00210.234020.0010
Template processing0.844496.049320.4222
Template load and register function0.00020.026810.0002
states
state_id_array0.00210.241710.0021
state_identifier_array0.00140.156220.0007
Override
Cache load0.00190.2121720.0000
Sytem overhead
Fetch class attribute can translate value0.00150.167830.0005
Fetch class attribute name0.00110.120190.0001
XML
Image XML parsing0.00290.333630.0010
class_abstraction
Instantiating content class attribute0.00000.0033120.0000
General
dbfile0.00710.8033290.0002
String conversion0.00000.000730.0000
Note: percentages do not add up to 100% because some accumulators overlap

CSS/JS files loaded with "ezjscPacker" during request:

CacheTypePacklevelSourceFiles
CSS0extension/community/design/community/stylesheets/ext/jquery.autocomplete.css
extension/community_design/design/suncana/stylesheets/scrollbars.css
extension/community_design/design/suncana/stylesheets/tabs.css
extension/community_design/design/suncana/stylesheets/roadmap.css
extension/community_design/design/suncana/stylesheets/content.css
extension/community_design/design/suncana/stylesheets/star-rating.css
extension/community_design/design/suncana/stylesheets/syntax_and_custom_tags.css
extension/community_design/design/suncana/stylesheets/buttons.css
extension/community_design/design/suncana/stylesheets/tweetbox.css
extension/community_design/design/suncana/stylesheets/jquery.fancybox-1.3.4.css
extension/bcsmoothgallery/design/standard/stylesheets/magnific-popup.css
extension/sevenx/design/simple/stylesheets/star_rating.css
extension/sevenx/design/simple/stylesheets/libs/fontawesome/css/all.min.css
extension/sevenx/design/simple/stylesheets/main.v02.css
extension/sevenx/design/simple/stylesheets/main.v02.res.css
JS0extension/ezjscore/design/standard/lib/yui/3.17.2/build/yui/yui-min.js
extension/ezjscore/design/standard/javascript/jquery-3.7.0.min.js
extension/community_design/design/suncana/javascript/jquery.ui.core.min.js
extension/community_design/design/suncana/javascript/jquery.ui.widget.min.js
extension/community_design/design/suncana/javascript/jquery.easing.1.3.js
extension/community_design/design/suncana/javascript/jquery.ui.tabs.js
extension/community_design/design/suncana/javascript/jquery.hoverIntent.min.js
extension/community_design/design/suncana/javascript/jquery.popmenu.js
extension/community_design/design/suncana/javascript/jScrollPane.js
extension/community_design/design/suncana/javascript/jquery.mousewheel.js
extension/community_design/design/suncana/javascript/jquery.cycle.all.js
extension/sevenx/design/simple/javascript/jquery.scrollTo.js
extension/community_design/design/suncana/javascript/jquery.cookie.js
extension/community_design/design/suncana/javascript/ezstarrating_jquery.js
extension/community_design/design/suncana/javascript/jquery.initboxes.js
extension/community_design/design/suncana/javascript/app.js
extension/community_design/design/suncana/javascript/twitterwidget.js
extension/community_design/design/suncana/javascript/community.js
extension/community_design/design/suncana/javascript/roadmap.js
extension/community_design/design/suncana/javascript/ez.js
extension/community_design/design/suncana/javascript/ezshareevents.js
extension/sevenx/design/simple/javascript/main.js

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
8content/datatype/view/ezxmltext.tpl<No override>extension/community_design/design/suncana/templates/content/datatype/view/ezxmltext.tplEdit templateOverride template
18content/datatype/view/ezxmltags/paragraph.tpl<No override>extension/ezwebin/design/ezwebin/templates/content/datatype/view/ezxmltags/paragraph.tplEdit templateOverride template
8content/datatype/view/ezxmltags/line.tpl<No override>design/standard/templates/content/datatype/view/ezxmltags/line.tplEdit templateOverride template
4content/datatype/view/ezimage.tpl<No override>extension/sevenx/design/simple/templates/content/datatype/view/ezimage.tplEdit templateOverride template
2content/datatype/view/ezxmltags/literal.tpl<No override>extension/community/design/standard/templates/content/datatype/view/ezxmltags/literal.tplEdit templateOverride template
1pagelayout.tpl<No override>extension/sevenx/design/simple/templates/pagelayout.tplEdit templateOverride template
 Number of times templates used: 42
 Number of unique templates used: 7

Time used to render debug report: 0.0002 secs