你的位置:首页 > 信息动态 > 新闻中心
信息动态
联系我们

tedu springcloud day08 学习总结

2021/12/29 18:36:28

将yml配置文件配置到nacos配置中心中:

第一步添加pom文件中nacos依赖

<dependency>
    <groupId>com.alibaba.cloud</groupId>
    <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>

 第二步:修改yml配置文件

server:
  port: 9000
spring:
  application:
    name: sca-gateway #可以省略的
  cloud:
    #虽然网关没有在nacos进行注册,但是这个子项目sca-gateway在nacos进行注册了所以得启动nacos
    nacos:
      discovery: #注册和发现
        server-addr: localhost:8848
      config:
        server-addr: localhost:8848
        file-extension: yml
    sentinel:
      transport:
        dashboard: localhost:8180
      eager: true # 服务启动的时候sentinel控制台看到的服务信息
#    gateway: #网关配置
#      routes: #配置网关路由规则 #路由配置(routes下可以有多个路由,用id作为唯一标识)
#        - id: route01  #路由id,自己指定一个唯一值即可
#          #lb表示负载均衡
#          uri: lb://sca-provider #网关帮我们转发的url,请求转发路径,一般请求访问的是网关,网关会帮忙转达的
#          #url是uri的一个子集
#          predicates: ###断言(谓此):匹配请求规则(定义转发条件,只有谓词所有条件都满足才会请求抓发)
#            - Path=/nacos/provider/echo/**  #请求路径定义,此路径对应uri中的资源,(**)代表多级目录
#            # - Header=X-Request-Id, \d+
#            # - Method=Get
#            # - Query=token. \d+
#          filters: ##网关过滤器,用于对谓词中的内容进行判断分析以及处理,这也是局部过滤器,针对于具体(当前)路由进行设计,谓词条件为true时则执行这里的filter
#            - StripPrefix=1 #转发之前去掉path中第一层路径,例如nacos,去除前缀过滤器,这里的1就是去除path的第一层目录

#sca-provider:
#  ribbon: #ribbon是一个负载均衡组件,是Ribbon组件中提供了IRule接口及相关实现
#    NFLoadBalancerRuleClassName: com.netflix.loadbalancer.RandomRule
#流程分析: RoutePredicateHandlerMapping-->PathRoutePredicateFactory-->Xxx WebHandler-->Filters()

 

第三步:在nacos的public命名空间中创建sca-gateway.yml配置,内容如下:

spring: 
 cloud: 
  gateway: #网关配置
  routes: #配置网关路由规则 #路由配置(routes下可以有多个路由,用id作为唯一标识)
    - id: route01  #路由id,自己指定一个唯一值即可
      #lb表示负载均衡
      uri: lb://sca-provider 
      #网关帮我们转发的url,请求转发路径,一般请求访问的是网关,网关会帮忙转达的
      #url是uri的一个子集
      predicates: ###断言(谓此):匹配请求规则(定义转发条件,只有谓词所有条件都满足才会请求抓发)
        - Path=/nacos/provider/echo/**  #请求路径定义,此路径对应uri中的资源,(**)代表多级目录
        # - Header=X-Request-Id, \d+
        # - Method=Get
        # - Query=token. \d+
      filters: 
        - StripPrefix=1

说明,此配置添加后,可以将bootstrap.yml中网关部分的配置注释掉。

第四步:启动nacos,sentinel,provider,gateway服务,然后进行访问测试。

单点登录系统

单点登录,英文是 Single Sign On(缩写为 SSO)。即多个站点共用一台认证授权服务器,用户在其中任何一个站点登录后,可以免登录访问其他所有站点。而且,各站点间可以通过该登录状态直接交互

设计方案:

        用户登陆成功以后,将用户信息存储到token(令牌),然后写到客户端进行存储。

说明,在这套方案中,用户登录成功后,会基于JWT技术生成一个token,用户信息可以存储到这个token中.后续用户在访问资源时,对token内容解析,检查登录状态以及权限信息,无须再访问数据库.

 

第一步:新建一个maven工程

第二步:添加pom依赖

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.jt</groupId>
    <artifactId>02-sso</artifactId>
    <version>1.0-SNAPSHOT</version>
    <!--maven父工程的pom文件中一般要定义子模块,
    子工程中所需依赖版本的管理,公共依赖并且父工程的打包方式一般为pom方式-->

    <!--第一步: 定义子工程中核心依赖的版本管理(注意,只是版本管理)-->
    <dependencyManagement>
        <dependencies>
            <!--spring boot 核心依赖版本定义(spring官方定义)-->
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-dependencies</artifactId>
                <version>2.3.2.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>

            <!--Spring Cloud 微服务规范(由spring官方定义)-->
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>Hoxton.SR9</version>
                <type>pom</type><!--假如scope是import,type必须为pom-->
                <scope>import</scope><!--引入三方依赖的版本设计-->
            </dependency>

            <!--Spring Cloud alibaba 依赖版本管理 (参考官方说明)-->
            <dependency>
                <groupId>com.alibaba.cloud</groupId>
                <artifactId>spring-cloud-alibaba-dependencies</artifactId>
                <version>2.2.6.RELEASE</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>
    <!--第二步: 添加子工程的所需要的公共依赖-->
    <dependencies>
        <!--lombok 依赖,子工程中假如需要lombok,不需要再引入-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <scope>provided</scope><!--provided 表示此依赖仅在编译阶段有效-->
        </dependency>
        <!--单元测试依赖,子工程中需要单元测试时,不需要再次引入此依赖了-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope><!--test表示只能在test目录下使用此依赖-->
            <exclusions>
                <exclusion><!--排除一些不需要的依赖-->
                    <groupId>org.junit.jupiter</groupId>
                    <artifactId>junit-jupiter-engine</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
        <!--其它依赖...-->
    </dependencies>
    <!--第三步: 定义当前工程模块及子工程的的统一编译和运行版本-->
    <build><!--项目构建配置,我们基于maven完成项目的编译,测试,打包等操作,
    都是基于pom.xml完成这一列的操作,但是编译和打包的配置都是要写到build元素
    内的,而具体的编译和打包配置,又需要plugin去实现,plugin元素不是必须的,maven
    有默认的plugin配置,常用插件可去本地库进行查看-->
        <plugins>
            <!--通过maven-compiler-plugin插件设置项目
            的统一的jdk编译和运行版本-->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-compiler-plugin</artifactId>
                <!--假如本地库没有这个版本,这里会出现红色字体错误-->
                <version>3.8.1</version>
                <configuration>
                    <source>8</source>
                    <target>8</target>
                </configuration>
            </plugin>
        </plugins>
    </build>
</project>

第三步:导入数据库

source d:/jt-sso.sql

第四步:创建一个子模块sso-system

第五步:添加pom依赖

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>02-sso</artifactId>
        <groupId>com.jt</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>sso-system</artifactId>

    <!--工程中所有依赖都需要写道dependencies元素中-->
    <dependencies>
        <!--1.数据库访问相关-->
        <!--1.1 mysql 数据库驱动-->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
        </dependency>
        <!--1.2 mybatis plus 插件-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.4.2</version>
        </dependency>
        <!--服务治理相关-->
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
        </dependency>
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
        </dependency>
        <!--Web 服务相关-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <!--服务的限流-->
<!--        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-sentinel</artifactId>
        </dependency>-->
    </dependencies>

</project>

第六步:创建并编写启动类

第六步:测试数据库连接是否成功,创建一个测试类进行测试