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

gitlab starts #10

Draft
wants to merge 3 commits into
base: master
Choose a base branch
from
Draft

gitlab starts #10

wants to merge 3 commits into from

Conversation

jessopb
Copy link
Collaborator

@jessopb jessopb commented Oct 19, 2022

No description provided.

gitlab/Makefile Outdated Show resolved Hide resolved
gitlab/docker-compose.yaml Show resolved Hide resolved
@EnigmaCurry EnigmaCurry force-pushed the master branch 24 times, most recently from 191eefe to d1f0644 Compare October 28, 2022 02:04
@jessopb jessopb force-pushed the service-gitlab branch 3 times, most recently from 97fd63e to 0904991 Compare January 26, 2023 16:06
@jessopb jessopb marked this pull request as ready for review January 26, 2023 16:46
Comment on lines +9 to +11
POSTGRES_PASS=password
POSTGRES_DB_NAME=gitlab_production
GITLAB_ROOT_PASSWORD=changeme
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

passwords should be blank in .env-dist, otherwise the Makefile won't randomize it.

gitlab/Makefile Show resolved Hide resolved

## Initial setup

Bring up the service with `docker-compose up -d`
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Lets use the make style to describe how to bringing up the service.

make config
make install
make open

test:
[
"CMD-SHELL",
"pg_isready -U $$POSTGRES_USER -d $$POSTGRES_DB_NAME"
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

is double $$ correct here?

- "traefik.http.routers.gitlab-web.rule=Host(`${GITLAB_TRAEFIK_HOST}`)"
- "traefik.http.routers.gitlab-web.entrypoints=websecure"
- "traefik.http.routers.gitlab-web.service=gitlab-web"
- "traefik.http.routers.gitlab-web.tls.certresolver=${ACME_CERT_RESOLVER}"
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

certresolvers aren't needed anymore that we are using manual cert creation with make certs

- "traefik.http.services.gitlab-web.loadbalancer.server.port=80"
## SSH
- "traefik.tcp.routers.gitlab-ssh.rule=HostSNI(`*`)"
- "traefik.tcp.routers.gitlab-ssh.entrypoints=ssh"
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ssh is the same entrypoint that gitea uses, its on port 2222. Did you mean to use a different entrypoint on port 2224 (this requires modifying the traefik config)? I don't know why you would need to run both gitea and gitlab on the same machine, so maybe sharing the same entrypoint is the right thing to do.

Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

#@ if data.values.ssh_entrypoint_enabled == "true":
ssh:
address: #@ data.values.ssh_entrypoint_host + ":" + data.values.ssh_entrypoint_port
#@ end

POSTGRES_PORT=5432
POSTGRES_PASS=password
POSTGRES_DB_NAME=gitlab_production
GITLAB_ROOT_PASSWORD=changeme
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

please add a newline

Copy link
Owner

@EnigmaCurry EnigmaCurry left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@@ -5,5 +5,5 @@ include ../_scripts/Makefile.projects
config:
@${BIN}/reconfigure_ask ${ENV_FILE} GITLAB_TRAEFIK_HOST "Enter your gitlab domain name" "gl.${ROOT_DOMAIN}"
@${BIN}/reconfigure_ask ${ENV_FILE} APP_NAME "Enter the service description" "git thing"
@${BIN}/reconfigure ${ENV_FILE} POSTGRES_PASS=$(shell openssl rand -hex 45)
@${BIN}/reconfigure ${ENV_FILE} GITLAB_ROOT_PASSWORD=$(shell openssl rand -hex 45)
@[[ -z "$$(dotenv -f ${ENV_FILE} get POSTGRES_PASS)" ]] && ${BIN}/reconfigure ${ENV_FILE} POSTGRES_PASS=$(shell openssl rand -hex 45) || true
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

dotenv should be ${BIN}/dotenv

Copy link
Owner

@EnigmaCurry EnigmaCurry Feb 9, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

You can now use the reconfigure_password script instead of this.

@${BIN}/reconfigure_password ${ENV_FILE} POSTGRES_PASS

GITLAB_TRAEFIK_HOST=git.example.com
GITLAB_SSH_PORT=2224
# Choose Let's Encrypt 'staging' or 'production' environment:
ACME_CERT_RESOLVER=production
Copy link
Owner

@EnigmaCurry EnigmaCurry Feb 9, 2023

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ACME_CERT_RESOLVER is no longer used

# Choose Let's Encrypt 'staging' or 'production' environment:
ACME_CERT_RESOLVER=production

POSTGRES_USER=gitlab
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

These should all be namespaced like GITLAB_POSTGRES_USER

(In theory, you should be able to concatenate all of the d.rymcg.tech project .env files together into one and not have any overlaps)

- "traefik.http.routers.gitlab-web.entrypoints=websecure"
- "traefik.http.routers.gitlab-web.service=gitlab-web"
- "traefik.http.routers.gitlab-web.tls.certresolver=${ACME_CERT_RESOLVER}"
- "traefik.http.services.gitlab-web.loadbalancer.server.port=80"
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

server.port is not required as long as the image properly specified an EXPOSE in its Dockerfile, traefik will autodetect the port.

## Web
- "traefik.http.routers.gitlab-web.rule=Host(`${GITLAB_TRAEFIK_HOST}`)"
- "traefik.http.routers.gitlab-web.entrypoints=websecure"
- "traefik.http.routers.gitlab-web.service=gitlab-web"
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

specifying the service is not necessary, traefik will autodetect this.

]
gitlab:
image: gitlab/gitlab-ce:latest
container_name: gitlab
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

remove the container name to support multiple instances.

GITLAB_OMNIBUS_CONFIG: |
gitlab_rails['gitlab_shell_ssh_port'] = ${GITLAB_SSH_PORT}
networks:
- traefik-proxy
Copy link
Owner

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

we're not using the traefik-proxy network anymore, no networks need to be configured.

@EnigmaCurry EnigmaCurry marked this pull request as draft May 7, 2023 19:43
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

Successfully merging this pull request may close these issues.

2 participants