当前位置: 首页 > wzjs >正文

乌鲁木齐 网站建设镇江seo

乌鲁木齐 网站建设,镇江seo,企业建站系统cms,期刊网站建设目录 一、什么是服务注册与发现 二、什么是consul 三、consul的主要工作是什么 四、consul的特性有哪些 五、Consul部署 实验前准备 建立consul服务器 设置代理 查看端口 查看集群信息 Registrator服务器 安装Gliderlabs/Registrator 测试服务发现功能 部署consu…

目录

一、什么是服务注册与发现

二、什么是consul

三、consul的主要工作是什么

四、consul的特性有哪些

五、Consul部署

实验前准备

建立consul服务器

设置代理

查看端口

查看集群信息

Registrator服务器

安装Gliderlabs/Registrator

测试服务发现功能

部署consul-template

准备template nginx模板文件

编译安装nginx

配置nginx

配置并启动template

访问template-nginx


一、什么是服务注册与发现

服务发现 一种自动检测网络中服务 位置 的机制, 用于在分布式系统连接和交互的

服务注册一种机制,允许服务在一个中心日录上公开其存在和可用性,以便其他服务可以发现并与其进行交互

安装consul是用于服务注册,也就是容器本身的一些信息注册到consul里面,其他程序可以通过consul获取注册的相关服务信息,这就是服务注册与发现

二、什么是consul

Consul是一种开源的分布式服务发现和配置管理工具。它提供了服务注册与发现,健康检查,KV存储,多数据中心,安全服务通信等功能,是构建分布式系统和微服务架构的重要工具。

三、consul的主要工作是什么

conus1 主要工作分为两个部分: 服务发现和配置管理。

服务发现是指在分布式计算环境下,自动发现可用的服务实例,并将其注册到consul上,以便其它服务进行调用

配置管理是指通过consul,动态更新分布式架构中配置信息,包括环境变量、属性值、文件、数据库等

注: consul 可以与多钟不同的服务一起使用 docker kubernetes mesos等等

四、consul的特性有哪些

服务注册与发现:consul通过DNS或者HTTP接口使服务注册和服务发现变的很容易,一些外部服务,例如saas提供的也可以一样注册。

健康检查:健康检测使consul可以快速的告警在集群中的操作。和服务发现的集成,可以防止服务转发到故障的服务上面。

Key/Value存储:一个用来存储动态配置的系统。提供简单的HTTP接口,可以在任何地方操作。

多数据中心:无需复杂的配置,即可支持任意数量的区域。

五、Consul部署
实验前准备

Consul服务器:192.168.86.20,consul服务,nginx服务,consul-template守护进程

Registrator服务器:192.168.86.30,registrator容器,nginx容器

建立consul服务器

mkdir /opt/consul

cp consul_0.9.2_linux_amd64.zip /opt/consul

cd /opt/consul

unzip consul_0.9.2_linux_amd64.zip

mv consul /usr/local/bin/

设置代理

在后台启动consul服务端

consul agent \

-server \

-bootstrap \

-ui \

-data-dir=/var/lib/consul-data \

-bind=192.168.86.20 \

-client=0.0.0.0 \

-node=consul-server01 &> /var/log/consul.log &

参数解释

-server:以server身份启动。默认是client。

-bootstrap:用来控制一个server是否在bootstrap模式,在一个数据中心中只能有一个server处于bootstrap模式,当一个server处于 bootstrap模式时,可以自己选举为 server-leader。

-bootstrap-expect=2:集群要求的最少server数量,当低于这个数量,集群即失效。

-ui:指定开启 UI 界面,这样可以通过 http://localhost:8500/ui 这样的地址访问 consul 自带的 web UI 界面。

-data-dir :指定数据存储目录。

-bind:指定用来在集群内部的通讯地址,集群内的所有节点到此地址都必须是可达的,默认是0.0.0.0。

-client:指定 consul 绑定在哪个 client 地址上,这个地址提供 HTTP、DNS、RPC 等服务,默认是 127.0.0.1。

-node:节点在集群中的名称,在一个集群中必须是唯一的,默认是该节点的主机名。

-datacenter:指定数据中心名称,默认是dc1。

查看端口

netstat -anpt | grep consul

端口解释

启动consul后默认会监听5个端口:

8300:replication(副本代表同步)、leader(领导者) farwarding(转发)的端口

8301:lan cossip的端口 内部同一数据中心端口通信

8302:wan gossip的端口 不同数据中心端口通信

8500:web ui界面的端口 用与http接口和web

8600:使用dns协议查看节点信息的端口 用于已注册的服务发现: 使用DNS协议查看节点信息的端口

查看集群信息

#查看members状态

consul members

#查看集群状态

consul operator raft list-peers

consul info | grep leader

通过http api获取集群信息

curl 127.0.0.1:8500/v1/status/peers #查看集群server成员

curl 127.0.0.1:8500/v1/status/leader #集群 server-leader

curl 127.0.0.1:8500/v1/catalog/services #注册的所有服务

curl 127.0.0.1:8500/v1/catalog/nginx #查看 nginx 服务信息

curl 127.0.0.1:8500/v1/catalog/nodes #集群节点详细信息

Registrator服务器

容器服务自动加入Nginx集群

安装Gliderlabs/Registrator

Gliderlabs/Registrator 可检查容器运行状态自动注册,还可注销 docker 容器的服务到服务配置中心,目前支持 Consul、Etcd 和 SkyDNS2

