This page aims at sharing some best practices regarding our Akeneo connector for SalesForce Commerce Cloud implementation and some basic guidelines to keep in mind.
What you need to know?
First of all, Akeneo Connector is a bridge between Akeneo PIM (in its core version) and Salesforce Commerce Cloud (in its core version). Why is it important to notice? Because our Akeneo Connector is an agnostic connector that is independent of customer's specificities. Our goal is to provide a solid technical basis to plug Akeneo PIM into a Salesforce Commerce Cloud (SFCC) instance. If some particularities are required, this is not a problem; ask your IT referral (integrator or IT team) to customize the connector.
Another important notion here is to consider that Akeneo Connectors are 3rd-party plug-ins and therefore, we are fully impacted by the SalesForce system limitations. Basically, SF is made to manage a massive volume of data, but with as little data transformation as possible. The very first rule you need to keep in mind is "Think agnostic" (if you have to choose between many data model in the PIM, prefer a native SFCC approach). This means that, if in SFCC a piece of data is managed as an integer, please highly prefer creating an integer field in your Akeneo PIM rather than considering the connector will take care of it (the connector will do the job, but the performance will decrease).
Talking about performance
We are often asked about the metrics and performance of Akeneo Connectors. Unfortunately, this is not that easy. In general, please note that four main criteria impact the performance of the connector:
- The catalog volume: even if that's the first one that comes to mind it is not the only one to consider.
- The catalog complexity: indeed, importing 500 000 products can be an easy task if the product is described by "just" a name, a description, and an image. However, if the product is very complex (high number of attributes, many reference entities, plenty of variations, etc.), importing 2 000 products can be a very painful and long process.
- The SalesForce limitations: in addition to what we already said in the introduction, and to preserve its performances, SalesForce limits some uses.
- The Media/Assets management: Asset binaries are often cumbersome to synchronize to transfer from Akeneo PIM to SFCC. Imagine the time it takes to transfer and copy 80Go of assets through the connector to SFCC.
So what can I do to preserve my connector's performances?
- Always prefer direct data mapping between Akeneo PIM and SFCC, this way you don't need to rely on SF to convert the PIM data into the required format. By doing so, you will help your system to be more efficient.
- One of the most impactful use is the Asset Binaries use. So if it is possible for you to consider using a DAM and the Asset Manager (media link & file link) instead of Image binaries directly uploaded in the PIM, you will save a lot of time. Prefer saving a string of characters (URL) versus an actual HD picture.
- Challenge the amount of data you will copy over to Salesforce. You might have attributes on Akeneo PIM that are not needed for your storefront. Filtering them out of synchronization can help you save some time during imports.
Full import or partial import?
There are two ways to import product data:
- Full import: this is the longest import process because everything, including media, will be synchronized between Akeneo PIM and SFCC. However, this full import happens once for the very first synchronization used to build your catalog on SFCC side. Then, most of the time, full import jobs are scheduled and automatically executed to resynchronize all data when needed (every night, every 2 days...depending on your process, the full import frequency can change). The four performance criteria, listed above, highly impact this import process, and this is why this process is often an automated task. To illustrate the catalog volume vs. complexity, please consider those figures:
|Industries||Product Amount||Average full import time|
|Clothing - Streetwear||250 000||6 hours|
|Luxury (way more complex)||80 000||8 hours|
Please consider those figures as indications and not as exact references
- Differential import: Depending on the last successful import date, the system can sync only new products when it's necessary. However, to reconstruct some data on the SFCC side, some tasks have to be run as a full import anyway (e.g., categories are fully imported even in a differential import). However, this differential import process will allow you to decrease the needed import time. This type of import is used daily to resync data that has changed in the days. This one is often a manual operation.
You will have to define your data update policy to adjust the threshold between full import and differential import.
What are the best practices to customize Akeneo Connector?
As part of our SFCC online training, here are the tech guidelines to help you create a customization on top of the Akeneo Core version of the cartridge:
if you are using a 21.0.0 or a higher version of the cartridge, use bm_akeneo_custom and bm_akeneo instead of bc_akeneo.
- As a standard practice in SFCC cartridge development, do not edit Akeneo Connector for SFCC directly. Create another cartridge (bc_akeneo_custom) and place it on the cartridge path before bc_akeneo. Customized files will be copied here. It will be helpful when newer versions of Akeneo Connector for SFCC are released.
- The right approach is to generate a sample catalog with Akeneo Connector for the SFCC core version and then to download the XMLs from the Impex location. After that, compare the customized version and check that it does not introduce any unexpected changes in the generated XMLs by comparing the two sets.
How to ensure the success of my integration?
This is pretty easy: you should test the Connector as early as possible in the integration process. By doing so, you will challenge the data model and ensure the efficiency of the mapping.
Please note that evaluating the core connector version to know if it fits your needs belongs to your technical team or your integrator. This is why the earlier you start testing, the earlier you are confident in the connector compatibility and its adoption.
You should ask yourself:
- Are Akeneo PIM and/or the eCommerce platform customized in any way? If they are, that should raise a warning.
- Are all the project actors aware of their responsibilities?, if there are any doubts, make sure everyone attends the Akeneo Akademy Training.
- Does the system integrator (or the IT team in charge of the integration) know that:
- the Akeneo Connector can evolve and, when it happens, they will have to update their Connector accordingly (with or without customizations)?
- if there is a customization, the related support (level 1 to 3) and maintenance fall with the team that has developed this customization.
- The bigger the catalog, the sooner the Connector has to be tested, especially in terms of performance and synchro data policy definition.
- The more complex the catalog, the sooner the connector mapping has to be considered. Waiting until the end of the project would take a lot more time which might lead to delaying the go-live date and create frustration.
- Be brave, don't worry about trying out new things. Benefit from this opportunity to challenge your existing data model and to get rid of all the complexity inherited from a legacy solution. Our advice here is that this is better to modify an existing data model slightly on the eCommerce side to be able to efficiently map and smoothly import your data rather than recreating a legacy complexity in the PIM.
- An Akeneo Connector will do what it is created for: to plug any standard PIM into a standard version of Salesforce, by maintaining the highest performance and scalability for all its users. If Akeneo Connectors tests are not up to your performance standards, then there are two options for you:
- Not using the Akeneo Connector at all and creating yours from scratch (and we are totally fine with that)
- Creating customizations to enhance performances according to your performance standard.