【Linux】【Services】【SaaS】Docker+kubernetes(9. 安装consul实现服务注册发现)
1. 简介
1.1. 官方网站:
https://www.consul.io
1.2. Consul的功能:
服务发现:通过DNS或HTTP接口使得消费者发现服务,应用程序可以轻松找到所依赖的服务。
健康检查:防止将请发转发不健康的主机。
键值存储:可以使用分层键/值存储,比如功能标记、动态配置等。
多数据中心:开箱即用,不需要复杂的配置。这就意味着不用建立抽象的逻辑来扩展多个地区。
1.3. Consul集群介绍:
-- Consul agent是Consul核心工作,分为client和server两种工作模式。默认以client模式运行,提供服务注册、健康检查、转发查询给server leader。server模式启动时使用-server选项指定,用于维护Consul集群状态、Raft协议进行选举。
-- agent必须在每个Consul节点运行,所有运行Consul agent节点构成Consul集群。
-- 官方建议Consul集群至少3或5个节点运行Consul agent server模式,client节点不限。
-- 通过join或rejoin加入集群。一旦加入,集群信息使用gossip算法同步到整个集群节点。
2. 环境
2.1. 机器列表
2.2. 版本:
3. 安装与配置
3.1. Nginx
yum安装
yum -y install nginx
下载upsync模块
git clone https://github.com/weibocom/nginx-upsync-module.git
3.2. Consul
下载
https://releases.hashicorp.com/consul/1.0.6/consul_1.0.6_linux_amd64.zip?_ga=2.258678857.2141400986.1520232419-1122875496.1520232419
安装
在server端,10.30.2.45/46/47
创建一个独立分区给consul用
~]# df -h /data/consul
Filesystem Size Used Avail Use% Mounted on
/dev/mapper/vg_system-lv_consul 10G 33M 10G 1% /data/consul
修改/usr/lib/systemd/system/consul.service
[Unit]
Description=Consul service discovery agent
Requires=network-online.target
After=network-online.target
[Service]
#User=consul
#Group=consul
EnvironmentFile=-/etc/consul.conf
#Environment=GOMAXPROCS=2
Restart=on-failure
ExecStartPre=[ -f "/var/run/consul/consul.pid" ] && /usr/bin/rm -f /var/run/consul/consul.pid
ExecStart=/usr/bin/consul $CONSUL_FLAGS $CONSUL_CLIENT $CONSUL_BIND
ExecReload=/bin/kill -HUP $MAINPID
KillSignal=SIGTERM
TimeoutStopSec=5
[Install]
WantedBy=multi-user.target
修改/etc/consul.conf,把172.16.0.45/46/47
CONSUL_FLAGS="agent -server -bootstrap-expect=2 -syslog -ui -data-dir=/data/consul -config-dir=/etc/consul.conf.d/ -pid-file=/var/run/consul/consul.pid -node=hctjoscache01 -datacenter=hccos -retry-join consul.hccos.cn:8301 -advertise=172.16.0.45 -enable-script-checks"
CONSUL_CLIENT="-client=0.0.0.0"
CONSUL_BIND="-bind=172.16.0.45"
CONSUL_FLAGS="agent -server -bootstrap-expect=2 -syslog -ui -data-dir=/data/consul -config-dir=/etc/consul.conf.d/ -pid-file=/var/run/consul/consul.pid -node=hctjoscache02 -datacenter=hccos -retry-join consul.hccos.cn:8301 -advertise=172.16.0.46 -enable-script-checks"
CONSUL_CLIENT="-client=0.0.0.0"
CONSUL_BIND="-bind=172.16.0.46"
CONSUL_FLAGS="agent -server -bootstrap-expect=2 -syslog -ui -data-dir=/data/consul -config-dir=/etc/consul.conf.d/ -pid-file=/var/run/consul/consul.pid -node=hctjoscache03 -datacenter=hccos -retry-join consul.hccos.cn:8301 -advertise=172.16.0.47 -enable-script-checks"
CONSUL_CLIENT="-client=0.0.0.0"
CONSUL_BIND="-bind=172.16.0.47"
修改DNS记录,添加两条A记录,这两条记录都指向Nginx机器
consul IN A 172.16.0.148
consul IN A 172.16.0.149
在Nginx机器上添加TCP转发
server {
listen 8301;
proxy_connect_timeout 5s;
proxy_timeout 30s;
proxy_pass consul-server;
}
upstream consul-server {
server 172.16.0.45:8301 max_fails=3 fail_timeout=10s;
server 172.16.0.46:8301 max_fails=3 fail_timeout=10s;
server 172.16.0.47:8301 max_fails=3 fail_timeout=10s;
}
启动服务
systemctl start consul
查看consul的节点
[root@hctjoscache03 ~]# consul members
Node Address Status Type Build Protocol DC Segment
hctjoscache01 172.16.0.45:8301 alive server 1.0.6 2 hccos <all>
hctjoscache02 172.16.0.46:8301 alive server 1.0.6 2 hccos <all>
hctjoscache03 172.16.0.47:8301 alive server 1.0.6 2 hccos <all>
在10.30.2.95/96/97/98上分别默认安装和启动httpd,用来测试(过程略)
在/etc/consul.conf.d/下面建立httpd.json和web_check.sh
[root@hctjoscache01 consul.conf.d]# cat httpd.json
{
"service": {
"name": "httpd",
"tags": ["primary"],
"address": "172.16.0.95",
"port": 80,
"enableTagOverride": false,
"checks": [
{
"script": "/etc/consul.conf.d/web_check.sh",
"interval": "30s"
}
]
}
}
[root@hctjoscache01 consul.conf.d]# cat web_check.sh
curl -i "172.16.0.95:80" >> /dev/null 2>&1
记得给web_check.sh一个执行权限,如果脚本没执行成功也会认为服务不可用
使用这个接口来查询服务状态
curl 'http://localhost:8500/v1/health/service/httpd?passing'
3.3. Consul-template
4. 命令详解
4.1. consul
选项 | 描述 |
-advertise | 通告地址 |
-bind | 集群节点之间通讯地址 |
-bootstrap | 设置服务器为bootstrap模式,在一个DC中只有一个server处于bootstrap模式。一般初始化第一台Consul时指定,自选举为leader |
-bootstrap-expect | 在一个DC钟期望提供server节点数目,consul会一直等到指定的server数目才会引导整个集群,选举leader,不能与bootstrap同时使用 |
-client | 设置客户端访问地址,包括RPC、DNS,默认为127.0.0.1 |
-config-file | 从JSON配置文件中读取 |
-data-dir | 指定存放agent server集群状态目录,以免系统重启丢失 |
-dc | 数据中心名称,默认dc1 |
-http-port | HTTP API监听端口 |
-join | 加入一个已经启动的agent,可以指定多个agent地址 |
-node | 节点名称,必须在集群中唯一的,默认是主机名 |
-rejoin | 忽略先前的离开,再次启动后尝试加入集群 |
-server | 切换agent模式到server模式,每个集群至少有一个server |
-ui | 启用内置的Web UI |
-ui-dir | Web UI的资源目录 |
【Linux】【Services】【SaaS】Docker+kubernetes(9. 安装consul实现服务注册发现)的更多相关文章
- Consul 多数据中心下的服务注册发现与配置共享
1. Consul简介 Consul是HashiCorp公司推出的开源软件,它提供了一套分布式高可用可横向扩展的解决方案,能为微服务提供服务治理.健康检查.配置共享等能力. Eurake2.x ...
- docker及k8s安装consul
一.docker部署consul集群 参考文献:https://www.cnblogs.com/lonelyxmas/p/10880717.html https://blog.csdn.net/qq_ ...
- rancher说明为什么需要按照指定版本安装以及rancher和节点linux环境配置-docker指定版本安装
rancher说明为什么需要按照指定版本安装以及rancher和节点linux环境配置-docker指定版本安装 待办 https://blog.csdn.net/CSDN_duomaomao/art ...
- 服务注册发现consul之一:consul介绍、安装、及功能介绍
Consul 是一套开源的分布式服务发现和配置管理系统,由 HashiCorp 公司用 Go 语言开发.它具有很多优点.包括:基于 raft 协议,比较简洁: 支持健康检查, 同时支持 HTTP 和 ...
- Centos安装Consul微服务
一.简介 Consul([ˈkɒnsl],康搜)是注册中心,服务提供者.服务消费者等都要注册到Consul中,这样就可以实现服务提供者.服务消费者的隔离.除了Consul之外,还有Eureka.Zoo ...
- 基于docker,consul,consul-template, registrator, nginx服务注册发现集群
介绍 该工程主要实现服务的自动注册发现,从而达到提高运维效率,做到服务的自动发现和动态扩展. 服务注册发现 服务启动后自动被发现 动态变更负载均衡 自动伸缩 工具 1.Registrator 这是 ...
- .netcore consul实现服务注册与发现-单节点部署
原文:.netcore consul实现服务注册与发现-单节点部署 一.Consul的基础介绍 Consul是HashiCorp公司推出的开源工具,用于实现分布式系统的服务发现与配置.与其他分 ...
- .netcore consul实现服务注册与发现-集群部署
一.Consul的集群介绍 Consul Agent有两种运行模式:Server和Client.这里的Server和Client只是Consul集群层面的区分,与搭建在Cluster之上的应用服务无关 ...
- 一个故事,一段代码告诉你如何使用不同语言(Golang&C#)提供相同的能力基于Consul做服务注册与发现
目录 引言 什么是微服务 传统服务 微服务 什么是服务注册与服务发现 为什么要使用不同的语言提供相同的服务能力 服务协调器 服务注册 Golang C#(.NetCore3.1) 服务发现 通过Htt ...
随机推荐
- mysql8版本以上重置密码
1.打开命令窗口cmd,输入命令:net stop mysql,停止MySQL服务, 2.开启跳过密码验证登录的MySQL服务, 输入命令 : mysqld --console --skip-gran ...
- silky微服务模块
目录 模块的定义和类型 在模块中注册服务 通过ServiceCollection实现服务注册 通过ContainerBuilder实现服务注册 使用模块初始化任务 使用模块释放资源 模块的依赖关系 构 ...
- eclipse查看jar包源代码
方法一:将jd-gui集成在Eclipse中 https://jingyan.baidu.com/article/b24f6c8275536686bfe5daed.html 下载2个反编译文件, ...
- python实现拉普拉斯图像金字塔
一,定义 二,代码: 要求:拉普拉斯金字塔时,图像大小必须是2的n次方*2的n次方,不然会报错 1 # -*- coding=GBK -*- 2 import cv2 as cv 3 4 5 #高斯金 ...
- [loj2136]地震后的幻想乡
考虑kruskal的过程:对$n$条边随机排列(排序),令$k$表示前$k$条边恰好能使图联通,根据题目的提示,即$E(\frac{k}{m+1})=\frac{E(k)}{m+1}$ 设$p(k)$ ...
- Kubernetes(K8s)极速入门
1. 概述 老话说的好:努力学习,努力提高,做一个有真才实学的人. 言归正传,之前我们聊了 如何使用国内的镜像源搭建 kubernetes(k8s)集群 ,今天我们来聊聊如何在 kubernetes( ...
- 查找 Search
如果值域小一点. 那么我们有一个很精妙的做法. 分块完维护数字\(cnt\),和一个\(bitset\)信息. 然而小不得. 那么我们考虑维护后缀\(nxt_i\),表示第\(i\)位后,最近的\(a ...
- Codeforces 724G - Xor-matic Number of the Graph(线性基)
Codeforces 题目传送门 & 洛谷题目传送门 一道还算不套路的线性基罢-- 首先由于图不连通,并且不同连通块之间的点显然不可能产生贡献,因此考虑对每个连通块单独计算贡献.按照 P415 ...
- 洛谷 P5044 - [IOI2018] meetings 会议(笛卡尔树+DP+线段树)
洛谷题面传送门 一道笛卡尔树的 hot tea. 首先我们考虑一个非常 naive 的区间 DP:\(dp_{l,r}\) 表示区间 \([l,r]\) 的答案,那么我们考虑求出 \([l,r]\) ...
- 常见 js 数组方法使用详解
数组常用方法总结 concat filter map some every reduce sort includes join some every 语法:array.every(function(c ...