Part 1: Provisioning an instance (this post)Part 2: Setting up a project
Intro
If you have not heard about the hype, here is the short explanation:
XM Cloud is a new offering from Sitecore based on the existing Content Management product called XM.
BUT there are differences. Major ones are:
- It is a full SaaS solution hosted and managed by Sitecore
- XM Cloud will have baked in personalization and analytics (based on Sitecore Personalize and Sitecore CDP)
- It will include Experience Edge, a CDN layer where content is published to as JSON data (truly headless)
- It will NOT have any support for CDs (Content delivery instances). So NO support for MVC based sites
- A brand new portal where new instances can be provisioned with a few clicks (which will be the topic of this first post)
- Brand new UIs for the editors called Explorer, Pages and Components (which will be the topic for upcoming posts)
- The frontend is build in any modern Jamstack framework like Next.js, Vue, Angular, etc. using GraphQL and/or the Framework SDKs
For a high level intro, also see https://www.sitecore.com/products/xm-cloud
Deploying an XM Cloud instance
So before taking advantage of XM Cloud we obviously need to deploy an instance.
An instance or environment as it is called in the portal, can be created when a project has been created. I will cover project creation in part 2.
Creating a new environment is done through the new portal (screenshot below) when clicking on an existing project.
Within the portal, multiple projects can be managed. A project is typically equal to a website or multiple websites with same content tree. Within each project there will be a number of instances, one being the production instance and then one to x number of non-production instances like QA, Test, Staging or whatever the organization needs.
Provisioning a new instance is done by just clicking the "Create new environment" within the project and then follow the guide:
When connected with a Github account the environment can be associated with a branch automatically and trigger deployments whenever there is a new commit to that branch.
For now Github is supported out of the box, but there are more on the roadmap like Azure DevOps. Using the CLI any code repository can be used with XM Cloud
When clicking "Create" the provisioning starts and you can follow the progress and see output from the different steps:
At the moment it takes about 3-10 minutes to provision a full XM Cloud setup which includes a CM server, adding the new UIs, connecting and provisioning the CDN layer (Experience Edge) for publishing the content as JSON data and setting up GraphQL endpoints.
The goal is to bring this time down to maximum 5 minutes.
When provisioning is done, the full environment is available and you can log in to the back end as it was any other Sitecore instance (Dashboard UI updated a bit).
The big difference is that Sitecore hosts and updates the instances for you and new features will be added over time. There are a few new apps in the UI and the UI has also had an overhall. Pages is one of those new apps which I will cover in a coming blog post.
That is all for provisioning a new XM Cloud instance, all it takes is about 5 minutes!
Next part in this series will be a step back and looking at how to set up that first project (needed for deploying instances), hook it up to Github and get the local development environment up and running.
After that there will be a sneak peak of the new Pages UI, followed by more details on how to work in this new setup as a developer (both backend and frontend).
Please let me know in the comments if there is anything you specifically would like to hear more about.
And do reach out on mlj@sitecore.net if you want to learn more about XM Cloud or any other Sitecore products 😀