Use this information to quickly start up Community Edition using Docker Compose.
Note: While Docker Compose is often used for production deployments, the Docker Compose file provided is recommended for development and test environments only. Customers are expected to adapt this file to their own requirements, if they intend to use Docker Compose to deploy a production environment.
To deploy Community Edition using Docker Compose, download and install Docker, then follow the steps below. Make sure that you’ve reviewed the prerequisites before continuing.
- 
    Clone the project locally, and change directory to the project’s docker-composefolder:git clone https://github.com/Alfresco/acs-deployment.git cd acs-deployment/docker-composeNote: Make sure that exposed ports are open on your host computer. Check the docker-compose.ymlfile to determine the exposed ports - refer to thehost:containerport definitions. You’ll see they include 5432, 8080, 8083 and others.
- 
    Deploy Community Edition, including the repository, Share, Postgres database, Search Services, etc.: docker-compose -f community-docker-compose.yml upThis downloads the images, fetches all the dependencies, creates each container, and then starts the system: ... ⠿ Network docker-compose_default Created ... 0.2s Container docker-compose-transform-core-aio-1 Created ... 0.0s ✔ Container docker-compose-share-1 Created ... 0.1s ✔ Container docker-compose-control-center-1 Created ... 0.0s ✔ Container docker-compose-solr6-1 Created ... 0.1s ✔ Container docker-compose-postgres-1 Created ... 0.0s ✔ Container docker-compose-activemq-1 Created ... 0.1s ✔ Container docker-compose-alfresco-1 Created ... 0.1s ✔ Container docker-compose-content-app-1 Created ... 0.0s ✔ Container docker-compose-proxy-1 Created ... 0.1s Attaching to docker-compose-activemq-1, docker-compose-alfresco-1, docker-compose-content-app-1, docker-compose-control-center-1, docker-compose-postgres-1, docker-compose-proxy-1, docker-compose-share-1, docker-compose-solr6-1, docker-compose-transform-core-aio-1 d ...Note that the name of each container begins with the folder name you created in step 2. As an alternative, you can also start the containers in the background by running docker-compose up -d.
- 
    Wait for the logs to complete, showing messages: ... docker-compose-alfresco-1 ... INFO ... Starting 'Transformers' subsystem, ID: [Transformers, default] docker-compose-alfresco-1 ... INFO ... Startup of 'Transformers' subsystem, ID: [Transformers, default] complete ...See Troubleshooting if you encounter errors whilst the system is starting up. 
- 
    Open your browser and check everything starts up correctly: Service Endpoint Administration and REST APIs http://localhost:8080/alfrescoControl Center http://localhost:8080/adminShare http://localhost:8080/shareAlfresco Content App http://localhost:8080/content-appSearch Services administration http://localhost:8083/solrIf Docker is running on your local machine, the IP address will be just localhost.If you’re still using the Docker Toolbox, you’ll need to switch to Docker Desktop as Docker Toolbox is deprecated. See the Alfresco Content Services - Enterprise documentation for more details about the Alfresco Control Center UI. 
- 
    Log in as the adminuser. Enter the default administrator passwordadmin.
Search Services administration
To access the Solr Admin UI, you need to add a header with a secret.
For Safari:
- Go to Develop > Show Web Inspector > Sources.
- Click on the + next to Local Overrides and select Local Overrides….
- 
    Configure the URL using a regular expression for the Solr host and port: For example, http://localhost:8983/solr/*
- Add the X-Alfresco-Search-Secretheader with the secret value.
For Chrome, FireFox, Opera, and Edge:
- Install the ModHeader extension.
- Add the X-Alfresco-Search-Secretheader with the secret value, as shown in the image.

Check system start up
Use this information to verify that the system started correctly, and to clean up the deployment.
- 
    Open a new terminal window. 
- 
    Change directory to the docker-composefolder that you created in the deployment steps.
- 
    Verify that all the services started correctly. - 
        List the images and additional details: docker-compose imagesYou should see a list of the services defined in your docker-compose.yamlfile:Container Repository Tag Image Id Size ---------------------------------------------------------------------------------------------------------------------------------------- docker-compose-activemq-1 alfresco/alfresco-activemq 5.18-jre17-rockylinux8 8d025606b35f 686MB docker-compose-alfresco-1 alfresco/alfresco-content-repository-community 23.1.0 b66ea7d42ad8 1.01GB docker-compose-content-app-1 alfresco/alfresco-content-app 4.3.0 a43e40e88c2d 87.4MB docker-compose-control-center-1 quay.io/alfresco/alfresco-control-center 8.3.0 9f7f1ce0ba60 43.2MB docker-compose-postgres-1 postgres 14.4 fb7289787ade 355MB docker-compose-proxy-1 alfresco/alfresco-acs-nginx 3.4.2 f9c4519b7920 23.4MB docker-compose-share-1 alfresco/alfresco-share 23.1.1 f4063f4d7a62 715MB docker-compose-solr6-1 alfresco/alfresco-search-services 2.0.8.2 be4b827d934a 835MB docker-compose-transform-core-aio-1 alfresco/alfresco-transform-core-aio 5.0.1 448b02b47f7d 1.67GB
