本文是微服务框架搭建系列的第一篇,本系列文章是自己学习和摸索的记录,文章的内容多提炼自互联网,经过笔者不断尝试后,达到了跑得起来的效果。
本文大量经验借鉴自李卫民老师的博客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,能访问到说明已经安装好了。
控制台一直在运行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