docker-compose.yaml 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. {% set tpl = ix_lib.base.render.Render(values) %}
  2. {% set c1 = tpl.add_container(values.consts.seaweedfs_container_name, "image") %}
  3. {% set perm_container = tpl.deps.perms(values.consts.perms_container_name) %}
  4. {% set perms_config = {"uid": values.run_as.user, "gid": values.run_as.group, "mode": "check"} %}
  5. {% do c1.set_user(values.run_as.user, values.run_as.group) %}
  6. {% do c1.healthcheck.set_test("wget", {"port": values.network.master_port.port_number, "path": "/cluster/healthz"}) %}
  7. {% set cmd = namespace(x=[
  8. "/usr/bin/weed", "-logtostderr", "server",
  9. "-dataCenter", values.seaweedfs.data_center_name,
  10. "-rack", values.seaweedfs.rack_name,
  11. "-dir", values.consts.data_path,
  12. "-master.port", values.network.master_port.port_number,
  13. "-master.volumeSizeLimitMB", "1024",
  14. "-volume.port", values.network.volume_port.port_number,
  15. "-volume.max", "0",
  16. ]) %}
  17. {% do tpl.portals.add(values.network.master_port, {"name": "Master"}) %}
  18. {% do tpl.portals.add(values.network.volume_port, {"name": "Volume", "path": "/ui/index.html"}) %}
  19. {% if values.network.filer_port.bind_mode %}
  20. {% do tpl.portals.add(values.network.filer_port, {"name": "Filer"}) %}
  21. {% do cmd.x.extend(["-filer", "-filer.port", values.network.filer_port.port_number]) %}
  22. {% endif %}
  23. {% if values.network.s3_port.bind_mode %}
  24. {% do cmd.x.extend(["-s3", "-s3.port", values.network.s3_port.port_number]) %}
  25. {% endif %}
  26. {% if values.network.webdav_port.bind_mode %}
  27. {% do cmd.x.extend(["-webdav", "-webdav.port", values.network.webdav_port.port_number]) %}
  28. {% endif %}
  29. {% do c1.set_entrypoint(cmd.x) %}
  30. {% do c1.environment.add_user_envs(values.seaweedfs.additional_envs) %}
  31. {% if not values.network.host_network %}
  32. {% do c1.add_port(values.network.master_port) %}
  33. {% do c1.add_port(values.network.volume_port) %}
  34. {% if values.network.filer_port.bind_mode %}{% do c1.add_port(values.network.filer_port) %}{% endif %}
  35. {% if values.network.s3_port.bind_mode %}{% do c1.add_port(values.network.s3_port) %}{% endif %}
  36. {% if values.network.webdav_port.bind_mode %}{% do c1.add_port(values.network.webdav_port) %}{% endif %}
  37. {% endif %}
  38. {% do c1.add_storage(values.consts.data_path, values.storage.data) %}
  39. {% do perm_container.add_or_skip_action("data", values.storage.data, perms_config) %}
  40. {% for store in values.storage.additional_storage %}
  41. {% do c1.add_storage(store.mount_path, store) %}
  42. {% do perm_container.add_or_skip_action(store.mount_path, store, perms_config) %}
  43. {% endfor %}
  44. {% if perm_container.has_actions() %}
  45. {% do perm_container.activate() %}
  46. {% do c1.depends.add_dependency(values.consts.perms_container_name, "service_completed_successfully") %}
  47. {% endif %}
  48. {{ tpl.render() | tojson }}