- 
        List the running containers: docker-compose psYou should see a list of the services defined in the docker-compose.yamlfile.
- 
        View the log files for each service <service-name>, or container<container-name>:docker-compose logs <service-name> docker container logs <container-name>For example, to check the logs for Share, run any of the following commands: docker-compose logs share docker container logs docker-compose-share-1You can add an optional parameter --tail=25before<container-name>to display the last 25 lines of the logs for the selected container.docker-compose logs --tail=25 share docker container logs --tail=25 docker-compose-share-1Check for a success message: Successfully retrieved license information from Alfresco.
 Once you’ve tested the services, you can clean up the deployment by stopping the running services. 
- 
        
- 
    Stop the session by using CONTROL+Cin the same window as the running services:^CGracefully stopping... (press Ctrl+C again to force) [+] Running 9/9 ✔ Container docker-compose-transform-core-aio-1 Stopped ... ✔ Container docker-compose-activemq-1 Stopped ... ✔ Container docker-compose-postgres-1 Stopped ... ✔ Container docker-compose-solr6-1 Stopped ... ✔ Container docker-compose-proxy-1 Stopped ... ✔ Container docker-compose-content-app-1 Stopped ... ✔ Container docker-compose-share-1 Stopped ... ✔ Container docker-compose-alfresco-1 Stopped ... ✔ Container docker-compose-control-center-1 Stopped ...
- 
    Alternatively, you can open a new terminal window, change directory to the docker-composefolder, and run:docker-compose downThis stops the running services, as shown in the previous example, and removes them from memory: ... ⠿ Container docker-compose-transform-core-aio-1 Removed ... ✔ Container docker-compose-solr6-1 Removed ... ✔ Container docker-compose-postgres-1 Removed ... ✔ Container docker-compose-proxy-1 Removed ... ✔ Container docker-compose-activemq-1 Removed ... ✔ Container docker-compose-alfresco-1 Removed ... ✔ Container docker-compose-control-center-1 Removed ... ✔ Container docker-compose-share-1 Removed ... ✔ Network docker-compose_default Removed ... ...
- 
    You can use a few more commands to explore the services when they’re running. Change directory to docker-composebefore running these:- 
        Stop all the running containers: docker-compose stop
- 
        Restart the containers (after using the stopcommand):docker-compose restart
- 
        Starts the containers that were started with docker-compose up:docker-compose start
- 
        Stop all running containers, and remove them and the network: docker-compose down --rmi allThe --rmi alloption also removes the images created bydocker-compose up, and the images used by any service. You can use this, for example, if any containers fail and you need to remove them:... ✔ Container docker-compose-transform-core-aio-1 Removed ... 0.5s ✔ Container docker-compose-solr6-1 Removed ... 10.2s ✔ Container docker-compose-postgres-1 Removed ... 0.2s ✔ Container docker-compose-proxy-1 Removed ... 10.2s ✔ Container docker-compose-activemq-1 Removed ... 2.3s ✔ Container docker-compose-alfresco-1 Removed ... 10.2s ✔ Container docker-compose-control-center-1 Removed ... 0.1s ✔ Container docker-compose-share-1 Removed ... 10.2s ... ✔ Image alfresco/alfresco-transform-core-aio:5.0.1 Removed ... 1.9s ...
 
- 
        
See the Docker documentation for more on using Docker.
Deployment project in GitHub
See the Alfresco/acs-deployment GitHub project for more details.
- In this project, you’ll find several Docker Compose files. The default docker-compose.ymlfile contains the latest work-in-progress deployment scripts, and installs the latest development version of Content Services.
- To deploy a specific released version of Content Services, several major.minor Docker Compose files are provided in the docker-composefolder of the project.
- To modify your development environment, for example to change or mount files in the existing images, you’ll have to create new custom Docker images (recommended approach). The same approach applies if you want to install AMP files into the repository and Share images. See the Customization guidelines for more.
Using the Community Compose file in this project deploys the following system:

Cleanup
To bring the system down and cleanup the containers run the following command:
docker-compose down
Troubleshooting
- 
    If you have issues running docker-compose upafter deleting a previous Docker Compose cluster, try replacing step 2 in the initial Docker Compose instructions with:docker-compose down && docker-compose build --no-cache && docker-compose -f community-docker-compose.yml upNote: Make sure that the docker-compose uppart of the command uses the format you chose in step 2.
- 
    Stop the session by using CONTROL+C.
- 
    Remove the containers (using the --rmi alloption):docker-compose down --rmi all
- 
    Try allocating more memory resources, as advised in docker-compose.yml.For example, in Docker, change the memory setting in Preferences (or Settings) Resources > Advanced > Memory to at least 13 GB. Make sure you restart Docker and wait for the process to finish before continuing. Go back to step 2 in the initial Docker Compose instructions to start the deployment again. 
Note: You’ll need a machine with at least 13GB of memory to distribute among the Docker containers.