diff --git a/doc/development/python_guide/deployment.md b/doc/development/python_guide/deployment.md
index 9ea2619d615a211ad5cc7ae3ba9bdb387bf54309..faec13aec5468065781285d48811e29a0323709c 100644
--- a/doc/development/python_guide/deployment.md
+++ b/doc/development/python_guide/deployment.md
@@ -29,7 +29,7 @@ To configure deployment of the PyPI package:
 1. Create a token under `Account Settings > Add API Tokens`.
 1. For the initial publish, select `Entire account (all projects)` scope. If the project already exists, scope the token to the specific project.
 1. Configure credentials:
-  
+
    Locally:
 
    ```shell
@@ -67,7 +67,31 @@ Deploying services to self-hosted environments poses challenges as services are
 
 Self-hosted customers need to know which version of the service is compatible with their GitLab installation. Python services do not make use of [managed versioning](https://gitlab.com/gitlab-org/release/docs/-/tree/master/components/managed-versioning), so each service needs to handle its versioning and release cuts.
 
-Per convention, once GitLab creates a new release, it can tag the service repo with a new tag named `self-hosted-<gitlab-version>`. An image with that tag is created, as [seen on AI Gateway](https://gitlab.com/gitlab-org/modelops/applied-ml/code-suggestions/ai-assist/-/blob/main/.gitlab/ci/build.gitlab-ci.yml?ref_type=heads#L9). It's important that we have a version tag that matches GitLab versions, making it easier for users to deploy the full environment.
+If a service is accessible through cloud-connector, it must adhere to [GitLab Statement Support](https://about.gitlab.com/support/statement-of-support/#version-support), providing stable deployments for the current and previous 2 majors releases of GitLab.
+
+##### Tips
+
+###### Create versions that match GitLab release
+
+When supporting self-hosted deployment, it's important to have a version tag that matches GitLab versions, making it easier
+for users to configure the different components of their environment. Add a pipeline to GitLab the GitLab release process
+that tags the service repo with the same tag, which will then trigger a pipeline to create an image with the defined tag.
+
+Example: [a pipeline on GitLab](https://gitlab.com/gitlab-org/gitlab/-/blob/master/.gitlab/ci/aigw-tagging.gitlab-ci.yml) creates a tag on AI Gateway
+that [releases a new image](https://gitlab.com/gitlab-org/modelops/applied-ml/code-suggestions/ai-assist/-/blob/main/.gitlab/ci/build.gitlab-ci.yml?ref_type=heads#L24).
+
+###### Multiple release deployments
+
+Supporting 3 major versions can lead to a confusing codebase due to too many code paths. An alternative to keep support while
+allowing code clean ups is to provide deployments for multiple versions of the service. For example, suppose GitLab is on
+version `19.5`, this would need three deployments of the service:
+
+- One for service version `17.11`, which provides support for all GitLab `17.x` versions
+- One for service version `18.11`, which provides support for all GitLab `18.x` versions
+- One for service version `19.5`, which provides support for GitLab versions `19.0`-`19.5`.
+
+Once version 18.0 is released, unused code from versions 17.x can be safely removed, since a legacy deployment will be present. 
+Then, once version 20.0 is released, and GitLab version 17.x is not supported anymore, the legacy deployment can also be removed.
 
 #### Publishing images