Warning: file_get_contents(/data/phpspider/zhask/data//catemap/0/docker/10.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Postgresql 在docker下添加psql时出现清单未知错误_Postgresql_Docker - Fatal编程技术网

Postgresql 在docker下添加psql时出现清单未知错误

Postgresql 在docker下添加psql时出现清单未知错误,postgresql,docker,Postgresql,Docker,我在docker php/postgres/phppgadmin中创建了一个脚本,我需要将psql添加到我的项目中以上载我的sql转储。 我找到了它并将其添加到我的项目中,但运行build命令时出现错误: docker-compose up -d --build ... Sccessfully built 3b0700d7bed8 Successfully tagged lprodsdocker_web:latest Pulling psql (softwareplant/psql:lates

我在docker php/postgres/phppgadmin中创建了一个脚本,我需要将psql添加到我的项目中以上载我的sql转储。 我找到了它并将其添加到我的项目中,但运行build命令时出现错误:

docker-compose up -d --build
... 
Sccessfully built 3b0700d7bed8
Successfully tagged lprodsdocker_web:latest
Pulling psql (softwareplant/psql:latest)...
ERROR: manifest for softwareplant/psql:latest not found: manifest unknown: manifest unknown
My docker-compose.yml:

version: '3'

services:

    web:
        build:
            context: ./web           # directory of web/Dockerfile.yml
            dockerfile: Dockerfile.yml

        environment:
            - APACHE_RUN_USER=#1000
            # - APACHE_RUN_USER=www-data

        container_name: lprods_web

        volumes:
            - ${APP_PATH_HOST}:${APP_PTH_CONTAINER}
        ports:
            - 8086:80
        working_dir: ${APP_PTH_CONTAINER}



    db:
        image: postgres:9.6.10-alpine
        container_name: lprods_db
        ports:
            - '5433:5432'
        restart: always
        environment: 
            POSTGRES_USER: 'postgres'
            POSTGRES_PASSWORD: '1'
            POSTGRES_DB: 'wprods'
        volumes:
            - ./init:/docker-entrypoint-initdb.d/


    phppgadmin:
        image: dockage/phppgadmin:latest
        environment:
            - PHP_PG_ADMIN_SERVER_HOST=db
            - PHP_PG_ADMIN_SERVER_PORT=5432
            - PHP_PG_ADMIN_SERVER_DEFAULT_DB=postgres
        container_name: lprods_phppgadmin

        restart: always
        ports:
            - 8087:80
            - "443:443"
        links:
            - db

    psql:
        image: softwareplant/psql
        environment:
            - PHP_PG_ADMIN_SERVER_HOST=db
            - PHP_PG_ADMIN_SERVER_PORT=5432
            - PHP_PG_ADMIN_SERVER_DEFAULT_DB=postgres
        container_name: lprods_phppgadmin

        restart: always
        ports:
            - 8087:80
            - "443:443"
        links:
            - db

    composer:
        image: composer:1.6
        container_name: lprods_composer
        volumes:
            - ${APP_PATH_HOST}:${APP_PTH_CONTAINER}
        working_dir: ${APP_PTH_CONTAINER}
        command: composer install  --ignore-platform-reqs
哪条路正确?就有这样的形象。。。 无效吗?你能给我一些其他的建议吗

已修改: 下一步我试试

https://hub.docker.com/r/governmentpaas/psql
Provides psql Postgres client. 

description seems like what I need : to upload dump into postgres db
In docker-compose.yml I added item :

    psql:
        image: governmentpaas/psql
        environment:
            - PHP_PG_ADMIN_SERVER_HOST=db
            - PHP_PG_ADMIN_SERVER_PORT=5432
            - PHP_PG_ADMIN_SERVER_DEFAULT_DB=postgres
        container_name: lprods_psql

        restart: always
        ports:
            - "8088:80"
            - "444:444"
        links:
            - db
它已经安装好了,我在托管操作系统中看到了这个容器:

lprods_docker$ docker ps
CONTAINER ID        IMAGE                       COMMAND                  CREATED             STATUS                          PORTS                                        NAMES
a3342c0b0df4        dockage/phppgadmin:latest   "/sbin/entrypoint ap"   16 minutes ago      Up 16 minutes                   0.0.0.0:443->443/tcp, 0.0.0.0:8087->80/tcp   lprods_phppgadmin
3ffa2823257a        governmentpaas/psql         "/bin/sh"                16 minutes ago      Restarting (0) 42 seconds ago                                                lprods_psql
7071eaf067d6        lprodsdocker_web            "docker-php-entrypoi"   17 minutes ago      Up 16 minutes                   0.0.0.0:8086->80/tcp                         lprods_web
4372e269daf8        postgres:9.6.10-alpine      "docker-entrypoint.s"   17 minutes ago      Up 16 minutes                   0.0.0.0:5433->5432/tcp                       lprods_db
但在输入bash容器时未找到psql命令:

# uname -a
Linux 7071eaf067d6 4.15.0-66-generic #75-Ubuntu SMP Tue Oct 1 05:24:09 UTC 2019 x86_64 GNU/Linux
root@7071eaf067d6:/var/www/lprods_docker_root# whereis psql

# psql -v
bash: psql: command not found

这是我需要的图像吗?如果是,如何使用?

您必须指定图像的标签,例如:

version: '3'

services:

[...]

    psql:
        image: softwareplant/psql:dev-jira7

[...]


softwareplant/psql似乎是postgresql server,为什么需要2个数据库?看起来这是一个无效的包。当我需要将sql转储上传到dbname数据库中时,使用posgtres命令,比如psql-h localhost-d dbname-U postgres-W。但是在我的web容器中,我没有psql命令。如何安装?请看修改块