Docker简单部署Traefik微服务网关

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
注册配置 MSE Nacos/ZooKeeper,118元/月
简介: Docker简单部署Traefik微服务网关

什么是Traefik?

Traefik 是一款开源的反向代理与负载均衡工具,它监听后端的变化并自动更新服务配置。Traefik 最大的优点是能够与常见的微服务系统直接整合,可以实现自动化动态配置。目前支持 Docker、Swarm,Marathon、Mesos、Kubernetes、Consul、Etcd、Zookeeper、BoltDB 和 Rest API 等后端模型。

什么是微服务网关?

微服务网关是整个微服务API请求的入口,可以实现过滤Api接口。并且可以实现用户的验证登录、解决跨域、日志拦截、权限控制、限流、熔断、负载均衡、黑名单与白名单机制等。

Docker部署服务器

  1. Consul (测试的版本为v1.11.4)
docker pull bitnami/consul:latest
docker pull bitnami/consul-exporter:latest
docker run -itd \
--name consul-server-standalone \
-p8300:8300 \
-p8500:8500 \
-p8600:8600/udp \
-eCONSUL_BIND_INTERFACE='eth0' \
-eCONSUL_AGENT_MODE=server \
-eCONSUL_ENABLE_UI=true \
-eCONSUL_BOOTSTRAP_EXPECT=1 \
-eCONSUL_CLIENT_LAN_ADDRESS=0.0.0.0 \
    bitnami/consul:latest
  1. Traefik (测试的版本为v2.5.6)
docker pull traefik:latest
docker run -itd`    --name traefik-server `--link consul-server-standalone `    --add-host=host.docker.internal:host-gateway `-p8080:8080 `    -p 80:80 `-v /var/run/docker.sock:/var/run/docker.sock `    traefik:latest --api.insecure=true --providers.consul.endpoints="consul-server-standalone:8500"

管理后台

加入路由配置

在这里我使用了Consul作为远程配置中心,配置以KV的方式存储,可登陆consul的管理后台添加配置,Traefik默认是监控配置改变的。

traefik/http/routers/myrouter-1/rule PathPrefix('/')
traefik/http/routers/myrouter-1/entryPoints/0 http
traefik/http/routers/myrouter-1/service myservice-1
traefik/http/services/myservice-1/loadbalancer/servers/0/url http://host.docker.internal:8100

简单的Go服务示例

packagemainimport (
"fmt""net/http")
funcHelloHandle(whttp.ResponseWriter, r*http.Request)  {
_, _=fmt.Fprint(w, "hello kitty")
}
funcmain() {
http.HandleFunc("/hello", HelloHandle)
ife :=http.ListenAndServe(":8100", nil); e!=nil{
panic(e.Error())
    }
  • 原始服务器的访问地址是:http://localhost:8100/hello
  • 通过网关访问的地址是:http://localhost/hello

注意的点

  • 在这里我使用了Consul作为远程配置中心,另外Etcd等也可以。
  • 因为我网关跑在了Docker下,而http服务器跑在了宿主机上,因此需要--add-host=host.docker.internal:host-gateway以期Traefik能够访问宿主机。
目录
相关文章
|
6天前
|
人工智能 API
阿里云微服务引擎及 API 网关 2024 年 6 月产品动态
阿里云微服务引擎及 API 网关 2024 年 6 月产品动态
101 14
|
4天前
|
监控 负载均衡 API
探索微服务架构下的API网关设计
【7月更文挑战第19天】在云原生时代,微服务架构以其灵活性和可扩展性成为企业数字化转型的优选。本文将深入探讨API网关在微服务架构中的核心角色,包括其设计原则、关键功能以及面临的挑战。我们将通过实例分析API网关如何提升系统的可维护性、安全性和性能,并讨论如何在复杂环境中实现高效的API管理策略。
79 9
|
1天前
|
监控 安全 前端开发
探索微服务架构中的API网关模式
【7月更文挑战第23天】在云原生时代,微服务架构已成为构建可扩展、灵活且容错的系统的标准方法。然而,随着服务的增多,如何有效地管理跨服务通信成为了一个挑战。API网关模式应运而生,作为微服务生态系统中的关键组件,它负责请求的路由、转发、过滤和加工处理。本文将从API网关的定义出发,深入探讨其在微服务架构中的应用,以及如何实现高效的服务治理。我们将通过实例分析来揭示API网关设计的最佳实践,并讨论其对系统性能、安全性和可维护性的影响。
|
1天前
|
弹性计算 负载均衡 监控
探索微服务架构下的API网关模式
在现代的分布式系统中,微服务架构已经成为了主流。随着服务的不断增多,如何高效地管理这些服务之间的通信成为了一个关键问题。本文将深入探讨API网关模式,一种有效的解决方案,它能够提供请求路由、负载均衡、认证授权和监控等功能。我们将通过对比分析、案例研究以及数据统计来展示API网关模式的优势,并讨论其在实际部署中的最佳实践和可能面临的挑战。
19 5
|
23小时前
|
缓存 监控 负载均衡
探索微服务架构中的API网关模式
在微服务架构的海洋中,API网关如同一座灯塔,指引着服务间的通信。本文将深入探讨API网关的设计哲学、关键功能以及在实际应用中的考量因素。通过对比分析,我们将揭示API网关如何在提高系统可维护性、增强安全性和优化性能方面发挥其不可或缺的作用。此外,文章还将提供实践指南,帮助读者在构建或改进微服务架构时,做出明智的API网关选择和部署决策。
|
22小时前
|
负载均衡 监控 安全
探索微服务架构中的API网关模式
在微服务的大潮中,API网关扮演着至关重要的角色。它不仅是客户端与各个微服务之间的桥梁,更是性能优化、安全加固和协议转换的关键节点。本文将深入探讨API网关的核心概念,分析其在微服务架构中的重要性,并结合实例展示如何有效设计和管理API网关,以及如何通过网关解决跨域资源共享(CORS)和认证授权的挑战。
|
2天前
|
测试技术 Linux Docker
【好玩的开源项目】Docker部署cook菜谱工具
【7月更文挑战第19天】Docker部署cook菜谱工具
15 1
|
6天前
|
负载均衡 安全 API
探索微服务架构中的API网关模式
【7月更文挑战第18天】在微服务架构中,API网关不仅是流量的守门人,更是服务的协调者。本文将深入探讨API网关的核心作用、设计原则以及实现策略,揭示其在微服务生态系统中不可或缺的地位。通过案例分析,我们将一窥API网关如何优雅地处理服务发现、负载均衡、认证授权等关键任务,同时确保系统的弹性和安全性。
|
5天前
|
监控 Java 微服务
Spring Boot微服务部署与监控的实战指南
【7月更文挑战第19天】Spring Boot微服务的部署与监控是保障应用稳定运行和高效维护的重要环节。通过容器化部署和云平台支持,可以实现微服务的快速部署和弹性伸缩。而利用Actuator、Prometheus、Grafana等监控工具,可以实时获取应用的运行状态和性能指标,及时发现并解决问题。在实际操作中,还需根据应用的具体需求和场景,选择合适的部署和监控方案,以达到最佳效果。

热门文章

最新文章