This project contains the code for running Alfresco Content Services (ACS) with Docker using Docker Compose or on Kubernetes using Helm Charts.
Automated tests for helm charts are running on KinD cluster v1.25 and EKS v1.27.
The v7.0.0 release is the first release of the acs helm charts which completely leverage the new individual subcharts we started releasing since March 2023 in a dedicated repo: alfresco-helm-charts.
This change will make life easier to whoever want to customize or extend the helm deployments and simplify the future maintenance, at the cost of breaking the compatibility with the values structure which remained almost stable since the v6 release.
Please review the new values carefully and adapt any custom configuration you may have. You can read the upgrades guide for more details on the changes.
Deploying to new namespace is always the preferred way of upgrading ACS as we do not test charts for upgrade scenarios (even with previous versions) neither do we provide roll-back facilities.
The ACS Enterprise version is installed by default, using Docker images from Quay.io. If you're an Alfresco customer, you can request Quay.io credentials by logging a ticket with Hyland Community.
The repository Docker image provides a limited trial of the Enterprise version of Alfresco Content Services, which switches to read-only mode after 2 days. For a longer trial, you can request the 30-day Download Trial.
The Community Edition can be installed without the need of a license or quay.io account.
The master branch of this repository now contains the artifacts required to deploy both the the latest work-in-progress development version and previous stable versions of ACS that are still supported.
During the development phase, one or more milestone releases will be produced
indicated by an -M
suffix, for example `6.0.0-M.1``. Once an ACS version
become GA, also a GA release of this repository will be published.
The table below shows the exact version of ACS deployed with each chart version/tag.
Chart Version/Tag | Default | 7.4.N | 7.3.N | 7.2.N | 7.1.N | 7.0.N | Community |
---|---|---|---|---|---|---|---|
5.0.0-M1 | 7.0.0-M2 | 6.2.1-A8 | |||||
5.0.0-M2 | 7.0.0-M3 | 7.0.0 | |||||
5.0.0 | 7.0.0 | 7.0.0 | |||||
5.0.1 | 7.0.0 | 7.0.0 | |||||
5.1.0-M1 | 7.1.0-M1 | 7.1.0-M1 | |||||
5.1.0-M2 | 7.1.0-M2 | 7.0.1 | 7.1.0-M2 | ||||
5.1.0 | 7.1.0.1 | 7.0.1 | 7.1.0 | ||||
5.1.1 | 7.1.0.1 | 7.0.1 | 7.1.0 | ||||
5.2.0-M1 | 7.2.0-M1 | 7.1.0.1 | 7.0.1 | 7.2.0-M1 | |||
5.2.0-M2 | 7.2.0-M2 | 7.1.1 | 7.0.1 | 7.2.0-M2 | |||
5.2.0 | 7.2.0 | 7.1.1 | 7.0.1 | 7.2.0 | |||
5.3.0-M1 | 23.1.0-M1 | 7.2.1 | 7.1.1.5 | 7.0.1.3 | 23.1.0-M1 | ||
5.3.0-M2 | 7.3.0-M1 | 7.2.1 | 7.1.1.5 | 7.0.1.3 | 7.3.0-M2 | ||
5.3.0-M3 | 7.3.0-M2 | 7.2.1 | 7.1.1.5 | 7.0.1.3 | 7.3.0-M2 | ||
5.3.0 | 7.3.0 | 7.2.1 | 7.1.1.5 | 7.0.1.3 | 7.3.0 | ||
5.4.0-M1 | 7.4.0-M1 | 7.3.0.1 | 7.2.1.5 | 7.1.1.7 | 7.0.1.9 | 7.4.0-M1 | |
5.4.0-M2 | 7.4.0-M2 | 7.3.1 | 7.2.1.7 | 7.1.1.8 | 7.0.1.10 | 7.4.0-M2 | |
5.4.0-M3 | 7.4.0-M3 | 7.3.1 | 7.2.1.7 | 7.1.1.8 | 7.0.1.10 | 7.4.0-M3 | |
6.0.0 | 7.4.0.1 | 7.3.1 | 7.2.1.11 | 7.1.1.8 | 7.0.1.10 | 7.4.0.1 | |
6.0.1 | 7.4.0.1 | 7.3.1 | 7.2.1.11 | 7.1.1.8 | 7.0.1.10 | 7.4.0.1 | |
6.0.2 | 7.4.0.1 | 7.3.1 | 7.2.1.11 | 7.1.1.8 | 7.0.1.10 | 7.4.0.1 | |
6.1.0-M.1 | 23.1.0-A19 | 7.4.0.1 | 7.3.1 | 7.2.1.11 | 7.1.1.8 | 7.0.1.10 | 7.4.0.1 |
7.0.0-M.1 | 23.1.0-A27 | 7.4.1 | 7.3.1 | 7.2.1.12 | 7.1.1.8 | 7.0.1.10 | 7.4.1 |
7.0.0-M.2 | 23.1.0-M4 | 7.4.1.1 | 7.3.1 | 7.2.1.12 | 7.1.1.8 | 7.0.1.10 | 7.4.1.1 |
7.0.0 | 23.1.0 | 7.4.1.2 | 7.3.1.1 | 7.2.1.12 | 7.1.1.8 | 7.0.1.10 | 23.1.0 |
7.0.1 | 23.1.1 | 7.4.1.3 | 7.3.1.2 | 7.2.1.13 | 7.1.1.10 | 7.0.1.10 | 23.1.0 |
During the development of 5.4.0 we've started moving individual components templates (search, sync, activemq, ...) into individual charts on alfresco-helm-charts. That decision introduced some breaking changes like resource renaming and values structure modifications that has been shipped since v6.0.0.
While our latest version of the charts should be able to deployment any version of ACS (theoretically), we only ever test deployment of currently supported versions. Also we do not provide values files for older unsupported version. If you need to deploy old version we provide a reference table below to allow you find the older values files and charts. You can either try using the values file for a version with the latest charts or using the old charts.
unsupported ACS version | Last chart version providing it |
---|---|
6.2 | 5.3.0 |
6.1 | 5.1.1 |
These charts should not be used for any new deployment but just for reference.
To get started please refer to the Docker Compose and Helm Chart documentation.
The code in this repository is released under the Apache License, see the LICENSE file for details.
Please use this guide to make a contribution to the project and information to report any issues.
New releases are usually made from the default branch. When a bugfix release is
necessary and master branch already received updates that are meant to be
released at a later time, then the release must be made from a branch which
follows the release branch pattern: release/v$Major.Minor
.
First ensure that:
- the supported-matrix reflects the status of the currently released Alfresco products and update if necessary before proceeding.
- the components charts have been released in stable versions (no pre-release version should be present in Chart.yaml).
Start the release by opening a PR against the appropriate branch that will:
- Update the versioning table
- In alfresco-content-services,
bump chart version to the version you want to release (use
-M.x
suffix if it's a prerelease) - Run
pre-commit run --all-files helm-docs
to update helm docs - Edit upgrades docs renaming the
To be released
section to the current version and create a newTo be released
section for the future. - Run Bump versions workflow against the same newly created branch, the
first time with
charts
option. Inspect the changes pushed on the branch, revert unwanted changes if necessary. - Run Bump versions workflow against the same branch with option
values
. This will update both docker compose tags and helm charts values. Inspect the changes pushed on the branch, looking for any missing update.
Once the PR has been merged, create the release with:
git tag -s vx.x.x -m vx.x.x
git push origin vx.x.x
gh release create vx.x.x --generate-notes -t vx.x.x -d
where vx.x.x
is the same alfresco-content-services
Chart version.
Once the workflow triggered by this new tag is successful, review the GitHub release notes, usually removing dependabot entries and other not-really useful changelog entries.
Publish the release (remove draft status).
Once the tagged workflow is successful, the release process is completed.
- Go to the
docs/docker-compose/diagrams
and/ordocs/helm/diagrams
folders of the repository and there you will find 2 plantuml source files and their PNG diagram files. - Update the plantuml(.puml) files for enterprise/community edition with latest changes as required.
- Once you are done with the changes, you can generate the diagrams with 2 ways.
- You can update the diagrams with cli method by running the below command. You need to have Java and Plantuml installed on your machine.
java -jar plantuml.jar filename
- The other way to generate the diagrams is via official plantuml website. Go to the below url and paste your puml code and click on submit.
http://www.plantuml.com/plantuml/uml/SyfFKj2rKt3CoKnELR1Io4ZDoSa70000