Шаблон проекта для быстрого старта написания сервиса на Erlang, в комплекте:
Чтобы опробовать в деле, надо всего лишь:
$ mkdir -p ~/.config/rebar3/templates
$ cd $_
$ git clone https://github.com/rbkmoney/erlang-templates.git .
$ cd ~
$ rebar3 new erlang-service name=snakeoil
$ cd snakeoil
$ git init
$ git submodule add -b master https://github.com/rbkmoney/build_utils.git build_utils
$ git submodule init
...
+ установить значения переменных BASE_IMAGE_TAG и BUILD_IMAGE_TAG в Makefile
Хозяйке на заметку. Для того, чтобы это всё заработало, необходимы следующие компоненты:
К счастью, теперь все это доступно в build образе, работать с которым легко и удобно через
make
:
- wc_
- запустить в build контейнере - wdeps_
- запустить в build контейнере вместе с необходимыми зависимыми сервисами, используя docker-compose
.- build_image - построить образ микросервиса
- push_image - отправить образ микросервиса в docker registry
Чтобы получить описание и поддерживаемые переменные:
$ rebar3 new help erlang-service
erlang-service:
custom template (~/.config/rebar3/templates/erlang-service.template)
Description: Erlang OTP Service
Variables:
name="myapp" (Name of the service, an application with this name will also be created)
description="A service that does something" (Short description of purpose of the service)
version="1" (Initial version string)
date="2016-01-26"
datetime="2016-01-26T14:17:58+00:00"
author_name="Author Name"
author_email="a.name@corporate.domain"
copyright_year="2016"
apps_dir="apps" (Directory where applications will be created if needed)
В случае необходимости доработки в первую очередь обращайтесь к официальной документации.
Из-за наличия в коде mustache-плейсхолдеров следующего вида ( <file:service-templates/apps/app/test/app_tests_SUITE.erl>):
-module({{name}}_tests_SUITE).
Форматирование через erlfmt
становится нетривиальным.
Для этого в make format
сделана подмена на в большинстве случаев приемлимый для парсинга код через find
, xargs
и sed
({{placeholder}}
-> ___placeholder___
) и должна работать для большинства случаев.