docker run -d \

--name=registrator \

--net=host \

-v /var/run/docker.sock:/tmp/docker.sock \

--restart=always \

gliderlabs/registrator:latest \

--ip=192.168.86.30 \

consul://192.168.86.20:8500

参数解释

–net=host:把运行的docker容器设定为host网络模式。

-v /var/run/docker.sock:/tmp/docker.sock :把宿主机的Docker守护进程(Docker daemon)默认监听的Unix域套接字挂载到容器中。

–restart=always:设置在容器退出时总是重启容器。

–ip:刚才把network指定了host模式,所以我们指定ip为宿主机的ip。

consul:指定consul服务器的IP和端口

测试服务发现功能

在registrator服务器上创建

docker run -itd -p:83:80 --name test-01 -h test01 nginx

docker run -itd -p:84:80 --name test-02 -h test02 nginx

docker run -itd -p:88:80 --name test-03 -h test03 httpd

docker run -itd -p:89:80 --name test-04 -h test04 httpd

-h:设置容器主机名

验证http和nginx服务是否注册到consul,在浏览器中输入http://192.168.86.20:8500

部署consul-template

Consul-Template是一个守护进程,用于实时查询Consul集群信息,并更新文件系统上任意数量的指定模板,生成配置文件。更新完成以后,可以选择运行 shell 命令执行更新操作

准备template nginx模板文件

在consul服务器上操作

vim /opt/consul/nginx.ctmpl

#定义一个nginx upstream简单模板

upstream http_backend {

{{range service "nginx"}}

server {{.Address}}:{{.Port}};

{{end}}

}

#定义一个server,监听端口8000,反向代理到upstream

server {

listen 8000;

server_name localhost 192.168.86.20;

access_log /var/log/nginx/dzd.com-access.log;

index index.html index.php;

location / {

proxy_set_header HOST $host;

proxy_set_header X-Real-IP $remote_addr;

proxy_set_header Client-IP $remote_addr;

proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

proxy_pass http://http_backend;

}

}

编译安装nginx

yum -y install pcre-devel zlib-devel gcc gcc-c++ make

useradd -M -s /sbin/nologin nginx

tar zxvf nginx-1.12.0.tar.gz -C /opt/

cd /opt/nginx-1.12.0/

./configure --prefix=/usr/local/nginx --user=nginx --group=nginx && make -j && make install

ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/

配置nginx

vim /usr/local/nginx/conf/nginx.conf

添加虚拟主机目录

http { include mime. types; include vhost/*. cont; default_type application/octet-stream;

}

#创建虚拟主机目录

mkdir /usr/local/nginx/conf/vhost

#创建日志文件目录

mkdir /var/log/nginx

#启动nginx

Nginx

配置并启动template

unzip consul-template_0.19.3_linux_amd64.zip -d /opt/

cd /opt/

mv consul-template /usr/local/bin/

前台启动template服务,注意启动后不要中止进程(ctrl+c)

consul-template --consul-addr 192.168.86.20:8500 \

--template "/opt/consul/nginx.ctmpl:/usr/local/nginx/conf/vhost/dzd.conf:/usr/local/nginx/sbin/nginx -s reload" \

--log-level=info

再开一个终端查看生成配置文件

vim /usr/local/nginx/conf/vhost/dzd.conf

访问template-nginx

在Registrator服务器上

docker ps -a

docker exec -it test-01 bash

echo “this is test1 web” > /usr/share/nginx/html/index.html

exit

docker exec -it test-02 bash

echo “this is test2 web” > /usr/share/nginx/html/index.html

exit

浏览器访问http://192.168.86.20:8000,多次刷新

http://www.dtcms.com/wzjs/315750.html

相关文章:

  • 用html5做的网站网络运营推广是做什么的
  • php网站开发班开发一个网站的步骤流程
  • 网站开发可以入无形资产吗网络公司推广方案
  • 阿里云网站建设与发布题库上海网络推广招聘
  • 玄武模板网站制作报价沈阳网页建站模板
  • 学勇建站买卖网交易平台
  • 我帮诈骗团伙做诈骗网站获利职业技能培训
  • 辽宁建设工程信息网官网新网站如何进入健康码防疫核验一体机
  • 公司网站首页怎么设置前端seo优化
  • 北京微网站建设设计服务百度云网盘资源链接
  • 商务网站开发考题百度推广开户
  • 龙华建设局网站网站排名大全
  • 自己做个网站多少钱网络推广和网站推广平台
  • 美国网站域名后缀深圳博惠seo
  • 漳州市住房城乡建设局网站公关公司经营范围
  • 网站备案注销流程网络营销ppt课件
  • wordpress 网站描述珠海seo推广
  • 怎么做外围网站代理合肥seo招聘
  • 服装手机商城网站建设优化设计六年级下册数学答案
  • 阿里企业邮箱客服电话seo搜索引擎优化人才
  • 美国建网站的价格网络营销seo培训
  • 成都的网站建设开发公司国外网站推广公司
  • 怎么做二维码网站网站制作的基本流程
  • 成都访问公司网站亚马逊提升关键词排名的方法
  • 济南泰安网站建设公司万网域名交易
  • vs2105制作个人网站专业seo网络推广
  • 用符号做照片的网站怎么给自己的公司建立网站
  • 怎么做淘宝 天猫京东网店的网站网络营销平台的主要功能
  • 网站开发作品网络安全培训机构排名
  • 网站购物车设计全网营销平台