Docker Swarm搭建Gitlab

在云端搭建自己的代码仓库,本地Push代码,持续集成后自动发布。新版的Gitlab很好地支持这个需求,虽然只是自己使用,但目标还是利用三台云主机搭建一个高可用模式的Gitlab服务。

active-active-gitlab

本文首先实现用Swarm管理集群,部署单主机模式的Gitlab。云主机是收集学生优惠卷1元买来的,单核,1G内存。一开始运行起gitlab,整个系统卡顿了,显然的资源不足。到官网上查看gitlab安装需求才知道现在的资源状况只能实现最不值得推荐的配置:

1 core supports up to 100 users but the application can be a bit slower due to having all workers and background jobs running on the same core
1GB RAM + 3GB of swap is the absolute minimum but we strongly advise against this amount of memory. See the unicorn worker section below for more advice.

查看主机交换区大小发现默认交换区大小为0,因此需要手动增加交换区大小。

增加交换区

生成4G大小的文件在/home目录下文件为swapflie:

$ sudo dd if=/dev/zero of=/home/swapflie bs=1M count=4096
4096+0 records in
4096+0 records out
4294967296 bytes (4.3 GB) copied, 36.7799 s, 117 MB/s

把这个文件转换成swap分区

$ sudo /sbin/mkswap /home/swapflie

使分区生效

$ sudo /sbin/swapon /home/swapfile

查看分区是否分配成功,(省略了其他指标参数)

$ free -h
             total       used       free     
Swap:         4.0G         0B       4.0G

搭建Gitlab

准备Swarm集群

在资源有限的情况下管理容器集群,Swarm是一个比较好的选择,相比于之前生产环境用的Kubernetes,Swarm操作简单,资源开销小,适合内部环境使用。

如果已经安装了最新版本的docker(目前是1.12.5),docker engine 已经集成了swarm。
可以用下面的命令安装最新发布版本的docker,安装完需要将当前用户加入docker用户组,并重新登录生效。

curl -fsSL https://get.docker.com/ | sh

阅读官方文档,理想情况下用Swarm配合Docker Compose以及Docker Machine可以很方便地构建docker集群。但Docker Machine创建docker环境相当于在云主机上创建另外的虚拟机(如virtual box,默认单核,1G内存),所以只能手动在云主机上安装相同docker环境,而不使用 Docker Machine。
另外Docker Compose配合Swarm,文档中有比较详细的使用方法,一开始根据这个文档部署环境,结果遇到很多坑,查错的过程中才知道目前这种模式仍在试验阶段,需要安装试验版本(docker 1.13)或者启动试验模式。使用Docker Compose + Swarm模式的方式需要其他方法,一种方式是将docker-compose.yml文件转换成swarm服务的启动方式,有个临时的实现方法,可以试用。

这里没有使用上面的方法,而是全部用命令行方式构建Swarm集群:

初始化集群

Swarm的思想主要是将多台主机抽象成一台manager服务器,通过Swarm来启动docker容器(service),像直接运行容器一样,不同的是容器会被负载均衡到不同主机。而对于容器的管理则可只在manager机器上进行。Swarm的架构如图:


swarm-arch

这里首先实现两台主机的service部署,managers上运行Swarm集群可视化工具,slave主机上运行gitlab.

登录manager主机,初始化Swarm manage

docker swarm init --advertise-addr 192.168.10.11

命令返回slave节点加入集群的命令,如:

To add a worker to this swarm, run the following command:
 docker swarm join \
 --token SWMTKN-1-5bgo3ocj3mqezig2v3j9mge4aknehgbcueovivzu6mz9supqzg-8igbqrbqhsh0z9l62qrrs0zi0 \
 192.168.10.11:2377

该信息在集群创建成功后也可以在manage主机通过下面命令获得。

docker swarm join-token worker

登录到slave主机,加入集群

通过manage返回的token信息,加入集群

 docker swarm join \
 --token SWMTKN-1-5bgo3ocj3mqezig2v3j9mge4aknehgbcueovivzu6mz9supqzg-8igbqrbqhsh0z9l62qrrs0zi0 \
192.168.10.11:2377

注意我这里的两个主机都是云主机,而且两台主机不在同一个局域网网段,因此需要将manage的内网地址192.168.10.11换成对应的公网IP,才能成功注册。如果两台主机在同一局域网,则可直接添加到集群。

给slave主机添加标签,使manage可以通过标签限定具体slave node,后面可以看到:

docker node  update --add-lable type=gitlab-node1

这里给slave机器添加type=gitlab-node1的标签。

启动Swarm可视化服务

