web微服务规划
2023-12-13 05:48:27
一、背景
?通过微服务来搭建web系统,就要对微服务进行规划,包括服务的划分,每个服务和数据库的命名规则,服务用到的端口等。
二、微服务划分
1、根据业务进行拆分
如:
一个购物系统可以将微服务拆分为基础中心、会员中心、券中心,积分中心、商品中心、订单中心、支付中心等等微服务功能。
2、端口规划:
我们可以预定义本购物系统的微服务端口采用8300-8399端口。就是这100个端口够100个服务使用,做好编排和数字字典。
3、有的服务会共用一个数据库有的服务会单独使用数据库
我们可以规划:系统_功能 为命名规则的数据库
如:
shop_user 会员中心数据库
shop_order 订单中心数据库
等等
三、微服务网关配置文件样例
#应用ID
app:
id: xxxxxx
#端口
server:
port: 8300
#应用版本
deploy:
version: -v1
#服务名称
spring:
application:
name: base-gateway
cloud:
gateway:
discovery:
locator:
enabled: false # 这个配置是默认给每个服务创建一个router,设置为false防止请求默认转发到url中包含的微服务名上
#例:/auth/**会默认转发到服务auth下,而不是转发到配置的uri
lower-case-service-id: true # 微服务名称以小写形式呈现
routes:
- id: base-admin #微服务路由规则
uri: lb://base-admin #负载均衡,将请求转发到注册中心的base-admin
predicates: #断言,如果前端请求包含/base-admin/,则走这条规则
- Path=/base-admin/**
filters: # 过滤器 /base-admin/** 转发到 uri/**
- StripPrefix=1
- id: member-business
uri: lb://member-business
predicates:
- Path=/member-business/**
filters: # /member-business/** 转发到 uri/**
- StripPrefix=1
#spring boot 升级到2.6.x后需要增加的配置
main:
allow-circular-references: true
mvc:
pathmatch:
matching-strategy: ANT_PATH_MATCHER
#注册到eureka注册中心
eureka:
instance:
prefer-ip-address: true
instance-id: ${spring.cloud.client.ip-address}:${server.port}
client:
service-url:
defaultZone: ${eureka.defaultZone}
#集成apollo配置中心
apollo:
bootstrap:
enabled: true
namespaces: application,txyunjdbc.yml,redis.yml,ctgmember.yml,weixin.yml,cloudflashpay.yml
meta: http://member-config:8080
management:
endpoint:
gateway:
enabled: true
endpoints:
web:
exposure:
include: gateway #禁止外界访问 Spring Cloud Gateway actuator 端点
#日志级别配置
logging:
level:
root: INFO
cn.ctg.member.dao: DEBUG
文章来源:https://blog.csdn.net/dongjing991/article/details/134950254
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!