(十五) 整合spring cloud云架构 - commonservice-sso服务搭建(一)

简介: spring cloud云架构、

前面几篇我们已经介绍了Spring Cloud和oauth2的知识点,今天我们要利用Spring Cloud和oauth2进行commonservice-sso服务搭建,本节我们只是搭建commonservice-sso的基础平台,闲话少说,直接将步骤记录下来:

  1. 创建maven项目commonservice-sso,其中pom.xml文件配置如下:
<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>  
      
    <parent>  
        <groupId>com.ml.honghu</groupId>  
        <artifactId>commonservice</artifactId>  
        <version>0.0.1-SNAPSHOT</version>  
    </parent>  
  
    <artifactId>commonservice-sso</artifactId>  
    <packaging>jar</packaging>  
  
    <dependencies>  
        <dependency>  
            <groupId>org.springframework.cloud</groupId>  
            <artifactId>spring-cloud-starter-eureka</artifactId>  
        </dependency>  
        <dependency>  
            <groupId>org.springframework.cloud</groupId>  
            <artifactId>spring-cloud-starter-config</artifactId>  
        </dependency>  
        <dependency>  
            <groupId>org.springframework.boot</groupId>  
            <artifactId>spring-boot-starter-actuator</artifactId>  
        </dependency>  
        <dependency>  
            <groupId>org.springframework.boot</groupId>  
            <artifactId>spring-boot-starter-data-rest</artifactId>  
        </dependency>  
        <dependency>  
            <groupId>org.springframework.boot</groupId>  
            <artifactId>spring-boot-starter-web</artifactId>  
        </dependency>  
        <dependency>  
            <groupId>org.springframework.boot</groupId>  
            <artifactId>spring-boot-starter-security</artifactId>  
        </dependency>  
  
        <dependency>  
            <groupId>org.springframework.security.oauth</groupId>  
            <artifactId>spring-security-oauth2</artifactId>  
        </dependency>  
  
        <dependency>  
            <groupId>org.springframework.boot</groupId>  
            <artifactId>spring-boot-starter-test</artifactId>  
        </dependency>  
        <dependency>  
            <groupId>org.springframework.hateoas</groupId>  
            <artifactId>spring-hateoas</artifactId>  
        </dependency>  
        <dependency>  
            <groupId>org.springframework.boot</groupId>  
            <artifactId>spring-boot-starter-data-rest</artifactId>  
        </dependency>  
        <dependency>  
            <groupId>com.ml.honghu.common.framework</groupId>  
            <artifactId>common-framework-dao</artifactId>  
            <version>1.0.0-SNAPSHOT</version>  
        </dependency>  
        <dependency>  
            <groupId>org.springframework.boot</groupId>  
            <artifactId>spring-boot-starter-web</artifactId>  
        </dependency>  
        <dependency>  
            <groupId>org.springframework.boot</groupId>  
            <artifactId>spring-boot-starter-freemarker</artifactId>  
        </dependency>  
        <dependency>  
            <groupId>com.ml.honghu</groupId>  
            <artifactId>component-base</artifactId>  
        </dependency>  
        </dependency>  
    </dependencies>  
  
    <!-- 打包插件,其中repackage、true是专门打spring boot专用包 -->  
    <build>  
        <plugins>  
            <plugin>  
                <groupId>org.springframework.boot</groupId>  
                <artifactId>spring-boot-maven-plugin</artifactId>  
                <executions>  
                    <execution>  
                        <id>1</id>  
                        <goals>  
                            <goal>repackage</goal>  
                        </goals>  
                    </execution>  
                    <execution>  
                        <id>2</id>  
                        <goals>  
                            <goal>build-info</goal>  
                        </goals>  
                    </execution>  
                </executions>  
            </plugin>  
        </plugins>  
    </build>  
</project>  
  1. 配置bootstrap.yml文件
  application:  
    name: commonservice-sso  
  profiles:   
    active: dev,discoveryClient  
  cloud:  
    config:  
      discovery:   
        enabled: true  
        service-id: commonservice-config-server  
eureka:   
  client:  
    service-url:  
      defaultZone: http://honghu:123456@localhost:8761/eureka  
  instance:  
    prefer-ip-address: true  
  1. 配置项目启动文件
  
