-
Notifications
You must be signed in to change notification settings - Fork 76
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
2ffa347
commit 585820e
Showing
11 changed files
with
158 additions
and
26 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,16 @@ | ||
version: '3' | ||
|
||
services: | ||
redis: | ||
image: redis:5-alpine | ||
restart: always | ||
ports: | ||
- 6379:6379 | ||
labels: | ||
- traefik.http.routers.db.rule=Host(`redis.shanyue.local`) | ||
|
||
# 使用已存在的 traefik 的 network | ||
networks: | ||
default: | ||
external: | ||
name: traefik_default |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,50 @@ | ||
--- | ||
title: 使用 docker-compose 部署 postgres | ||
date: 2019-01-04 20:37 | ||
|
||
--- | ||
|
||
# 部署 redis | ||
|
||
## 部署 | ||
|
||
使用官方镜像 `redis:5-alpine` 进行部署 | ||
|
||
`docker-compose.yaml` 配置文件如下,由于我们仅仅把 `redis` 作为一个缓存服务,因此不做持久化的处理 | ||
|
||
> 关于配置文件,我维护在我的 github 仓库 [shfshanyue/op-note:compose](https://github.com/shfshanyue/op-note/tree/master/compose) 中 | ||
``` yaml | ||
version: '3' | ||
|
||
services: | ||
redis: | ||
image: redis:5-alpine | ||
restart: always | ||
ports: | ||
- 6379:6379 | ||
labels: | ||
- traefik.http.routers.db.rule=Host(`redis.shanyue.local`) | ||
|
||
# 使用已存在的 traefik 的 network | ||
networks: | ||
default: | ||
external: | ||
name: traefik_default | ||
``` | ||
`docker-compose up` 启动服务 | ||
|
||
``` bash | ||
$ docker-compose up -d | ||
``` | ||
|
||
## 连接 Redis | ||
|
||
使用 `docker-compose exec` 测试是否能够正常连接redis | ||
|
||
``` bash | ||
$ docker-compose exec redis redis-cli | ||
``` | ||
|
||
连接正常 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1 +1,68 @@ | ||
# docker compose 编排容器架构简介 | ||
# docker-compose 编排架构简介 | ||
|
||
首先需要说一下服务器配置,只要你的服务器配置高于1核2G,均可使用该基础设施来管理你的个人服务器,你可以在服务中部署几个应用,并且把该服务器作为你的测试服务器来使用。但是你的应用过多,或者QPS稍大,可以相应地加强服务器配置。 | ||
|
||
现在来简述下一个低配置的个人服务器的基础设施架构图 | ||
|
||
data:image/s3,"s3://crabby-images/7a820/7a82064505d7876562fb7398867de75bb94ff94b" alt="docker compose architecture" | ||
|
||
<!--more--> | ||
|
||
## Traefik | ||
|
||
架构图的最核心位置是 `traefik`,一个 `Edge Router`,它也是该基础设施的重点。 | ||
|
||
服务器内的所有应用服务,如 `postgres`,`redis` 以及自己所写的应用服务,都与 `traefik` 置于一个网络下,**它们共同组成了一个集群**。 | ||
|
||
以下是我使用它的理由 | ||
|
||
+ 热更新配置,无需重启 | ||
+ 自动服务发现与负载均衡 | ||
+ TLS/SSL 证书的自动生成 | ||
+ 与 `docker` 的完美集成,基于 `container label` 的配置 | ||
+ 漂亮的 `dashboard` 界面 | ||
|
||
关于 `traefik` 可以参考文章 [Traefik 简易配置及入门](https://github.com/shfshanyue/op-note/blob/master/traefik.md) | ||
|
||
## 请求路由 | ||
|
||
从图左侧可以看出,请求路由分为两大类。当然他们的路由规则都是通过 `traefik` 来控制 | ||
|
||
+ `shanyue.tech` 通过公有的域名提供公有的、可供互联网访问的服务。如博客,微信公众号开发,个人网站及后端服务等等 | ||
+ `shanyue.local` 通过私有的域名提供私有的、只供内部进群访问的服务,保证安全性。如数据库,redis等等 | ||
|
||
## 应用与服务 | ||
|
||
在图右侧,都是个人服务器里的应用,它们均是通过 `docker-compose` 部署。你可以在 [shfshanyue/op-note:compose](https://github.com/shfshanyue/op-note/tree/master/compose) 中找到所有的配置文件 | ||
|
||
只需要 `docker-compose up -d` 即可启动 | ||
|
||
+ `whoami`: 一个用以测试的服务,测试负载均衡及路由匹配等 | ||
+ `dns`: 集群内 DNS 服务,给自己的私有域名 `shanyue.local` 做解析 | ||
+ `openvpn`:与个人笔记本搭建局域网,方便访问个人服务器上服务以及调试页面 | ||
+ `postgres` | ||
+ `redis` | ||
|
||
本章将会讲述如何部署它们以及它们的配置文件。不过在此之前,你需要对 `docker` 以及 `docker-compose` 了解一些,参考以前文章 | ||
|
||
1. [docker 简易入门](https://github.com/shfshanyue/op-note/blob/master/docker.md) | ||
1. [docker compose 简易入门](https://github.com/shfshanyue/op-note/blob/master/docker-compose.md) | ||
|
||
## 私有服务 | ||
|
||
`shanyue.local` 路由所提供的服务都是私有服务,通过 `dnsmasq` 与 `openvpn` 在个人笔记本上进行访问。 | ||
|
||
+ [搭建集群内部 DNS 服务器](https://github.com/shfshanyue/op-note/blob/master/dnsmasq.md) | ||
+ [使用 openvpn 访问集群私有服务](https://github.com/shfshanyue/op-note/blob/master/openvpn.md) | ||
|
||
## 监控 | ||
|
||
个人服务器自然也需要监控,如负载,CPU,内存,网络,磁盘等。如果你服务器配置较高,且中有重要应用在跑时可以使用 `prometheus` 与 `grafana` 搭建一套监控系统,但是作为一个轻量的个人服务器,这样就显得小题大做,而且消耗极其资源。 | ||
|
||
关于该云服务器的 `metric` 可以直接在阿里云的监控面板上进行查看。但对于轻量的个人服务器,可以使用 `htop` 与 `ctop` 两个简单的命令行工具来搞定 | ||
|
||
+ `htop` 监控进程指标 | ||
+ `ctop` 监控容器指标 | ||
|
||
data:image/s3,"s3://crabby-images/5358b/5358be399d242c665413c328321b59c61c64bf03" alt="htop" | ||
data:image/s3,"s3://crabby-images/02804/02804b314869e2d5f560af4f22aa54660a946029" alt="ctop" |
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
Empty file.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.