Setting up a Content Delivery Network (CDN)¶
Deploying with KeyCDN¶
This document will guide you through the setup of a KeyCDN account with your Flectra powered website.
Step 1: Create a pull zone in the KeyCDN dashboard¶
data:image/s3,"s3://crabby-images/a4572/a45721cf73bf9b68182d425ff7e855216fc51004" alt="../../_images/keycdn_create_a_pull_zone.png"
When creating the zone, enable the CORS option in the advanced features submenu. (more on that later)
data:image/s3,"s3://crabby-images/01824/01824f853b7d4ce4c570f4ad8ebe7734ae9e28eb" alt="../../_images/keycdn_enable_CORS.png"
Once done, you’ll have to wait a bit while KeyCDN is crawling your website.
data:image/s3,"s3://crabby-images/74e5d/74e5d4d5c2ed0162f4376eb9fa09a062d9e8d89e" alt="../../_images/keycdn_progressbar.png"
Note
a new URL has been generated for your Zone, in this case it is
http://pulltest-b49.kxcdn.com
Step 2: Configure the flectra instance with your zone¶
In the Flectra back end, go to the Website Settings: menu, then activate the CDN support and copy/paste your zone URL in the CDN Base URL field. This field is only visible and configurable if you have developer mode activated.
data:image/s3,"s3://crabby-images/20114/20114eeacfc4725779c903a36703fdcf215b5990" alt="../../_images/odoo_cdn_base_url.png"
Now your website is using the CDN for the resources matching the CDN filters regular expressions.
You can have a look to the HTML of your website in order to check if the CDN integration is properly working.
data:image/s3,"s3://crabby-images/1b4e0/1b4e0119c729d4baf424864beeb669d4911ea23e" alt="../../_images/odoo_check_your_html.png"
Why should I activate CORS?¶
A security restriction in some browsers (Firefox and Chrome at time of writing) prevents a remotely linked CSS file to fetch relative resources on this same external server.
If you don’t activate the CORS option in the CDN zone, the more obvious resulting problem on a default Flectra website will be the lack of font-awesome icons because the font file declared in the font-awesome CSS won’t be loaded on the remote server.
Here’s what you would see on your homepage in such a case:
data:image/s3,"s3://crabby-images/e2088/e20885ceab1b85d1155b0112ba094f59ef4ddb58" alt="../../_images/odoo_font_file_not_loaded.png"
A security error message will also appear in the browser’s console:
data:image/s3,"s3://crabby-images/348fb/348fb3fa4d7ae64509ae7be1c5c958193b49c076" alt="../../_images/odoo_security_message.png"
Enabling the CORS option in the CDN fixes this issue.