import org.springframework.boot.SpringApplication;  
import org.springframework.boot.autoconfigure.SpringBootApplication;  
import org.springframework.cloud.netflix.eureka.EnableEurekaClient;  
  
@SpringBootApplication  
@EnableEurekaClient  
public class SSOApplication {  
    public static void main(String[] args) {  
        SpringApplication.run(SSOApplication.class, args);  
    }  
}  
  1. 创建sso相关表:

oauth_access_token、oauth_approvals、

oauth_client_details、oauth_client_token、

oauth_code、oauth_refresh_token

脚本如下:

Navicat MySQL Data Transfer 
 
Source Server         : localhost 
Source Server Version : 50621 
Source Host           : localhost:3306 
Source Database       : honghu 
 
Target Server Type    : MYSQL 
Target Server Version : 50621 
File Encoding         : 65001 
 
Date: 2017-10-26 20:12:56 
*/  
  
SET FOREIGN_KEY_CHECKS=0;  
  
-- ----------------------------  
-- Table structure for `oauth_access_token`  
-- ----------------------------  
DROP TABLE IF EXISTS `oauth_access_token`;  
CREATE TABLE `oauth_access_token` (  
  `token_id` varchar(256) DEFAULT NULL,  
  `token` blob,  
  `authentication_id` varchar(128) NOT NULL,  
  `user_name` varchar(256) DEFAULT NULL,  
  `client_id` varchar(256) DEFAULT NULL,  
  `authentication` blob,  
  `refresh_token` varchar(256) DEFAULT NULL,  
  PRIMARY KEY (`authentication_id`)  
) ENGINE=InnoDB DEFAULT CHARSET=utf8;  
  
  
-- ----------------------------  
-- Table structure for `oauth_approvals`  
-- ----------------------------  
DROP TABLE IF EXISTS `oauth_approvals`;  
CREATE TABLE `oauth_approvals` (  
  `userId` varchar(256) DEFAULT NULL,  
  `clientId` varchar(256) DEFAULT NULL,  
  `scope` varchar(256) DEFAULT NULL,  
  `status` varchar(10) DEFAULT NULL,  
  `expiresAt` datetime DEFAULT NULL,  
  `lastModifiedAt` datetime DEFAULT NULL  
) ENGINE=InnoDB DEFAULT CHARSET=utf8;  
  
-- ----------------------------  
-- Records of oauth_approvals  
-- ----------------------------  
  
-- ----------------------------  
-- Table structure for `oauth_client_details`  
-- ----------------------------  
DROP TABLE IF EXISTS `oauth_client_details`;  
CREATE TABLE `oauth_client_details` (  
  `client_id` varchar(128) NOT NULL,  
  `resource_ids` varchar(256) DEFAULT NULL,  
  `client_secret` varchar(256) DEFAULT NULL,  
  `scope` varchar(256) DEFAULT NULL,  
  `authorized_grant_types` varchar(256) DEFAULT NULL,  
  `web_server_redirect_uri` varchar(256) DEFAULT NULL,  
  `authorities` varchar(256) DEFAULT NULL,  
  `access_token_validity` int(11) DEFAULT NULL,  
  `refresh_token_validity` int(11) DEFAULT NULL,  
  `additional_information` varchar(4096) DEFAULT NULL,  
  `autoapprove` varchar(256) DEFAULT NULL,  
  PRIMARY KEY (`client_id`)  
) ENGINE=InnoDB DEFAULT CHARSET=utf8;  
  
  
-- ----------------------------  
-- Table structure for `oauth_client_token`  
-- ----------------------------  
DROP TABLE IF EXISTS `oauth_client_token`;  
CREATE TABLE `oauth_client_token` (  
  `token_id` varchar(256) DEFAULT NULL,  
  `token` blob,  
  `authentication_id` varchar(128) NOT NULL,  
  `user_name` varchar(256) DEFAULT NULL,  
  `client_id` varchar(256) DEFAULT NULL,  
  PRIMARY KEY (`authentication_id`)  
) ENGINE=InnoDB DEFAULT CHARSET=utf8;  
  
-- ----------------------------  
-- Records of oauth_client_token  
-- ----------------------------  
  
