gpt4 book ai didi

postgresql - Codenvy添加postgresql到项目报错

转载 作者:行者123 更新时间:2023-11-29 12:59:48 26 4
gpt4 key购买 nike

我是 Codenvy 的新手,所以我的问题可能非常愚蠢,顺便说一句,这是我的问题:

我创建了我的项目,然后添加了数据库 (postgresql),我创建了一个新的 docker 文件,并在其中粘贴了此文件中的代码:https://github.com/codenvy/dockerfiles/blob/master/base/jdk7_postgresql/Dockerfile

我保存了它,然后我用刚创建的运行器运行了这个项目,但是我有这个错误:

[DOCKER] Setting up dh-python (1.20141111-2) ...
[DOCKER] Processing triggers for systemd (215-17+deb8u2) ...
[DOCKER] Processing triggers for libc-bin (2.19-18+deb8u1) ...
[DOCKER] Processing triggers for dbus (1.8.20-0+deb8u1) ...
[DOCKER] Starting PostgreSQL 9.3 database server:
[DOCKER] main
[DOCKER] .
[DOCKER] CREATE ROLE
[DOCKER] ---> 77b708d3360b
[DOCKER] Removing intermediate container cdd908fb498e
[DOCKER] Step 4 : ADD startup.sh /home/user/startup.sh
[DOCKER][ERROR] startup.sh: no such file or directory
[ERROR] We are having trouble starting the runner and deploying application. Either necessary files are missing or a fundamental configuration has changed.
Docker image build failed

我知道如何解决这个问题吗?提前致谢!

最佳答案

此 PostgresSQL 镜像使用 startup.sh 脚本启动 postgresql 服务。您可以在 https://github.com/codenvy/dockerfiles/blob/master/base/jdk7_postgresql/startup.sh 找到它

要解决这个问题,您可以在项目的根目录中创建一个内容相同的新文件 startup.sh,将其添加为源(例如 ADD $src$/startup.sh/home/user/startup.嘘)。您还需要注入(inject)项目源以使其按预期工作,因此您的 Dockerfile 可能如下所示:

FROM codenvy/jdk7

ENV DEBIAN_FRONTEND noninteractive

RUN sudo apt-key adv --keyserver keyserver.ubuntu.com --recv-keys B97B0AFCAA1A47F044F244A07FCC7D46ACCC4CF8 && \
echo "deb http://apt.postgresql.org/pub/repos/apt/ precise-pgdg main" | sudo tee /etc/apt/sources.list.d/pgdg.list && \
sudo apt-get update && \
sudo -E bash -c "apt-get install -y python-software-properties software-properties-common postgresql-9.3 postgresql-client-9.3 postgresql-contrib-9.3 pwgen" && \
sudo service postgresql start && \
CODENVY_POSTGRESQL_PASSWORD=$(pwgen -N 1) && echo "export CODENVY_POSTGRESQL_PASSWORD=$CODENVY_POSTGRESQL_PASSWORD" >> /home/user/.postgresrc && \
CODENVY_POSTGRESQL_DB=testdb_$(pwgen -N 1) && echo "export CODENVY_POSTGRESQL_DB=$CODENVY_POSTGRESQL_DB" >> /home/user/.postgresrc && \
CODENVY_POSTGRESQL_USER=codenvy && echo "export CODENVY_POSTGRESQL_USER=$CODENVY_POSTGRESQL_USER" >> /home/user/.postgresrc && \
sudo -u postgres psql --command "CREATE USER $CODENVY_POSTGRESQL_USER WITH SUPERUSER PASSWORD '$CODENVY_POSTGRESQL_PASSWORD';" && \
sudo -u postgres createdb -O $CODENVY_POSTGRESQL_USER $CODENVY_POSTGRESQL_DB

#Inject project sources
ADD $app$ /home/user/$app$
RUN unzip -q /home/user/$app$ -d /home/user
ENV ARGUMENTS $args$

#Add file to the container
ADD $src$/startup.sh /home/user/startup.sh

RUN sudo chmod +x /home/user/startup.sh

#EXPOSE 5432

CMD sudo /home/user/startup.sh

或者您可以简单地使用 Codenvy 默认的 PostgreSQL 9.3 + Java 7 运行器,您可以在运行器面板 > 配置选项卡上找到它。

关于postgresql - Codenvy添加postgresql到项目报错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33593321/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com