Не удалось вызвать задачу «винокурня.релиз» - PullRequest
1 голос
/ 16 марта 2020

Я работаю через несколько различных How-Tos (основной в проекте плюс несколько через поиск в Google) для edeliver для развертывания кода, но я не могу найти решение этой Could not invoke task "distillery.release": 1 error found! проблемы:

$ mix edeliver build release

BUILDING RELEASE OF HELLO_WORLD APP ON BUILD HOST

-----> Authorizing hosts
-----> Ensuring hosts are ready to accept git pushes
-----> Pushing new commits with git to: abc@company.com
-----> Resetting remote hosts to b8a7e8d2098b228f693352a0ebc59fa5c708f7a3
-----> Cleaning generated files from last build
-----> Updating git submodules
-----> Fetching / Updating dependencies
-----> Compiling sources
-----> Generating release
using mix to generate release
** (Mix) Could not invoke task "distillery.release": 1 error found!
--verbosity : Unknown option

A remote command failed on:

  abc@company.com

Output of the command is shown above and the command executed
on that host is printed below for debugging purposes:

FAILED with exit status 1:

    [ -f ~/.profile ] && source ~/.profile
    set -e
    cd /tmp/erlang/hello-world/builds
    if [ "mix" = "rebar" ]; then
      echo "using rebar to generate release"
      ./rebar   -f generate
    elif [ "mix" = "relx" ]; then
      echo "using relx to generate release"
      ./relx release
    elif [ "mix" = "mix" ]; then
      echo "using mix to generate release"
      MIX_ENV="prod" LINK_SYS_CONFIG="" LINK_VM_ARGS="" APP="hello_world" AUTO_VERSION="commit-count+git-revision+branch-unless-master" BRANCH="master" SKIP_RELUP_MODIFICATIONS="" RELUP_MODIFICATION_MODULE="" USING_DISTILLERY="" mix do release.version ,  distillery.release --verbosity=verbose
    fi

Настройка

  • Erlang 22 * ​​1008 *
  • Elixir 1.10.2 (скомпилировано с Erlang / OTP 21)
$ mix phx.new hello_world --no-ecto

mix.exs

...
  def application do
    [
      mod: {HelloWorld.Application, []},
      extra_applications: [:logger, :runtime_tools, :edeliver]
    ]
  end
...
  defp deps do
    [
      {:phoenix, "~> 1.4.16"},
      {:phoenix_pubsub, "~> 1.1"},
      {:phoenix_html, "~> 2.11"},
      {:phoenix_live_reload, "~> 1.2", only: :dev},
      {:gettext, "~> 0.11"},
      {:jason, "~> 1.0"},
      {:plug_cowboy, "~> 2.0"},
      {:edeliver, ">= 1.8.0"},
      {:distillery, "~> 2.1", warn_missing: false}
    ]
  end
...

.deliver / config

APP="hello_world" # name of your release

# The applicationis build here:
BUILD_HOST="www.hello-world.de" # host where to build the release
BUILD_USER="deployer" # local user at build host
BUILD_AT="/tmp/erlang/hello-world/builds" # build directory on build host

# Staging
STAGING_HOSTS=""
STAGING_USER=""

# This is the place where it's going to be hosted:
PRODUCTION_HOSTS="www.hello-world.de" # deploy / production hosts separated by space
PRODUCTION_USER="deployer" # local user at deploy hosts
DELIVER_TO="/home/deployer/phoenix-systems" # deploy directory on production hosts

AUTO_VERSION=commit-count+git-revision+branch-unless-master # https://github.com/edeliver/edeliver/wiki/Auto-Versioning


# For *Phoenix* projects, symlink prod.secret.exs to our tmp source
pre_erlang_get_and_update_deps() {
  local _prod_secret_path="/home/deployer/hello-world.prod.secret.exs"
  if [ "$TARGET_MIX_ENV" = "prod" ]; then
    __sync_remote "
      ln -sfn '$_prod_secret_path' '$BUILD_AT/config/prod.secret.exs'
    "
  fi
}

Mis c:

$ mix do deps.get, compile
$ echo ".deliver/releases/" >> .gitignore
$ git init
$ git add -a
$ git commit -m "Setting up edeliver"

Я копирую /home/deployer/hello-world.prod.secret.exs на сервер сборки и производства.

$ mix release.init
* creating rel/vm.args.eex
* creating rel/env.sh.eex
* creating rel/env.bat.eex
$ git add .
$ git commit -m "release config"

Чем я запускаю mix edeliver build release и получаю ошибку.

Ответы [ 3 ]

2 голосов
/ 16 марта 2020

Соответствующие строки:

** (Mix) Could not invoke task "distillery.release": 1 error found!
--verbosity : Unknown option

При --verbosity опция была устарела в v2.

Согласно документации ликеро-водочного завода:

Флаг --verbosity больше не существует, используйте --silent, --quiet или --verbose.

Он видит нераспознанную опцию и терпит неудачу. К сожалению, это происходит в сценарии оболочки, предоставленном самим delivery (верно? Или это ваше?).

MIX_ENV="prod" [...] mix do release.version ,  distillery.release --verbosity=verbose

В любом случае, похоже, что на сервере сборки есть какой-то беспорядок. Я не уверен, почему это оказывается противоречивым, но, возможно, полная очистка поможет.

0 голосов
/ 27 марта 2020

решение очень простое

  1. Запустите mix винокурню.init
  2. переменная APP (.deliver / config) должна быть такой же, как атом выпуска (rel / config.exs) ..
0 голосов
/ 16 марта 2020

Добавление этого файла с последующим git add . && git commit -m "test" решает проблему.

Решает = Обходной путь.

rel / config

# Import all plugins from `rel/plugins`
# They can then be used by adding `plugin MyPlugin` to
# either an environment, or release definition, where
# `MyPlugin` is the name of the plugin module.
~w(rel plugins *.exs)
|> Path.join()
|> Path.wildcard()
|> Enum.map(&Code.eval_file(&1))

use Distillery.Releases.Config,
    # This sets the default release built by `mix distillery.release`
    default_release: :hello_world,
    # This sets the default environment used by `mix distillery.release`
    default_environment: Mix.env()

# For a full list of config options for both releases
# and environments, visit https://hexdocs.pm/distillery/config/distillery.html


# You may define one or more environments in this file,
# an environment's settings will override those of a release
# when building in that environment, this combination of release
# and environment configuration is called a profile

environment :dev do
  # If you are running Phoenix, you should make sure that
  # server: true is set and the code reloader is disabled,
  # even in dev mode.
  # It is recommended that you build with MIX_ENV=prod and pass
  # the --env flag to Distillery explicitly if you want to use
  # dev mode.
  set dev_mode: true
  set include_erts: false
  set cookie: :"BNCsY8N!n{HeSZ[e_;mefm[~h>}|cU)0e6gJvkV5oh;Die$e:UC/O>Uh*6hG|<k("
end

environment :prod do
  set include_erts: true
  set include_src: false
  set cookie: :"?4t`!aFwp]@4zosVIBfaIG.^u(BX^nS=Rq}v2u&v0;mRvABjI.TdP*QLKo$rYpa="
end

# You may define one or more releases in this file.
# If you have not set a default release, or selected one
# when running `mix distillery.release`, the first release in the file
# will be used by default

release :hello_world do
  set version: current_version(:hello_world)
  set applications: [
    :runtime_tools
  ]
end
...