部署docker-gitlab

本文涉及的产品
云原生数据库 PolarDB MySQL 版,Serverless 5000PCU 100GB
云数据库 Redis 版,社区版 2GB
推荐场景:
搭建游戏排行榜
简介:

  Gitlab的docker化,找了些资料,后来发现其实人们早就已经做好了,并且在github上就有。最近学到了一个思想,”不重复造轮子“, 我这里简单照着文档做下总结。

  GitLab是利用 Ruby on Rails 一个开源的版本管理系统,使用Git作为代码管理工具,并在此基础上搭建起来的web服务.实现一个自托管的Git项目仓库,可通过Web界面进行访问公开的或者私人项目。它拥有与Github类似的功能,能够浏览源代码,管理缺陷和注释。可以管理团队对仓库的访问,它非常易于浏览提交过的版本并提供一个文件历史库。团队成员可以利用内置的简单聊天程序(Wall)进行交流。它还提供一个代码片段收集功能可以轻松实现代码复用,便于日后有需要的时候进行查找。

  Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app)。几乎没有性能开销,可以很容易地在机器和数据中心中运行。最重要的是,他们不依赖于任何语言、框架包括系统。

安装docker:

1
# wget -qO- https://get.docker.com/ | sh

安装docker-gitlab:

安装对应版本的gitlab镜像:

1
# docker pull sameersbn/gitlab:8.5.5

如果想安装最新版,使用:

1
# docker pull sameersbn/gitlab:latest

启动gitlab:

最快的启动方式是使用docker-compose

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

yml文件里存放了相应服务的配置,可根据情况更改;可以使用如下命令生成一个64位是随机字符串,用于GITLAB_SECRETS_DB_KEY_BASE

1
2
# pwgen -Bsv1 64
qs7KxxMx3wrWpFMH3CxFpbnCNHPfxsxcgRTJcNMgjMJhwLfvmh4HrmwKc4mMcRc7
1
     - GITLAB_SECRETS_DB_KEY_BASE=qs7KxxMx3wrWpFMH3CxFpbnCNHPfxsxcgRTJcNMgjMJhwLfvmh4HrmwKc4mMcRc7

另外docker-gitlab默认使用/home/git/data这个目录用来存放提交上来的代码,我修改成了自己的路径:

1
2
volumes:
     /srv/docker/gitlab/gitlab : /data/code

启动gitlab,这个过程需要等待一段时间:

1
# docker-compose up



wKioL1bmLOuwP2wcAAGqLkq-Ouk972.png

wKiom1bmLGayZg90AAJjaBdgDuY925.png


执行完成之后查看启动结果:

1
2
3
4
5
root@gitlab:~ # docker ps -a 
CONTAINER ID        IMAGE                         COMMAND                  CREATED             STATUS              PORTS                                                   NAMES
aefaf4098b00        sameersbn /gitlab :8.5.5         "/sbin/entrypoint.sh "    13 hours ago        Up 13 hours         443 /tcp , 0.0.0.0:10022->22 /tcp , 0.0.0.0:10080->80 /tcp    root_gitlab_1
a8ed7a4dd879        sameersbn /postgresql :9.4-14    "/sbin/entrypoint.sh"     13 hours ago        Up 13 hours         5432 /tcp                                                 root_postgresql_1
a9e519dcb183        sameersbn /redis :latest         "/sbin/entrypoint.sh"     13 hours ago        Up 13 hours         6379 /tcp                                                 root_redis_1

如果不用docker-compose的方式,也可以手动 launch:

1、启动postgresql:

1
2
3
4
5
docker run --name gitlab-postgresql -d \
     -- env  'DB_NAME=gitlabhq_production'  \
     -- env  'DB_USER=gitlab'  -- env  'DB_PASS=password'  \
     --volume  /srv/docker/gitlab/postgresql : /var/lib/postgresql  \
     sameersbn /postgresql :9.4-14

2、启动redis:

1
2
3
docker run --name gitlab-redis -d \
     --volume  /srv/docker/gitlab/redis : /var/lib/redis  \
     sameersbn /redis :latest

3、启动gitlab:

1
2
3
4
5
6
7
docker run --name gitlab -d \
     --link gitlab-postgresql:postgresql --link gitlab-redis:redisio \
     --publish 10022:22 --publish 10080:80 \
     -- env  'GITLAB_PORT=10080'  -- env  'GITLAB_SSH_PORT=10022'  \
     -- env  'GITLAB_SECRETS_DB_KEY_BASE=long-and-random-alpha-numeric-string'  \
     --volume  /srv/docker/gitlab/gitlab : /home/git/data  \
     sameersbn /gitlab :8.5.5

上面的命令将使用10080作为Gitlab的Web访问端口,10022将作为ssh push和pull代码的端口。 在本地可以使用浏览器打开http://localhost:10080来访问Gitlab,初始登录网站使用root账户,用户名为root,密码为:5iveL!fe,登录后需要立即修改密码。

登陆:

http://localhost:10080

wKioL1bmVi6Slw8_AACm3Z5DaZU617.png登陆进去之后修改密码就可以进行项目管理了~

wKiom1bmfofCQdevAACNVtvq3_w606.png







      本文转自Jx战壕  51CTO博客,原文链接:http://blog.51cto.com/xujpxm/1750968,如需转载请自行联系原作者



相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
9天前
|
应用服务中间件 网络安全 nginx
快速上手!使用Docker和Nginx部署Web服务的完美指南
快速上手!使用Docker和Nginx部署Web服务的完美指南
|
4天前
|
关系型数据库 MySQL Shell
4.Docker 应用部署
4.Docker 应用部署
|
3天前
|
负载均衡 Cloud Native Linux
Docker部署Traefik结合内网穿透远程访问Dashboard界面
Docker部署Traefik结合内网穿透远程访问Dashboard界面
|
4天前
|
存储 Linux 文件存储
Linux使用Docker部署Traefik容器并实现远程访问管理界面-1
Linux使用Docker部署Traefik容器并实现远程访问管理界面
|
4天前
|
存储 Shell Docker
docker 部署单节点的etcd以及 常用使用命令
在 Docker 中部署单节点的 etcd 以及一些常用命令的操作,可以按照以下步骤进行: ## 一、部署单节点 etcd 1. **拉取 etcd Docker 镜像**:您可以从 Docker Hub 拉取 etcd 的官方镜像。 ```shell docker pull quay.io/coreos/etcd:latest ``` 2. **启动 etcd 容器**:使用 `docker run` 命令来启动 etcd 容器。以下是一个示例命令,其中将容器的 2379 端口映射到主机的 2379 端口: ```shell docker run -d \
|
4天前
|
弹性计算 Shell 数据安全/隐私保护
自动化构建和部署Docker容器
【4月更文挑战第30天】
7 0
|
5天前
|
关系型数据库 分布式数据库 PolarDB
PolarDB产品使用合集之关于在Docker环境中部署和维护PolarDB-X,有相关文章可以参考吗
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。
|
6天前
|
缓存 运维 Serverless
Serverless 应用引擎产品使用之在阿里云函数计算中使用Docker进行部署函数如何解决
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
12 0
|
8天前
|
数据库 Nacos Docker
基于docker-compose部署微服务基本环境
基于docker-compose部署微服务基本环境
10 0
|
9天前
|
消息中间件 Kafka Docker
docker部署kafka
docker部署kafka
26 1