在Gitlab CI上设置PostGIS

4

我一直在尝试将gitlab CI与我的django项目搭配使用。该项目使用postgis扩展。尽管进行了所有设置,但仍然出现找不到postgis.control文件的错误。

$ export PGPASSWORD=$POSTGRES_PASSWORD
$ psql -c "CREATE EXTENSION IF NOT EXISTS postgis;" -d $POSTGRES_DB -U $POSTGRES_USER -h "postgres"
ERROR:  could not open extension control file "/usr/share/postgresql/11/extension/postgis.control": No such file or directory
ERROR: Job failed: exit code 1

这是我的.gitlab-ci.yml文件。
image: python:3.6

stages:
  - test

services:
  - mdillon/postgis
  - postgres

variables:
  POSTGRES_DB: my_db
  POSTGRES_USER: my_user
  POSTGRES_PASSWORD: ""
  TESTFOLDER: "myapp/apps/api myapp/apps/logger"
  DATABASE_URL: "postgres://my_user:@mdillon-postgis/my_db"

test:
  stage: test
  image: mdillon/postgis
  before_script:
    - apt-get update -qy
    - export PGPASSWORD=$POSTGRES_PASSWORD
    - psql -c "CREATE EXTENSION IF NOT EXISTS postgis;" -d $POSTGRES_DB -U    $POSTGRES_USER -h "postgres"
    - psql -c "CREATE EXTENSION IF NOT EXISTS postgis_topology;" -d $POSTGRES_DB -U $POSTGRES_USER -h "postgres"
    - apt-get install -y openjdk-8-jre-headless libjpeg-dev zlib1g-dev software-properties-common ghostscript libxslt1-dev binutils libproj-dev libgdal-dev gdal-bin memcached libmemcached-dev 
    - export DEBIAN_FRONTEND=noninteractive;
    - pip install --upgrade pip
    - pip install -r requirements/base.pip
    - pip install flake8
  script:
    - python manage.py test $TESTFOLDER --noinput --settings=myapp.settings.gitlab_ci --parallel 4 --verbosity=2
  only:
    - master

我也遇到了同样的问题,你解决了吗? - edudepetris
@edudepetris,你可以查看我发布的新答案。 - Mensaah
2个回答

1

0

你的数据库服务器可能没有安装postgis。你需要运行以下命令进行安装:sudo apt-get install postgis


你如何在数据库服务器上运行它呢?因为从那个GitLab CI文件中,它只是导入了一个Postgres Docker容器。 - Qwertie
在“- apt-get update”后面添加一行新的命令:“- apt-get install postgis -qy”。 - Renato Portela

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接