返回到manage主机,通过docker node ls命令查看集群节点状态,一切正常后,启动Swarm可视化服务。官方并没有提供可视化服务,在这里(docker-swarm-visualizer)有一个很好的开源实现,可以直接使用该镜像构建服务。

$ docker service create   --name=swarm_visual   --publish=5001:8080/tcp   --constraint=node.role==manager   --mount=type=bind,src=/var/run/docker.sock,dst=/var/run/docker.sock   manomarks/visualizer

服务启动通过 --constraint=node.role==manager 限定该服务在manage主机运行。并通过将web端口映射到云主机的5001端口。可以通过(公网IP:5001)的方式访问。

创建gitlab数据vloumes

为了方便容器数据的共享,以及后面数据的迁移,选择创建volumes来在本地持久化gitlab容器数据,而不是映射到本地路径。
登录到slave主机,为gitlab创建volumes,volumes的使用可以从后面看到:

$ docker volume create --name gitlab_config
$ docker volume create --name gitlab_logs
$ docker volume create --name gitlab_data

这里创建了三个volumes,分别存储gitlab的配置文件、日志和用户数据。

启动Gitlab服务

在manage主机上可以直接启动gitlab服务,并限定服务在slave主机运行。系统自动会到gitlub上pull相应镜像,并在本地运行。

sudo docker service create \
    --name swarm_gitlab\
    --publish 5002:443 --publish 5003:80 --publish 5004:22 \
    --replicas 1 \
    --mount type=volume,source=gitlab_config,destination=/etc/gitlab \
    --mount type=volume,source=gitlab_logs,destination=/var/log/gitlab \
    --mount type=volume,source=gitlab_data,destination=/var/opt/gitlab \
    --constraint 'node.labels.type == gitlab-node1' \
    gitlab/gitlab-ce:latest

命令中指定服务名为swarm_gitlab,以及http服务(443,80)和ssh服务(22)端口,分别映射到宿主机;指定备份服务数为1,映射本地路径到容器相应路径,这里使用volums的方式;限定在标签type= gitlab-node1的主机上启动服务。

测试

登录到manage主机,查看节点查看服务状态:

$ docker service ls
ID            NAME          REPLICAS  IMAGE                    COMMAND
79c0rvct38j1  swarm_visual  1/1       manomarks/visualizer
dbygi9gx1318  swarm_gitlab  1/1       gitlab/gitlab-ce:latest

$ docker service ps swarm_gitlab
ID                         NAME            IMAGE                    NODE               DESIRED STATE  CURRENT STATE        ERROR
3haqups6rzf8ugobqzyescl21  swarm_gitlab.1  gitlab/gitlab-ce:latest  VM**  Running        Running 9 hours ago

访问manage主机的5001端口,可以看到Swarm集群的状态:

docker-swarm-visulizer

通过docker node的相关命令同样也可以查看集群节点信息。

访问slave主机的5003端口,看到熟悉的Gitlab登录界面,创建初试用户和密码,创建用户组,和测试Project:


gitlab

小结

本文主要实现在有限云主机资源下搭建gitlab服务,这里并没有涉及gitlab的具体配置。这里只是简单构建一个可用的服务,后面再去看gitlab的管理方法,以及服务的稳定性和数据的备份与恢复。此外,第一次使用Swarm,由于资源限制,并没有采用最佳的方式来部署服务。

原创文章,转载请注明出处,点击到我的博客

更多关注公众号:


wechat
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,772评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,458评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,610评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,640评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,657评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,590评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,962评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,631评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,870评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,611评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,704评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,386评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,969评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,944评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,179评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,742评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,440评论 2 342

推荐阅读更多精彩内容

  • 前两篇东西,我们分别介绍了Mesos和Dockers的安装和使用。在《Mesos实战》这篇的结尾,我说过将会介绍如...
    燕京博士阅读 1,296评论 0 2
  • 目录 Swarm简介 Swarm架构 Swarm命令 总结 1. Swarm简介 Docker自诞生以来,其容器特...
    garyond阅读 1,309评论 1 9
  • 每日健步迎朝阳,吐故纳新精神爽。 胸怀若谷容万物,广阔天地放眼量。 世事纷扰勿彷徨,读书学习不能忘。 交朋结友互勉...
    YSL言书乐阅读 267评论 0 5
  • 田叶阅读 226评论 0 0
  • “也许我们都是月亮型的人,无论再怎么燃烧自己也无法温暖别人,所以要珍惜身边的太阳。” 这是当年我从朋友的QQ空间看...
    吴宇仁阅读 507评论 2 4