微服务框架搭建系列: 1.安装Ubuntu及搭建Gitlab私服

本文是微服务框架搭建系列的第一篇,本系列文章是自己学习和摸索的记录,文章的内容多提炼自互联网,经过笔者不断尝试后,达到了跑得起来的效果。
本文大量经验借鉴自李卫民老师的博客http://funtl.com以及菜鸟教程等。

进入正文,安装Ubuntu

安装环境VMWare WorkStation 15 pro虚拟机
操作系统Ubuntu 16.04 LTS (Ubuntu官网下载的ubuntu-16.04.5-server-amd64.iso)
注意:
-安装时需要联网
-安装Ubuntu时分区方式(partitionning method)时,一定要选LVM(磁盘扩容)!!!否则磁盘空间不能扩容!!!血泪教训!

安装完成后,修改root密码

sudo passwd root

安装SSH

自己安装的Ubuntu没有SSH(阿里云的Ubuntu集成了SSH),所以判断服务器是否安装SSH服务,可以使用如下命令:

ssh localhost

如果显示如下:

ssh: connect to host localhost port 22: Connection refused

则表示没有还没有安装SSH,安装命令:

sudo apt-get install openssh-server

卸载命令:

sudo apt-get remove openssh-server

客户端安装命令(客户端是否需要安装看需求):

sudo apt-get install openssh-client

OpenSSH 服务器的主要配置文件为 /etc/ssh/sshd_config,几乎所有的配置信息都在此文件中。

下安装Docker

卸载旧版本Docker(对于现有的服务器和Ubuntu系统,要有一个“干净”的环境)

sudo apt-get remove docker \
              docker-engine \
              docker.io

使用 APT 安装Docker:
安装必要的一些系统工具

sudo apt-get update
sudo apt-get -y install apt-transport-https ca-certificates curl software-properties-common

安装 GPG 证书:

curl -fsSL http://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -

写入软件源信息:

sudo add-apt-repository "deb [arch=amd64] http://mirrors.aliyun.com/docker-ce/linux/ubuntu $(lsb_release -cs) stable"

更新并安装 Docker CE:

sudo apt-get -y update
sudo apt-get -y install docker-ce

启动 Docker CE:

sudo systemctl enable docker
sudo systemctl start docker

建立 docker 用户组:

sudo groupadd docker
sudo usermod -aG docker $USER

默认情况下,docker 命令会使用 Unix socket 与 Docker 引擎通讯。而只有 root 用户和 docker 组的用户才可以访问 Docker 引擎的 Unix socket。出于安全考虑,一般 Linux 系统上不会直接使用 root 用户。因此,更好地做法是将需要使用 docker 的用户加入 docker 用户组。

测试 Docker 是否安装正确:

docker run hello-world

输出以下信息则安装正确

Unable to find image 'hello-world:latest' locally
latest: Pulling from library/hello-world
ca4f61b1923c: Pull complete
Digest: sha256:be0cd392e45be79ffeffa6b05338b98ebb16c87b255f48e297ec7f98e123905c
Status: Downloaded newer image for hello-world:latest
Hello from Docker!
This message shows that your installation appears to be working correctly.
To generate this message, Docker took the following steps:
1. The Docker client contacted the Docker daemon.
2. The Docker daemon pulled the "hello-world" image from the Docker Hub.
    (amd64)
3. The Docker daemon created a new container from that image which runs the
    executable that produces the output you are currently reading.
4. The Docker daemon streamed that output to the Docker client, which sent it
    to your terminal.
To try something more ambitious, you can run an Ubuntu container with:
$ docker run -it ubuntu bash
Share images, automate workflows, and more with a free Docker ID:
https://cloud.docker.com/
For more examples and ideas, visit:
https://docs.docker.com/engine/userguide/

安装完成后配置镜像加速:
在 /etc/docker/daemon.json 中写入如下内容(文件不存在需要请新建该文件):

{
  "registry-mirrors": [
    "https://registry.docker-cn.com"
  ]
}

之后重新启动服务

