Google Tag Manager Server-Side Tagging: Tutorial
Updated: Tuesday, February 4, 2025
The aim of this article is to give you all the keys you need to determine whether implementing a GTM server-side solution is right for your business, and also the steps you need to take to implement it.
Before going any further, you might be interested in a more specific guide:
- Google Ads Server-Side Tracking with Google Tag Manager
- Matomo Server-Side Tracking with Google Tag Manager
What is Google Tag Manager Client-Side?
In its client-side version, Google Tag Manager collects data on your website and sends this data to marketing platforms such as Google Analytics, Google Ads or Facebook Ads via the browser.
flowchart LR
subgraph Browser
A[Your website]
subgraph I[Google Tag Manager]
F(GA4 tracking code)
G(Google Ads tracking code)
H(Facebook Pixel)
end
end
C[Google Analytics 4 server]
D[Facebook Ads server]
E[Google Ads server]
A --> I
Browser -- google-analytics.com/collect --> C
Browser -- www.facebook.com/tr --> D
Browser -- googleadsservices.com/pagead/conversion/ --> E
The browser then sends requests directly to the marketing platforms you work with. Thanks to tracking codes, these platforms can deposit first-party or third-party cookies in the browser to identify the same visitor across multiple visits and/or link a visitor to a click on an ad.
Advantages of GTM Client-Side
- relatively simple to set up (the biggest complexity lies in manipulating the Data Layer)
- the community has developed numerous tag and variable templates to make your life easier
- there are many tutorials on the Internet to help you
- it’s what’s been done for a long time, so it’s easier to find these skills on the market (whether you’re recruiting or outsourcing)
- Google Tag Manager Client-Side is completely free
Drawbacks of GTM Client-Side
- cookies deposited via JavaScript are subject to restrictions in most browsers
- tends to increase page load times, as you need to add one tracking code per marketing platform
- you have very little control over the data you send to marketing platforms (data collected automatically)
- requests sent to marketing platforms may be blocked by ad blockers
What is Google Tag Manager Server-Side?
Instead of sending requests to each server of the marketing platforms you use, you’ll only send requests to your own server. Your server will then communicate with the marketing platforms.
flowchart TD
subgraph Browser
A[Your website]
subgraph I[GTM Client-Side]
F(GA4 tracking code)
end
end
subgraph J[Your server - Hosted on GCP or Addingwell or Stape]
subgraph K[GTM Server-Side]
R[GA4 Client]
L[Google Ads tag]
M[Facebook Ads tag]
N[Google Analytics tag]
end
end
R --> L
R --> M
R --> N
Browser <-- HTTP --> J
L -- googleadsservices.com --> O[Google Ads API]
M -- graph.facebook.com --> P[Facebook Ads API]
N -- google-analytics.com --> Q[Google Analytics API]
Advantages of GTM Server-Side
- reduces your website loading time (especially if you need to send data to a lot of marketing platforms)
- gives you total control over what data is sent to marketing platforms, as your server acts as an intermediary (dictating what data gets through and what doesn’t)
- you’re less prone to ad blockers (with specific configuration), as GTM and GA4 javascript libraries in particular can be downloaded from your server with unique paths.
- cookies deposited by the server will be less subject to browser restrictions and will have a longer lifespan.
Drawbacks of GTM Server-Side
- cloud hosting of your server has a cost and is complex to maintain (facilitated by Addingwell or Stape)
- requires more skills to set up (mastering GTM Client-Side is not enough to be operational with GTM Server-Side)
Client-Side VS Server-Side skills
mindmap
root[Client-Side <br>vs Server-Side skills]
[Client-Side]
(Javascript)
(Variables)
(Functions)
(JSON)
(Cookies)
(CSS selectors)
(HTML DOM)
[Server-Side]
(HTTP)
(Requests and responses)
(Cookies)
(JSON)
(Logging)
(Cloud)
(DNS)
(Load balancing)
(Monitoring <br>of resources)
Delegate cloud management
It may seem paradoxical, but the main benefits that come with GTM Server-Side (bypassing ad-blockers, extending cookie lifetime) are not natively available when you go through Google Cloud Platform (GCP).
=> To take full advantage of GTM Server-Side, I strongly advise you to delegate your cloud management.
To this end, I’m going to present 2 solutions (Addingwell and Stape) that manage the entire infrastructure/cloud of the server-side implementation from A to Z. This will enable you to choose the solution best suited to your needs.
Before getting started, here’s a table comparing the 2 solutions.
Addingwell | Stape | ||
---|---|---|---|
From | 90 euros/month | 20 euros/month | |
Requests on lowest plan | 2,000,000 | 500,000 | |
Free requests | 100,000 | 10,000 | |
Support | Yes, premium (meeting with sGTM specialists) and unlimited | 1 hour of call time per month only with the Enterprise plan | |
Account Manager | Yes with Enterprise Plan | Yes with Enterprise Plan |
Set up Addingwell
Addingwell: Best Tagging Server for GTM server-side.
Try for free no credit card required
Container creation
Once you’ve created your Addingwell account, you’ll be asked to create a container. This container will host GTM Server-Side.
data:image/s3,"s3://crabby-images/58b6d/58b6d0fb2b614a3dfaeaa886a8f2e0565164cbf5" alt="Creating a container on Addingwell"
The next screen asks for a Container Config, which we’ll find in the next step in GTM Server-Side.
data:image/s3,"s3://crabby-images/8932b/8932be06bdfbdb8d521c404bc856b0ef1b4e5908" alt="Container Config screen on Addingwell"
Creating a GTM Server-Side container
Go to tagmanager.google.com, then on the account of your choice create a Server container.
data:image/s3,"s3://crabby-images/d5b75/d5b75866f5a8d64ced6e482e395d5b3c5df6b85f" alt="Creating a new container in GTM Server-Side"
Select Server as Target Platform.
data:image/s3,"s3://crabby-images/108dc/108dcc3e319120572c3c390fb776e81f47c62cc2" alt="Choosing Server as target platform"
Then click Create to create your server container. You will then come to a popup where you must select the Maunally provision tagging server option. As soon as this option is selected, the Container Config appears.
data:image/s3,"s3://crabby-images/43edf/43edff7f4a13e32663f8f0c9574162f5bf3cd334" alt="Manual provisioning of server to get Container Config"
Copy the Container Config and paste it into the Addingwell interface. Then click Next.
data:image/s3,"s3://crabby-images/bbb74/bbb747b8dcffb52727ac5852b25ac444c9eb00e4" alt="Adding the Container Config in Addingwell"
Congratulations, at this stage you’ve made the link between the Addingwell infrastructure and your server container on Google Tag Manager.
Creating the custom domain
In this section, we’ll link a sub-domain of your main domain to your Addingwell container. Since my main domain is data-marketing-school.com
, the sub-domain I’ll choose is aw
. The access URL to my tagging server will therefore be https://aw.data-marketing-school.com
.
aw
as my subdomain for the purposes of this tutorial, but I'd advise you to choose a neutral subdomain like srv
or server
for example.Fill in this information in Addgingwell then click Next.
data:image/s3,"s3://crabby-images/ecebf/ecebfe68ad8437827f9d3b4fd370163232c86024" alt="Adding the subdomain in Addingwell"
The Addingwell container is now waiting for DNS configuration.
data:image/s3,"s3://crabby-images/72ff0/72ff0791f7f367e334a167805df0bf571282d467" alt="Waiting for DNS configuration in Addingwell"
DNS configuration
As specified on the Addingwell interface, here are the two DNS records I need to configure:
Record Type | Host | Value |
---|---|---|
A | aw.data-marketing-school.com | 34.36.186.178 |
AAAA | aw.data-marketing-school.com | 2600:1901:0:eb70:: |
The configuration of these records must be done on your DNS host. As far as I’m concerned, my website’s DNS records are managed on Cloudflare.
data:image/s3,"s3://crabby-images/1c95d/1c95d35ddbb30b06f6f850485bf8a0689bcd1bca" alt="A record in cloudflare pointing to Addingwell"
data:image/s3,"s3://crabby-images/beb0c/beb0c953b3d5a723fb8ee92f82f8245bf1e6e20e" alt="AAAA record in cloudflare pointing to Addingwell"
Congratulations, your custom domain is now configured.
Finalizing Addingwell configuration
On the Addingwell side, the server is now being provisioned.
data:image/s3,"s3://crabby-images/a482b/a482b27bef9e02664ce7cbd99f11a00558f80982" alt="Addingwell server provisioning in progress"
A few minutes later, your server is ready to use.
data:image/s3,"s3://crabby-images/fafd2/fafd2712b15d088da7b765c889380c7ed84ed7e0" alt="Addingwell server ready for use"
All that’s left is to specify your server URL in GTM Server-Side in Admin > Container Settings.
data:image/s3,"s3://crabby-images/33dde/33ddeaaea59d236c35dcc5c5b6c8036ee1ef5d08" alt="Configuring the server URL in GTM Server Side"
Congratulations, you’ve finished configuring your server with Addingwell, you can now open the preview on GTM Server Side and start sending requests to your server.
data:image/s3,"s3://crabby-images/1adf1/1adf1b2575766e49aa2925d756af2d0cb3943b57" alt="Functional GTM Server Side preview"
Set up Stape
Stape: Server-Side Tagging Made Easy For Everyone.
Join 100 000+ happy customers
Container creation
Once your account is created, go to your Dashboard and click on Create sGTM container.
data:image/s3,"s3://crabby-images/21b8d/21b8d78ec859014e76a0788ba61a9935dd4fba2e" alt="Button to create a container in Stape"
Next, give your container a name and specify the location of the servers. At this stage you can leave the Container Config field empty, as we’ll fill it in later.
data:image/s3,"s3://crabby-images/2b1ac/2b1ace4b4b09649e6cc807e648c5ccc0b2fa08c9" alt="Creating the Stape container"
Stape will then offer you their prices, so you can start with the free plan.
Creating the GTM Server-Side container
Go to tagmanager.google.com, then on the account of your choice create a Server container.
data:image/s3,"s3://crabby-images/6b805/6b80512f7324b7b594ce924880b3a96deeafbda4" alt="Button to create a new container in GTM"
Select Server as Target Platform.
data:image/s3,"s3://crabby-images/91b3a/91b3a5b58316f22a83a224b73c3f887f93c14a02" alt="Choosing Server as target platform"
Then click Create to create your server container. You will then come to a popup where you must select the Maunally provision tagging server option. As soon as this option is selected, the Container Config appears.
data:image/s3,"s3://crabby-images/28001/280014a4ddf406ea1c853ecef8d9ec69f7f49542" alt="Manual provisioning of server to get Container Config"
Copy the Container Config and return to the Stape interface. In the Container settings section, click on Edit.
data:image/s3,"s3://crabby-images/d341c/d341c1a56e7a181c9c0c60ac80a529c0190a1b9f" alt="Container settings section in Stape"
Fill in the Container Config then click Save.
data:image/s3,"s3://crabby-images/32dd3/32dd31da824763a6417835b8fdb0aaae395e409f" alt="Adding the Container Config in Stape"
Congratulations, after a few minutes your Stape container is now in Running state. We can now move on to creating a custom domain.
data:image/s3,"s3://crabby-images/f59c0/f59c045a6d132f506a6bde17e6a5eceee12d8fdf" alt="Stape container in Running state"
Custom domain creation
In your Stape interface, click on the Add custom domain button.
data:image/s3,"s3://crabby-images/85c7b/85c7b2a628a99a69bf33ea04ae15d68288fc53e9" alt="Add custom domain button in Stape"
Enter the URL you want for your tagging server, choose manual connection and click Next.
data:image/s3,"s3://crabby-images/df31c/df31c4cd918a8cb0f2801a432430f9a84b26e729" alt="Adding a custom domain in Stape"
st
as my subdomain for the purposes of this tutorial, but I'd advise you to choose a neutral subdomain like srv
or server
for example.Stape now offers you to configure a DNS record.
data:image/s3,"s3://crabby-images/e1095/e1095839bf39830f22f47aff28215c0417bf268e" alt="Waiting for DNS configuration in Stape"
DNS configuration
As specified on the Stape interface, here’s the DNS record I need to configure:
Record Type | Host | Value |
---|---|---|
CNAME | st.data-marketing-school.com | usv.stape.io |
The configuration of this record must be done on your DNS host. As far as I’m concerned, my website’s DNS records are managed on Cloudflare.
data:image/s3,"s3://crabby-images/d7efe/d7efe66e8f258e1c7d86a5c59c727669e8a16503" alt="CNAME record in cloudflare pointing to Stape"
Return to the Stape interface and click Verify. A few minutes later, your server is ready to use.
data:image/s3,"s3://crabby-images/537f7/537f7503eadfba9eaffda752b58947d0c4b0503d" alt="Stape server ready for use"
Congratulations, your custom domain is now configured.
Finalizing Stape configuration
All that remains is to specify your server URL in GTM Server-Side in Admin > Container Settings.
data:image/s3,"s3://crabby-images/bcbb1/bcbb1727bbd302a6f60d0afabc5655c777429722" alt="Configuring the server URL in GTM Server Side"
Congratulations, you’ve finished configuring your server with Stape, you can now open the preview on GTM Server Side and start sending requests to your server.
data:image/s3,"s3://crabby-images/3a7c6/3a7c6474ed8690680f418d4ceefb236bf14acf6e" alt="Functional GTM Server Side preview"
Send your data to the server
To send data to your server, we’ll use GA4 as a carrier.
On the client-side, you need to tell the Google tag to send the data to your server. To do this, you need to add the server_container_url
parameter to the configuration settings.
The value should be the URL of your server.
data:image/s3,"s3://crabby-images/81921/819212b0e712df06a55f12657e9a95d69f0180fe" alt="Add server_container_url parameter to Google tag configuration settings."
server_container_url
parameter to Google tag configuration settings.If certain event tags are triggered before the Google tag, they will use the default configuration and send requests directly to GA4 without passing through your server. This will lead to problems in the data stream later on.
To avoid this, it’s best to add the server_container_url
parameter as an event parameter for all your GA4 event tags.
data:image/s3,"s3://crabby-images/0ab21/0ab211ed8a3d8a547de8bd8e617a51604ff1b74b" alt="Adding the server_container_url parameter to the event parameters of GA4 event tags."
server_container_url
parameter to the event parameters of GA4 event tags.What is a Client?
A client listens to requests arriving on your server. If it recognizes a request as its own (for example, the GA4 client recognizes /g/collect
requests) then it will “Claim” it.
Only one client can Claim a request. In other words, one and the same request cannot be Claimed by several clients at the same time.
A client has a priority. The client with the highest priority will claim a request before other clients.
Once a client has Claimed a request, it will retrieve the information inside to extract an event name and event data that can be used by tags to send this data and/or get triggered.
data:image/s3,"s3://crabby-images/2c145/2c145ac90f1035f64947f536cdb33be33f63a839" alt="GA4 client claims a request"
Configuring the GA4 client
The GA4 client is present by default in a new GTM Server-Side container.
data:image/s3,"s3://crabby-images/64cb2/64cb2986b7ff33dccc53044e34fbe1068626b6e0" alt="Client GA4"
Default GA4 paths
This checkbox is checked by default. It allows the GA4 client to listen for /g/collect
requests.
If you uncheck it, the client will no longer Claim GA4 event requests.
Default gtag.js paths for specific IDs
This checkbox enables gtag.js files (e.g. the GA4 library) to be delivered from your server.
gtag.js
libraries in a first-party context.Cookies and client ID
When you’re in Client-Side, the cookie used by GA4 to identify a user is _ga
.
When you switch to Server-Side, the cookie used by default (initial GA4 client configuration) to identify a user is FPID
for First-Party IDentifier.
In the configuration you can choose to continue using the _ga
cookie, to use the FPID
cookie or a mix of the two.
Javascript managed
The _ga
cookie will always be used even if you’re in Server-Side.
Server managed
The FPID
cookie will be used.
When in server-managed mode, you can also check the Migrate from JavaScript Managed Client ID checkbox. This will continue to use the _ga
cookie for existing users, but will also drop the FPID
for new users.
Configuring the GA4 tag
Since we’re using the GA4 data standard to send data to the server, configuring the GA4 tag is pretty straightforward, as it will pass the data through to your GA4 property.
To simply send the data to GA4, you can create the tag and leave the configuration empty.
data:image/s3,"s3://crabby-images/d3171/d3171ae0efe709c89a7fc7b07e8010ebf9158595" alt="Server-side GA4 tag configuration"
Consent Mode management
If you have configured Consent Mode on the client-side and are using the GA4 standard to send data to your server, server-side tags will automatically take Consent Mode into account.
Consent Mode values are sent in the GA4 request via the gcs
and gcd
parameters.
These values are then extracted by the GA4 client, which will propose them in the event data in the x-ga-gcs
and x-ga-gcd
parameters. The gcd
parameter can also be found in x-sst-system_properties.gcd
.
It is these parameters that will adapt the behavior of Google tags (GA4, Google Ads and Floodlight) on the server side.
Preview tabs
Requests
Here you can see which client has Claimed the request, as well as incoming and outgoing requests from your server.
data:image/s3,"s3://crabby-images/0e3b8/0e3b89497a4cce00681da20e23444ff54488205f" alt="Request tab in GTM Server-Side preview"
Tags
As in the Tag Assistant on the client-side, here you can see which tags have been triggered and which have not.
data:image/s3,"s3://crabby-images/a25a6/a25a6fcba3284b588304de9d7d59c617cc4da8ee" alt="Tags tab in GTM Server-Side preview"
Variables
As with GTM WEB, there are built-in variables and also user-defined variables on the server side.
data:image/s3,"s3://crabby-images/40e80/40e802ed36c282378c448df16e3c6fb5ab3f052d" alt="Variables tab in GTM Server-Side preview"
As a reminder, built-in variables are pre-existing variables that you can enable or disable in your container.
User-defined variables are variables you have to configure yourself. For example, the Event data variable will be useful on the server side for fetching a specific parameter from event data.
Event data
Event data are all parameters that have been retrieved from the incoming GA4 request.
As a reminder, this event data is generated by the GA4 client.
data:image/s3,"s3://crabby-images/0f1ee/0f1eebe7137d5878c04eedc32ea04bd35a64a752" alt="Event Data tab in GTM Server-Side preview"
Console
The console, displays messages sent by tags when they are triggered.
These messages can be information, warnings or errors.
data:image/s3,"s3://crabby-images/a5c7f/a5c7ff482de6e6904cfb2810f4b0a5148ca19c34" alt="Console tab in GTM Server-Side preview"
Transformations
With transformations, you can add, modify or exclude parameters in event data.
As soon as a transformation is applied, tags must use the transformed parameters and no longer the original event data.
data:image/s3,"s3://crabby-images/d2e75/d2e754035330a0b515c2e262ab8b647e417a993e" alt="Transformations in GTM Server-Side"