diff --git a/.github/docker-compose-github.yml b/.github/docker-compose-github.yml index d8f1d14f..200d8a1d 100644 --- a/.github/docker-compose-github.yml +++ b/.github/docker-compose-github.yml @@ -11,10 +11,7 @@ services: - enterprise_access_mysql:/var/lib/mysql app: - image: openedx/enterprise-access - build: - context: .. - dockerfile: Dockerfile + image: edxops/enterprise-access-dev container_name: enterprise_access.app volumes: - ..:/edx/app/enterprise-access/enterprise_access diff --git a/.github/workflows/docker-publish.yml b/.github/workflows/docker-publish.yml deleted file mode 100644 index c8f901ee..00000000 --- a/.github/workflows/docker-publish.yml +++ /dev/null @@ -1,23 +0,0 @@ -name: Push Docker Images - -on: - push: - branches: - - main - -jobs: - # Push image to GitHub Packages. - # See also https://docs.docker.com/docker-hub/builds/ - push: - runs-on: ubuntu-latest - if: github.event_name == 'push' - - steps: - - name: Checkout - uses: actions/checkout@v4 - - - name: Build and Push docker image - env: - DOCKERHUB_PASSWORD: ${{ secrets.DOCKERHUB_PASSWORD }} - DOCKERHUB_USERNAME: ${{ secrets.DOCKERHUB_USERNAME }} - run : make github_docker_push diff --git a/Dockerfile b/Dockerfile deleted file mode 100644 index 2eed4a9a..00000000 --- a/Dockerfile +++ /dev/null @@ -1,125 +0,0 @@ -FROM ubuntu:focal as app -MAINTAINER sre@edx.org - - -# Packages installed: -# git; Used to pull in particular requirements from github rather than pypi, -# and to check the sha of the code checkout. - -# build-essentials; so we can use make with the docker container - -# language-pack-en locales; ubuntu locale support so that system utilities have a consistent -# language and time zone. - -# python; ubuntu doesnt ship with python, so this is the python we will use to run the application - -# python3-pip; install pip to install application requirements.txt files - -# pkg-config -# mysqlclient>=2.2.0 requires this (https://github.com/PyMySQL/mysqlclient/issues/620) - -# libmysqlclient-dev; to install header files needed to use native C implementation for -# MySQL-python for performance gains. - -# libssl-dev; # mysqlclient wont install without this. - -# python3-dev; to install header files for python extensions; much wheel-building depends on this - -# gcc; for compiling python extensions distributed with python packages like mysql-client - -# ENV variables for Python 3.12 support -ARG PYTHON_VERSION=3.12 -ENV TZ=UTC -ENV TERM=xterm-256color -ENV DEBIAN_FRONTEND=noninteractive - -# software-properties-common is needed to setup Python 3.12 env -RUN apt-get update && \ - apt-get install -y software-properties-common && \ - apt-add-repository -y ppa:deadsnakes/ppa - -# If you add a package here please include a comment above describing what it is used for -RUN apt-get update && apt-get -qy install --no-install-recommends \ - build-essential \ - language-pack-en \ - locales \ - pkg-config \ - libmysqlclient-dev \ - libssl-dev \ - git \ - wget \ - curl \ - libffi-dev \ - libsqlite3-dev \ - python3-pip \ - python${PYTHON_VERSION} \ - python${PYTHON_VERSION}-dev \ - python${PYTHON_VERSION}-distutils - -RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone - -RUN pip install --upgrade pip setuptools -# delete apt package lists because we do not need them inflating our image -RUN rm -rf /var/lib/apt/lists/* - -# need to use virtualenv pypi package with Python 3.12 -RUN curl -sS https://bootstrap.pypa.io/get-pip.py | python${PYTHON_VERSION} -RUN pip install virtualenv - -# Create a virtualenv for sanity -ENV VIRTUAL_ENV=/edx/venvs/enterprise-access -RUN virtualenv -p python${PYTHON_VERSION} $VIRTUAL_ENV -ENV PATH="$VIRTUAL_ENV/bin:$PATH" - -WORKDIR /tmp -RUN wget https://packages.confluent.io/clients/deb/pool/main/libr/librdkafka/librdkafka_2.0.2.orig.tar.gz -RUN tar -xf librdkafka_2.0.2.orig.tar.gz -WORKDIR /tmp/librdkafka-2.0.2 -RUN ./configure && make && make install && ldconfig - -RUN ln -s /usr/bin/python3 /usr/bin/python - -RUN locale-gen en_US.UTF-8 -ENV LANG en_US.UTF-8 -ENV LANGUAGE en_US:en -ENV LC_ALL en_US.UTF-8 -ENV DJANGO_SETTINGS_MODULE enterprise_access.settings.production - -EXPOSE 18270 -EXPOSE 18271 -RUN useradd -m --shell /bin/false app - -WORKDIR /edx/app/enterprise-access - -# Copy the requirements explicitly even though we copy everything below -# this prevents the image cache from busting unless the dependencies have changed. -COPY requirements/production.txt /edx/app/enterprise-access/requirements/production.txt -COPY requirements/pip.txt /edx/app/enterprise-access/requirements/pip.txt - -# Dependencies are installed as root so they cannot be modified by the application user. -RUN pip install -r requirements/pip.txt -RUN pip install -r requirements/production.txt - -RUN mkdir -p /edx/var/log - -# Code is owned by root so it cannot be modified by the application user. -# So we copy it before changing users. -USER app - -# Gunicorn 19 does not log to stdout or stderr by default. Once we are past gunicorn 19, the logging to STDOUT need not be specified. -CMD gunicorn --workers=2 --name enterprise-access -c /edx/app/enterprise-access/enterprise_access/docker_gunicorn_configuration.py --log-file - --max-requests=1000 enterprise_access.wsgi:application - -# This line is after the requirements so that changes to the code will not -# bust the image cache -COPY . /edx/app/enterprise-access - -FROM app as newrelic -RUN pip install newrelic -CMD newrelic-admin run-program gunicorn --workers=2 --name enterprise-access -c /edx/app/enterprise-access/enterprise_access/docker_gunicorn_configuration.py --log-file - --max-requests=1000 enterprise_access.wsgi:application - -FROM app as devstack -USER root -COPY requirements/dev.txt /edx/app/enterprise-access/requirements/dev.txt -RUN pip install -r requirements/dev.txt -USER app -CMD gunicorn --workers=2 --name enterprise-access -c /edx/app/enterprise-access/enterprise_access/docker_gunicorn_configuration.py --log-file - --max-requests=1000 enterprise_access.wsgi:application diff --git a/Makefile b/Makefile index dc97196f..62dca77d 100644 --- a/Makefile +++ b/Makefile @@ -157,25 +157,11 @@ start-devstack: ## run a local development copy of the server open-devstack: ## open a shell on the server started by start-devstack docker exec -it enterprise-access /edx/app/enterprise-access/devstack.sh open -pkg-devstack: ## build the enterprise-access image from the latest configuration and code - docker build -t enterprise-access:latest -f docker/build/enterprise-access/Dockerfile git://github.com/edx/configuration - detect_changed_source_translations: ## check if translation files are up-to-date cd enterprise_access && i18n_tool changed validate_translations: fake_translations detect_changed_source_translations ## install fake translations and check if translation files are up-to-date -docker_build_no_cache: - docker-compose build --no-cache - -docker_build: - docker build . -f Dockerfile --target app -t openedx/enterprise-access - docker build . -f Dockerfile --target app -t openedx/enterprise-access.worker - docker build . -f Dockerfile --target newrelic -t openedx/enterprise-access:latest-newrelic - - docker build . -f Dockerfile --target devstack -t openedx/enterprise-access:latest-devstack - docker build . -f Dockerfile --target devstack -t openedx/enterprise-access.worker:latest-devstack - travis_docker_tag: docker_build docker tag openedx/enterprise-access openedx/enterprise-access:$$TRAVIS_COMMIT docker tag openedx/enterprise-access:latest-newrelic openedx/enterprise-access:$$TRAVIS_COMMIT-newrelic @@ -197,12 +183,6 @@ dev.provision: dev.up: dev.up.redis docker-compose up -d -dev.up.build: docker_build dev.up.redis - docker-compose up -d - -dev.up.build-no-cache: docker_build_no_cache dev.up.redis - docker-compose up -d - dev.up.with-events: dev.up.kafka-control-center dev.up # Start redis via the devstack docker-compose.yml @@ -274,22 +254,8 @@ dev.static: dev.migrate: docker-compose exec -u 0 app python manage.py migrate -github_docker_build: - docker build . -f Dockerfile --target app -t openedx/enterprise-access - docker build . -f Dockerfile --target newrelic -t openedx/enterprise-access:latest-newrelic - -github_docker_tag: github_docker_build - docker tag openedx/enterprise-access openedx/enterprise-access:${GITHUB_SHA} - docker tag openedx/enterprise-access:latest-newrelic openedx/enterprise-access:${GITHUB_SHA}-newrelic - github_docker_auth: echo "$$DOCKERHUB_PASSWORD" | docker login -u "$$DOCKERHUB_USERNAME" --password-stdin -github_docker_push: github_docker_tag github_docker_auth ## push to docker hub - docker push 'openedx/enterprise-access:latest' - docker push "openedx/enterprise-access:${GITHUB_SHA}" - docker push 'openedx/enterprise-access:latest-newrelic' - docker push "openedx/enterprise-access:${GITHUB_SHA}-newrelic" - selfcheck: ## check that the Makefile is well-formed @echo "The Makefile is well-formed." diff --git a/docker-compose.yml b/docker-compose.yml index 080a20c5..93e67342 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -22,9 +22,7 @@ services: command: memcached -vv app: - # Uncomment this line to use the official enterprise_access base image - image: openedx/enterprise-access:latest-devstack - + image: edxops/enterprise-access-dev container_name: enterprise_access.app volumes: - .:/edx/app/enterprise-access/ @@ -51,10 +49,7 @@ services: ENABLE_DJANGO_TOOLBAR: 1 worker: - image: openedx/enterprise-access.worker:latest-devstack - build: - context: . - dockerfile: Dockerfile + image: edxops/enterprise-access-dev command: bash -c 'cd /edx/app/enterprise-access/ && celery -A enterprise_access worker -l DEBUG' container_name: enterprise_access.worker depends_on: