Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Isolate GitLab app from infrastructure / daemons provisioning #114

Open
brodock opened this issue Feb 26, 2016 · 3 comments
Open

Isolate GitLab app from infrastructure / daemons provisioning #114

brodock opened this issue Feb 26, 2016 · 3 comments

Comments

@brodock
Copy link

brodock commented Feb 26, 2016

I propose we make the cookbook into more than one.

There should be one "base" cookbook that would deploy the app without provisioning any dependency deamon/infrastructure.

This is good in many ways as people have different opinions on how to provisioning things, and will make it more reusable.

Some ideas:

  • GitLab-base - install ruby / deploys the app to specified folder, configure database/redis yaml based on attributes
  • GitLab-local - depends on GitLab-base, install redis / postgres or mysql / nginx (all on the same machine)
  • GitLab-HA - depends on GitLab-base, install and provision a HA setup using multiple machines, etc
  • GitLab-AWS - depends on GitLab-base, provision AWS managed services and changes base's attributes to match these values

By refactoring it to this style, we can cleanup cookbook, and people can reuse it with their own infra-structure requirements.

@atomic-penguin
Copy link
Owner

So @brodock, it definitely needs cleaned up. Not sure this is the right approach, but it looks like you are proposing wrapping the base cookbook for different use cases.

Omnibus Gitlab CE seems like it would be a good way forward for the base case. I have broken out the yum configuration for gitlab-ce into atomic-penguin/cookbook-yum-gitlab-ce as a starting point in reworking this into something more bite-sized.

So then a base recipe ideally becomes (for EL-platform family):

  1. install a few packages (ssh, postfix), install gitlab-ce.
  2. Run gitlab-ctl reconfigure, if needed (perhaps subscribe to gitlab-ce package for idempotency)
  3. template out /etc/gitlab/gitlab.rb
  4. Symlink old directories to omnibus-gitlab cookbooks to maintain compatibility?
  5. Tack on more features, or wrap in application cookbooks for various use-cases.

@brodock
Copy link
Author

brodock commented Mar 8, 2016

This is a good way to do that for general use, but I still think the "source" way of installing can be useful for other scenarios.

IMHO "base" recipe should enable both ways of installing: Omnibus and Source.
Infrastructure and environment specific use-cases should be implemented in one or more separated recipes.

Right now, generating an custom omnibus package takes a lot of time and requires specific setup and custom work, having "source" as an option makes it easy to manage an staging environment or deploying with custom changes.

@chewi
Copy link
Collaborator

chewi commented Nov 28, 2016

As things stand, the database recipes are a little strange. The mysql recipe installs a server whereas the postgres recipe does not. Both are written as though the database and user are being created remotely even though it makes more sense to do this locally, i.e. run the database cookbook on the database server, not on the application server.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

3 participants