Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to configure mod_pagespeed for SSL pages

We have website e.g. http://www.acb.com which points to a hardware load-balancer which is suppose to load-balance two dedicated server. Each server is running apache as a frontend and uses mod_proxy to forward request to tomcat.

Some pages of our website require SSL like https://www.abc.com/login or https://www.abc.com/checkout

SSL is terminated at hardware load-balancer.

When I configured mod_pagespeed it compressed, minimized and merged css file and rewrote them with an absolute url http://www.abc.com/css/merged.pagespeedxxx.css instead of relative url /css/merged.pagespeedxxx.css.

It works fine for non ssl pages but when I navigate to an ssl page such as https://www.abc.com/login all the css and js files are blocked by browser like chrome as their absolute url is not using ssl.

How can I resolve this issue ?

like image 543
Hussain Fakhruddin Avatar asked Jan 17 '13 05:01

Hussain Fakhruddin


2 Answers

Check for https string in this documentation and this one.

You should show us in your question your current ModPagespeedMapOriginDomain && ModPagespeedDomain settings.

From what I understand from these lines:

The origin_specified_in_html can specify https but the origin_to_fetch_from can only specify http, e.g.

ModPagespeedMapOriginDomain http://localhost https://www.example.com

This directive lets the server accept https requests for www.example.com without requiring a SSL certificate to fetch resources - in fact, this is the only way mod_pagespeed can service https requests as currently it cannot use https to fetch resources. For example, given the above mapping, and assuming Apache is configured for https support, mod_pagespeed will fetch and optimize resources accessed using https://www.example.com, fetching the resources from http://localhost, which can be the same Apache process or a different server process.

And these ones:

mod_pagespeed offers limited support for sites that serve content through https. There are two mechanisms through which mod_pagespeed can be configured to serve https requests:

  • Use ModPagespeedMapOriginDomain to map the https domain to an http domain.
  • Use ModPagespeedLoadFromFile to map a locally available directory to the https domain.

The solution would be something like that (or the one with ModPagespeedLoadFromFile)

ModPagespeedMapOriginDomain http://localhost https://www.example.com

BUT, the real problem for you is that apache does not directly receive the HTTPS requests as the hardware load balancer handle it on his own. So the mod-pagespeed output filter does not even know it was requested for an SSL domain. And when it modify the HTML content, applying domain rewrite maybe, it cannot handle the https case.

So... one solution (untested) would be using another virtualhost on the apache server, still HTTP if you want, dedicated to https handling. All https related urls (/login,/checkout,...) would then be redirected to this specific domain name by the hardware load balancer. Let's say http://secure.acb.com. This name is only in use between the load balancer and front apaches (and quite certainly apache should restrict access to this VH to the load balancer only).

Then in these http://secure.acb.com virtualhosts mod_pagespeed would be configured to externally rewrite domains to https://www.example.com. Something like:

ModPagespeedMapOriginDomain http://secure.example.com https://www.example.com

Finally the end user request is https://www.example.com/login, the load balancer manages HTTPS, talk to apache with http://secure.example.com, and page results contains only references to https://www.example.com/* assets. Now when theses assets are requested with an https domain request you still have the problem of serving theses assets. So the hardware load balancer should allow all theses assets url in the https domain and send them to the http://secure.abc.com virtualhosts (or any other static VH).

like image 87
regilero Avatar answered Oct 03 '22 19:10

regilero


This sounds like you configured the rewritten URL as http://www.abc.com/css/merged.pagespeedxxx.css yourself - therefor: Try to use a protocol-relative URL, e.g. remove http: and just state //www.abc.com/css/merged.pagespeedxxx.css - this will use the same protocol as the embedding page was requested in.

One of the well standardized but relatively unknown features of URLs

like image 44
Olaf Kock Avatar answered Oct 03 '22 19:10

Olaf Kock