sudo systemctl daemon-reload
sudo systemctl restart docker

最后输入 docker info 检查镜像是否配置

Docker-Compose安装:(注意版本更新)

sudo curl -L https://github.com/docker/compose/releases/download/1.23.2/docker-compose-`uname -s`-`uname -m` > /usr/local/bin/docker-compose
sudo chmod +x /usr/local/bin/docker-compose

注意不要使用sudo apt installdocker-compose安装,此方法安装的版本为1.8.0,版本过低不兼容后续程序。

Gitlab安装(硬件要求:2G内存,10000rpm硬盘)

Gitlab是开源的,所以可以自己架设Gitlab服务器来托管代码、持续集成等。步骤如下:
在Docker Hub https://hub.docker.com/ 找到Gitlab等社区版(中文)镜像 https://hub.docker.com/r/twang2218/gitlab-ce-zh ,把镜像拖进Docker

docker pull twang2218/gitlab-ce-zh

在/usr/local/下创建docker目录 再在docker目录下创建gitlab目录
写入/usr/local/docker/gitlab/docker-compose.yml 配置如下

version: '3'
services:
    web:
      image: 'twang2218/gitlab-ce-zh'
      restart: always
      hostname: '192.168.111.132'
      environment:
        TZ: 'Asia/Shanghai'
        GITLAB_OMNIBUS_CONFIG: |
          external_url 'http://192.168.111.132:8080'
          gitlab_rails['gitlab_shell_ssh_port'] = 2222
          unicorn['port'] = 8888
          nginx['listen_port'] = 8080
      ports:
        - '8080:8080'
        - '8443:443'
        - '2222:22'
      volumes:
        - /usr/local/docker/gitlab/config:/etc/gitlab
        - /usr/local/docker/gitlab/data:/var/opt/gitlab
        - /usr/local/docker/gitlab/logs:/var/log/gitlab

hostname应填写域名,虚拟机本地部署填ip即可,
external_url为外部访问端口,必须和Nginx反向代理的端口保持一致,
443端口为https请求的SSL安全端口,暴露为8443,避免冲突,
22为SSH连接端口,暴露为2222,避免冲突,
保存后输入命令docker-compose up,耐心等待后在浏览器输入 http://192.168.111.132:8080 即可打开Gitlab,能访问到说明已经安装好了。


1.png

控制台一直在运行gitlab,ctrl c强制结束进程,这样控制台就能继续操作了而不是一直在跑gitlab的后台程序,
输入 docker ps -a 列出所有容器,取到gitlab容器的id,用 docker start id 来重启已经停止的容器,重启后gitlab容器在系统后台运行,控制台可以继续操作系统。
或者启动时输入docker-compose up -d在后台运行程序,这样就省去了强退进程再重启,但是也比较不直观。
用XShell或者还有SecureCRT还可以再开一个连接就不用管当前在后台跑跑跑的这个连接了。
至此Gitlab私服就搭建完成了,按照微服务的理念,一台服务器只提供一种服务,那么这台服务器只用来做Gitlab服务器,接下来的服务,则用新的服务器来搭建。

---------------------------------------------2019.2.11更新-------------------------------------------------
今天给公司搭gitlab私服按以上流程走,到SSH远程连接到时候死活连不上,症状为:虚拟机与宿主机、外网、局域网远程主机互相能ping通,宿主机与外网、局域网远程主机互相能ping通,局域网远程主机ping不到虚拟机,SSH自然也连不上。然后在宿主机下载了一个XShell,连虚拟机提示“SSH服务器拒绝连密码”,按理说宿主机虚拟机互相ping通,在宿主机上SSH连虚拟机应该是可以的,但是失败了。尝试了多种办法之后找到一种解决办法,就是虚拟机联网方式不用NAT连,改用桥接,直接把虚拟机放在局域网里,问题解决。
且不讨论到底问题出在哪,什么原因,什么原理,总之先把问题解决了。这算不算有了极限编程的思想呢0.0

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

推荐阅读更多精彩内容