微服务架构

微服务架构

微服务

强调是一个服务的大小,关注的是一个点
专注个体,每个个体完成一个具体的任务或功能

微服务架构

一种架构模式,单一应用划分一组小的服务,服务之间相互配合,为用户提供最终价值。

SpringCloud和SpringBoot区别?

  • SpringBoot专注于快速方便的开发单个个体服务;

  • SpringCloud关注全局微服务的协调和整理,它将SpringBoot开发的一个个单体微服务整合起来;

  • SpringBoot可以独立使用开发,但是SpringCloud离不开SpringBoot,属于依赖关系;

  • SpringBoot属于一个科室,SpringCloud是综合医院

Spring boot跨域

Controller 类 加 @CrossOrigin

mybatis-plus配置 mapper xml

mybatis-plus:
  mapper-locations: classpath:mybatis/mapper/*.xml mybatis/mapper

前端数组对象传递

使用axios发出跨域请求,跟的参数,不允许是数组的格式
xxx?ids=[7,9]!也就是
不能使用 paramrs: JSON.stringfy(array)
改为xxx?0=7&1=9

解决方案

springmvc /springboot 接收List 入参_xu990128638的专栏-CSDN博客_springboot接收list参数

qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'indices' })
// 'a[0]=b&a[1]=c'

qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'brackets' })
// 'a[]=b&a[]=c'

qs.stringify({ a: ['b', 'c'] }, { arrayFormat: 'repeat' })
// 'a=b&a=c'

方案1

npm install qs
import qs from 'qs'


paramrs: qs.stringfy(array)

// 请求 url,get请求,参数projectIds和 controll方法对应
http://192.168.0.182:8088/Artilce/xxx?projectIds=1,2,3

// controller方法
@RequestMapping("/analysis")
public JsonResult queryList ( @RequestParam("projectIds")  List<Long> projectIds) {
  ...
}

方案二
post方式

// 发出post请求,数据格式 json
{
    "projectIds":[2,3]
}

// controller
@RequestMapping("/analysis")
public JsonResult queryList (@RequestBody ReqVo req) {
    ....
}

@Data
Class ReqVo {
    private List<Integer> projectIds;
}

Redis缓存引入

依赖引入

<dependency> 
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-data-redis</art factId> 
</dependency>

配置redis

server:
    port: 8002 
spring:
    application:
    name: edu-course-boot 
    redis:
        host: 192.168.204.141
        port: 6379

redis放在service层

  1. redis查询数据
  2. redis没有,去mysql查询
  3. 将查询结果缓存在redis中
@Service 
public class CourseServiceImpl implements CourseService {

    @Autowired
    private CourseMapper courseMapper;

    @Autowired 
    private RedisTemplate<Object,Object> redisTemplate;

    @Override public List<Course> getAllCourse() { 
    //将redis内存中的序列化的集合名称用String重新命名(增加可读性)
         RedisSerializer rs = new StringRedisSerializer();
         redisTemplate.setKeySerializer(rs);
        
         System.out.println("查询redis");
        
         List<Course> list =        
(List<Course>)redisTemplate.opsForValue().get("allCourses");        if(list == null){ 
                //去数据库      
            System.out.println("====MySql数据库====");
        
            list = courseMapper.getAllCourse(); 

            // 把从数据库查询的集合放在redis内存中(key,value,过期秒数,秒的工具类)
            redisTemplate.opsForValue().set("allCourses", list,10, TimeUnit.SECONDS);
        }

        return list;
}

高并发下的双层检测锁

@Override 
public List<Course> getAllCourse() {
    RedisSerializer rs = new StringRedisSerializer(); redisTemplate.setKeySerializer(rs);

    System.out.println("查询redis");
    List<Course> list =(List<Course>)redisTemplate.opsForValue().get("allCourses"); 

        // 第一次检测
    if(list == null){ 
        //排队,让第一个人进,走一遍流程(后面的人就会走缓存了) 
        synchronized (this){ 
            list = (List<Course>)redisTemplate.opsForValue().get("allCourses"); 
                // 第二次检测
                if(list == null){ 
                //去数据库
                System.out.println("====MySql数据库====");
                list = courseMapper.getAllCourse(); 
                // 把从数据库查询的集合放在redis内存中 
                redisTemplate.opsForValue().set("allCourses", list,10,TimeUnit.SECONDS); 
            }
        }
    }
    return list;
}

保证redis中数据最新

  1. 如果课程中内容发生变化,更新 ,修改内容的时候,会先将redis中的相关集合删除。
  2. 然后将最新的数据保存到数据库 而查询数据时,因为redis中的数据已经删除了,所以会第一时间去数据库查询,保证数据是最新 的。

三步解决 IDEA ‘Error:java: 无效的源发行版: 11’
三步解决 IDEA ‘Error:java: 无效的源发行版: 11’_Java持续实践-CSDN博客

IDEA集成Docker部署微服务

docker 安装配置

yum -y install docker
systemctl start docker
vim /lib/systemd/system/docker.service
# 修改
ExecStart=/usr/bin/dockerd -H tcp://0.0.0.0:2375 -H unix://var/run/docker.sock

systemctl daemon-reload

#重启
service docker restart
# 查看端口是否开启
netstat -nlpt
# 验证端口是否生效
curl http://192.168.204.141:2375/info

idea安装docker插件

Tcp socket :tcp://ip:2375
setting —>docker Registry address :https://owi3yzzk.mirror.aliyuncs.com
连接服务器

docker mavne插件

<plugin>
    <groupId>com.spotify</groupId>
    <artifactId>docker-maven-plugin</artifactId>
    <version>1.0.0</version>
    <configuration>
        <!--镜像名称 laosun/test-docker-demo-->
        <imageName>laosun/${project.artifactId}</imageName>
        <!--标签版本-->
        <imageTags>
            <imageTag>latest</imageTag>
        </imageTags>
        <!--基础镜像,相当于Dockerfile里的from-->
        <baseImage>openjdk:11.0.9.1-jdk-buster</baseImage>
        <!--标签版本-->
        <maintainer>laosun angiersun@lagou.com</maintainer>
        <!--入口点,project.build.finalName就是project标签下的build标签下的filename标签内容,test-docker-demo-->
        <!--相当于启动容器后,会自动执行java -jar/test-docker-demo.jar-->
        <entryPoint>["java", "-jar", "/${project.build.finalName}.jar"]</entryPoint>
        <!--docker地址-->
        <dockerHost>http://xxx:2375</dockerHost>

        <!-- 这里是复制 jar 包到 docker 容器指定目录配置 -->
        <resources>
            <resource>
                <targetPath>/</targetPath>
                <!--复制的根目录,target-->
                <directory>${project.build.directory}</directory>
                <!--把哪个文件上传到docker,相当于Dockerfile里的add test-docker-demo.jar /-->
                <include>${project.build.finalName}.jar</include>
            </resource>
        </resources>
    </configuration>
</plugin>

对项目进行打包并构建镜像到docker上

mvn clean package docker:build

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容