-- ----------------------------  
-- Table structure for `oauth_code`  
-- ----------------------------  
DROP TABLE IF EXISTS `oauth_code`;  
CREATE TABLE `oauth_code` (  
  `code` varchar(256) DEFAULT NULL,  
  `authentication` blob  
) ENGINE=InnoDB DEFAULT CHARSET=utf8;  
  
-- ----------------------------  
-- Records of oauth_code  
-- ----------------------------  
  
-- ----------------------------  
-- Table structure for `oauth_refresh_token`  
-- ----------------------------  
DROP TABLE IF EXISTS `oauth_refresh_token`;  
CREATE TABLE `oauth_refresh_token` (  
  `token_id` varchar(256) DEFAULT NULL,  
  `token` blob,  
  `authentication` blob  
) ENGINE=InnoDB DEFAULT CHARSET=utf8; 

备注: oauth的相关表是用来存储用户的token信息和认证信息的。

本节搭建先搭建那么多,后面的业务代码太多,我们会在后面的章节中放出来。

从现在开始,我这边会将近期研发的spring cloud微服务云架构的搭建过程和精髓记录下来,帮助更多有兴趣研发spring cloud框架的朋友,大家来一起探讨spring cloud架构的搭建过程及如何运用于企业项目。

目录
相关文章
|
18天前
|
Cloud Native Java API
聊聊从单体到微服务架构服务演化过程
本文介绍了从单体应用到微服务再到云原生架构的演进过程。单体应用虽易于搭建和部署,但难以局部更新;面向服务架构(SOA)通过模块化和服务总线提升了组件复用性和分布式部署能力;微服务则进一步实现了服务的独立开发与部署,提高了灵活性;云原生架构则利用容器化、微服务和自动化工具,实现了应用在动态环境中的弹性扩展与高效管理。这一演进体现了软件架构向着更灵活、更高效的方向发展。
|
17天前
|
存储 数据可视化 Java
基于MicrometerTracing门面和Zipkin实现集成springcloud2023的服务追踪
Sleuth将会停止维护,Sleuth最新版本也只支持springboot2。作为替代可以使用MicrometerTracing在微服务中作为服务追踪的工具。
61 1
|
27天前
|
存储 Linux KVM
Proxmox VE (PVE) 主要架构和重要服务介绍
Proxmox VE (PVE) 是一款开源的虚拟化平台,它基于 KVM (Kernel-based Virtual Machine) 和 LXC (Linux Containers) 技术,支持虚拟机和容器的运行。PVE 还提供高可用集群管理、软件定义存储、备份和恢复以及网络管理等企业级功能。
569 7
|
1月前
|
Cloud Native Java 对象存储
面向未来的架构设计:Spring Cloud和Netflix OSS在云原生环境下的发展趋势
展望未来,随着5G、边缘计算等新技术的兴起,微服务架构的设计理念将会更加深入人心,Spring Cloud和Netflix OSS也将继续引领技术潮流,为企业带来更为高效、灵活且强大的解决方案。无论是对于初创公司还是大型企业而言,掌握这些前沿技术都将是在激烈市场竞争中脱颖而出的关键所在。
49 0
|
2天前
|
消息中间件 Kafka 数据库
微服务架构中,如何确保服务之间的数据一致性?
微服务架构中,如何确保服务之间的数据一致性?
|
10天前
|
Java Spring
Spring底层架构源码解析(三)
Spring底层架构源码解析(三)
|
10天前
|
XML Java 数据格式
Spring底层架构源码解析(二)
Spring底层架构源码解析(二)
|
13天前
|
存储 分布式计算 druid
大数据-155 Apache Druid 架构与原理详解 数据存储 索引服务 压缩机制
大数据-155 Apache Druid 架构与原理详解 数据存储 索引服务 压缩机制
32 3
|
13天前
|
JSON 前端开发 Java
Spring Boot框架中的响应与分层解耦架构
在Spring Boot框架中,响应与分层解耦架构是两个核心概念,它们共同促进了应用程序的高效性、可维护性和可扩展性。
38 3
|
19天前
|
Cloud Native Java 对象存储
面向未来的架构设计:Spring Cloud和Netflix OSS在云原生环境下的发展趋势
面向未来的架构设计:Spring Cloud和Netflix OSS在云原生环境下的发展趋势
36 1