docker 入門學習系列文章教程 - 使用 compose 部署 GitLab 應用 (八)

1. 介紹

上一篇:Docker Compose的介紹與安裝(七)

之前介紹過compose,現在來使用它,直接來部署一個gitlab應用。

2. 下載鏡像

我們部署的是sameersbn/docker-gitlab這個鏡像。

首先把它下載下來。

$ docker pull sameersbn/gitlab

3. 配置文件

我們不需要去run它,只需要先下載一個compose的配置文件。

$ wget https://raw.githubusercontent.com/sameersbn/docker-gitlab/master/docker-compose.yml

打開這個文件,把它的內容按照你自己的需要修改,比如改改github登錄的配置信息,郵件發送的配置信息等。

比如我的配置如下:

version: '2'
services:
  redis:
    restart: always
    image: sameersbn/redis:latest
    command:
    - --loglevel warning
    volumes:
    - /srv/docker/gitlab/redis:/var/lib/redis:Z
  postgresql:
    restart: always
    image: sameersbn/postgresql:9.5-4
    volumes:
    - /srv/docker/gitlab/postgresql:/var/lib/postgresql:Z
    environment:
    - DB_USER=gitlab
    - DB_PASS=password
    - DB_NAME=gitlabhq_production
    - DB_EXTENSION=pg_trgm
  gitlab:
    restart: always
    image: sameersbn/gitlab:8.15.2
    depends_on:
    - redis
    - postgresql
    ports:
    - "10080:80"
    - "10022:22"
    volumes:
    - /srv/docker/gitlab/gitlab:/home/git/data:Z
    environment:
    - DEBUG=false
    - DB_ADAPTER=postgresql
    - DB_HOST=postgresql
    - DB_PORT=5432
    - DB_USER=gitlab
    - DB_PASS=password
    - DB_NAME=gitlabhq_production
    - REDIS_HOST=redis
    - REDIS_PORT=6379
    - TZ=Asia/Beijing
    - GITLAB_TIMEZONE=Beijing
    - GITLAB_HTTPS=false
    - SSL_SELF_SIGNED=false
    - GITLAB_HOST=gitlab.rails365.net
    - GITLAB_PORT=10080
    - GITLAB_SSH_PORT=10022
    - GITLAB_RELATIVE_URL_ROOT=
    - GITLAB_SECRETS_DB_KEY_BASE=xxx
    - GITLAB_SECRETS_SECRET_KEY_BASE=xxx
    - GITLAB_SECRETS_OTP_KEY_BASE=JBSWY3DPEHPK3PXP
    - GITLAB_ROOT_PASSWORD=
    - GITLAB_ROOT_EMAIL=
    - GITLAB_NOTIFY_ON_BROKEN_BUILDS=true
    - GITLAB_NOTIFY_PUSHER=false
    - [email protected]
    - [email protected]
    - [email protected]
    - GITLAB_BACKUP_SCHEDULE=daily
    - GITLAB_BACKUP_TIME=01:00
    - SMTP_ENABLED=true
    - SMTP_DOMAIN=192.168.33.10
    - SMTP_HOST=smtpdm.aliyun.com
    - SMTP_PORT=25
    - [email protected]
    - SMTP_PASS=xxxxx
    - SMTP_STARTTLS=true
    - SMTP_AUTHENTICATION=plain
    ....
    - OAUTH_GITHUB_API_KEY=8910bb915c112971520b
    - OAUTH_GITHUB_APP_SECRET=dc04e2fa55626bd0b1433c35adb57d85511d5772
    

有些地方被我省略了,還有些地方被我用xxx隱藏了。

4. compose up

現在改完之後就可以直接運行了。我們使用下面的命令來運行。

$ docker-compose up

運行的時候會發現會下載其他的鏡像,比如postgresql,還有redis。因爲compose是允許不同的鏡像容器互相鏈接的,從上面的配置文件中的內容也可以看出來。

如果要以守護態運行,可以加-d參數。

5. nginx配置

這個鏡像默認是會啓用10080端口訪問,我們可以用nginx反向代理到這個端口上。

比如:gitlab.conf。

upstream gitlab {
  server                    127.0.0.1:10080;
}
server {
  listen                    80;
  server_name               gitlab.rails365.net;
  server_tokens             off;
  root                      /dev/null;
  location / {
    proxy_read_timeout      300;
    proxy_connect_timeout   300;
    proxy_redirect          off;
    proxy_set_header        X-Forwarded-Proto $scheme;
    proxy_set_header        Host              $http_host;
    proxy_set_header        X-Real-IP         $remote_addr;
    proxy_set_header        X-Forwarded-For   $proxy_add_x_forwarded_for;
    proxy_set_header        X-Frame-Options   SAMEORIGIN;
    proxy_pass              http://gitlab;
  }
}

完結。

下一篇:使用compose部署Rocket.Chat應用(九)

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章