1

Dockerfile と Vagrant を使用して MariaDB をインストールすると、次のエラーが発生し続けます。

New password for the MariaDB "root" user:
Use of uninitialized value $_[1] in join or string at /usr/share/perl5/Debconf/DbDriver/Stack.pm line 111.
invoke-rc.d: policy-rc.d denied execution of stop.
Use of uninitialized value $val in substitution (s///) at /usr/share/perl5/Debconf/Format/822.pm line 83, <GEN6> line 1.
Use of uninitialized value $val in concatenation (.) or string at /usr/share/perl5/Debconf/Format/822.pm line 84, <GEN6> line 1.
dpkg: error processing mariadb-server-10.0 (--configure):
 subprocess installed post-installation script returned error exit status 1
Setting up libhtml-template-perl (2.91-1) ...
dpkg: dependency problems prevent configuration of mariadb-server:
 mariadb-server depends on mariadb-server-10.0 (= 10.0.15+maria-1~wheezy); however:
  Package mariadb-server-10.0 is not configured yet.

dpkg: error processing mariadb-server (--configure):
 dependency problems - leaving unconfigured
Errors were encountered while processing:
 mariadb-server-10.0
 mariadb-server
E: Sub-process /usr/bin/dpkg returned an error code (1)

これは、私が試したすべての MariaDB (10.0.15、10.1.2) で発生します。

私の DockerFile:

# vim:set ft=dockerfile:
FROM debian:wheezy

# add our user and group first to make sure their IDs get assigned consistently, regardless of whatever dependencies get added
RUN groupadd -r mysql && useradd -r -g mysql mysql

# grab gosu for easy step-down from root
RUN gpg --keyserver pool.sks-keyservers.net --recv-keys B42F6819007F00F88E364FD4036A9C25BF357DD4
RUN apt-get update && apt-get install -y curl && rm -rf /var/lib/apt/lists/* \
    && curl -o /usr/local/bin/gosu -SL "https://github.com/tianon/gosu/releases/download/1.2/gosu-$(dpkg --print-architecture)" \
    && curl -o /usr/local/bin/gosu.asc -SL "https://github.com/tianon/gosu/releases/download/1.2/gosu-$(dpkg --print-architecture).asc" \
    && gpg --verify /usr/local/bin/gosu.asc \
    && rm /usr/local/bin/gosu.asc \
    && chmod +x /usr/local/bin/gosu \
    && apt-get purge -y --auto-remove curl

RUN apt-key adv --keyserver pool.sks-keyservers.net --recv-keys 199369E5404BD5FC7D2FE43BCBCB082A1BB943DB

ENV MARIADB_MAJOR 10.0
ENV MARIADB_VERSION 10.0.15+maria-1~wheezy

RUN echo "deb http://ftp.osuosl.org/pub/mariadb/repo/$MARIADB_MAJOR/debian wheezy main" > /etc/apt/sources.list.d/mariadb.list

RUN apt-get update \
    && apt-get install -y \
        mariadb-server=$MARIADB_VERSION \
    && rm -rf /var/lib/apt/lists/* \
    && rm -rf /var/lib/mysql \
    && mkdir /var/lib/mysql \
    && sed -ri 's/^(bind-address|skip-networking)/;\1/' /etc/mysql/my.cnf

VOLUME /var/lib/mysql

COPY docker-entrypoint.sh /

ENTRYPOINT ["/docker-entrypoint.sh"]

EXPOSE 3306
CMD ["mysqld"]

私は考えられる解決策をGoogleで探していましたが、解決策が投稿されずに同じ問題を抱えている人しか見つけることができませんでした.

私の浮浪者の定義は次のようになります。

Vagrant.configure(VAGRANTFILE_API_VERSION) do |config|
    config.vm.define "mariadb" do |v|
        v.vm.provider "docker" do |d|
            d.build_dir = "./docker/mariadb"
            d.name = "mariadb"
            d.ports = ["3306:3306"]
            d.vagrant_vagrantfile = "#{DOCKER_HOST_VAGRANTFILE}"
            d.env = {
                MYSQL_ROOT_PASSWORD: "root",
                MYSQL_USER: "root",
                MYSQL_PASS: "root"
            }
        end
    end
end

また、MariaDB の代わりに MySQL をインストールしようとすると、うまくいきます。したがって、ここでの私の考えは、MariaDB のルート パスワードを設定するときにエラーが発生するということです。それは、このエラーが行の直後に表示さNew password for the MariaDB "root" user:れ、最後にまだ構成されていないと表示されることです。

たぶん、問題は VagrantFile にありますか? ただし、env変数の設定方法を変更しようとしましたが、問題は解決しませんでした:(

誰かがこれで私を助けてくれたらうれしいです。

更新: DockerFile 使用: https://github.com/docker-library/mariadb/blob/d06c367c4b199f91b36f5f6fabf8305282b8abac/10.0/Dockerfile (パーミッションを 755 に修正しました)

4

1 に答える 1

1

解決策は、VirtualMachine に RAM を追加して完全に再作成することでした (そのため、virtualbox を開いて boot2docker マシンも削除しました)。(これを指摘してくれたuser2915097に感謝します!)

于 2015-01-20T14:52:33.377 に答える