String pageKey = RedisKeyManagement.getKey(RedisKeyManagement.ACTIVITY_BAISHI_PAGE_CACHE, Arrays.asList(activityId.toString(),String.valueOf(current)));Object pageObj = redisService.get(pageKey);if(pageObj != null) { return ApiResult.success(pag
几乎搜遍了网上所有能找到的教程,比如windows下改文件夹的权限(NTFS格式下,只有windows旗舰版可以改,home版本没有这个选项),linux下更改为ext4格式,更改删除权限。以上方法都不行。 联系官网客服的方法都试过了,官方只说帮看看,要了一个邮箱就没信了,后来也没有接到邮件。 最后在B站上找到
软件系统设计:封底计算 系统设计 系统设计是一个设计软件系统元素的过程,如组件、架构、接口、模块、数据库类型等。然后定义不同组件如何相互交互的机制。这包括数据流和数据访问。 系统设计是一个非常广泛的话题,我只是试图触及冰山一角。 一个软件 系统架构 是一个 概念模型 这定
提高网站性能的 5 个快速步骤 您是否遇到过一个您没有费心优化的项目/网站,您需要在短时间内加快速度? 那么这篇文章可能会对你有所帮助! 有很多技术和模式可以加速 Web 应用程序的工作,但在本文中,我将考虑我个人认为最有效、最快速且易于实现的方法。 TL;博士 1.优化媒体 2.压缩文本
运用之妙,存乎一心。 计算机编程领域的基本思想,是大量实践与经验的提炼总结,是近乎于“道”的东西。有了思想的指引,就如同有高人指路,行不迷惑,遇事有法,运用之妙,存乎一心。 理解这些基本思想,就能构建牢固的编程思想体系,更好地理解和汲取各种技术机制和技术知识,因具体的技术机制和知
TCP头部格式:双方端口号,序列号,确认应答号,标志位(ACK,SYN,FIN),窗口大小 序列号:初始序列号为时间循环值,每加一次数据,就累加这次数据字节数,用于解决网络包乱序 确认应答号:下一次期望收到的序列号,在这之前的已经全部收到,不用再发了,用于解决丢包问题 TCP面向连接,何为连接:⽤于保证可靠性
# 查看系统版本 uname -a cat /proc/version cat /etc/redhat-release # 查看当前目录文件大小 du --max-depth=1 -h du -sh # 更新时区 cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime # 查看端口信息 fuser JmDiService.log netst
我们知道,高并发代表着大流量,高并发系统设计的魅力就在于我们能够凭借自己的聪明才智设计巧妙的方案,从而抵抗巨大流量的冲击,带给用户更好的使用体验。这些方案好似能操纵流量,让流量更加平稳地被系统中的服务和组件处理。 来做个简单的比喻吧。 从古至今,长江和黄河流域水患不断,远古
Django 本篇博客是我在B站学习的笔记。B站教程地址 Django介绍 起源 2005年发布,采用Python语言编写的开源框架。 早期的时候Django主做新闻和内容管理的 重量级的Python Web框架,Django配备了常用的大部分组件 组件 Django包含的组件如下: 基本配置文件/路由系统 模型层(M)/模板层
MyBatis一级缓存介绍 默认情况下,MyBatis只启用了本地的会话缓存,它仅仅对一个会话中的数据进行缓存。这也就是大家常说的MyBatis一级缓存,一级缓存的作用域是SqlSession。 MyBatis一级缓存的运行过程是这样的:执行SQL语句的过程中,首次执行它时从数据库获取的所有数据会被存储在一段
一、产品需求澄清、pm排期和任务分解 二、开发设计评审(研发、测试参与) (1)功能设计流程图 采用亿图图示梳理:系统与外部系统交互、系统模块之间流程、核心功能流程图 (2)数据库设计 从DDD角度界限上下文、er图、评审表结构设计是否合理、是否创建索引、数据量级别、是否需要
free链表:指向未使用的控制块与缓存页 hash表:key:表空间号+页号 value:缓存页 脏页:修改过的缓存页 flush链表:指向脏页 lru:缓存不够时,先删除最近最少使用的。 LRU链表:只要用到这个缓存页了,就把它置与lru链表头部 预读:mysql预判你会读后面那页,提前异步读取,但可能你并不会读,这会导致lru
说到Vue的钩子函数,可能很多人只停留在一些很简单常用的钩子(created,mounted),而且对于里面的区别,什么时候该用什么钩子,并没有仔细的去研究过 生命周期钩子: 这一比较简单 但是如果细究就回涉及到很多地方,比如 created,mounted什么时候开源调用某些函数之类的 这里先简略的写 用官
女朋友面试回来抱怨说会redis,面试官问了一堆redis Redis 优缺点及特点 什么是Redis?简述它的优缺点? Redis本质上是一个Key-Value类型的内存数据库,类似MemoryCache,整个数据库统统加载在内存当中进行操作,定期通过异步操作把数据库数据flush到硬盘上进行保存。因为是纯内
1、概述 MyBatis 是一款优秀的持久层框架 MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集的过程 MyBatis 可以使用简单的 XML 或注解来配置和映射原生信息,将接口和 Java 的 实体类 【Plain Old Java Objects,普通的 Java对象】映射成数据库中的记录 持
关于恶心人的屎山代码 最近在维护公司以前的代码,准确来说应该是重构,之前看这个项目的时候我还以为这玩意儿应该至少是7,8年前的代码了,然后看了一下 SVN(忽略为什么现在这公司在用 SVN,我也不知道呵呵). 呵呵,大部分的代码都是 2019 年的代码,我实在不能够想到 2019 年能将代码写成那个
1. happens-before规则https://blog.csdn.net/qq_39935047/article/details/120384799 2. Juc12_Volatile的可见性、不保证可见性、有序性、使用、内存屏障四大指令StoreStore、StoreLoad 、LoadLoad、LoadStorehttps://blog.csdn.net/TZ845195485/article/details/117601980 3.ja
3种优化思路: 尽量避免发送 HTTP 请求; 在需要发送 HTTP 请求时,考虑如何减少请求次数; 减少服务器的 HTTP 响应的数据大小; 一、尽量避免发送HTTP请求 实现方法: 对于⼀些具有重复性的 HTTP 请求采用 缓存技术 具体过程: 客户端收到第⼀个请求的响应后,可以将其缓存在本地磁 盘,下
在admin 下首先查询当前cache大小 db.serverStatus().wiredTiger.cache['maximum bytes configured']/1024/1024/1024 方法一: 修改配置文件mongod.conf 添加内容如下 storage: dbPath: /data/mongo journal: enabled: true #启用journal日志,false为关闭
1.sessionStorage:临时的会话存储 只要当前的会话窗口未关闭,存储的信息就不会丢失,即便刷新了页面,或者在编辑器中更改了代码,存储的会话信息也不会丢失。 2.localStorage:永久存储 会一直将数据存储在客户端的储存方式,即使关闭了浏览器,下次打开的时候仍然可以看到之前
以前古老的DOS操作系统,是单进行的系统。系统每次只能做一件事情,完成了一个任务才能继续下一个任务。每次只能做一件事情,比如在听歌的时候不能打开网页。所有的任务操作都按照串行的方式依次执行。 这类服务器缺点也很明显,等待操作的过长,无法同时操作多个任务,执行效率很差。 现
1. CPU缓存 CPU缓存分为3级结构: 寄存器 -> L1缓存(数据缓存 + 指令缓存) -> L2缓存 -> L3共享缓存 缓存的最小单位: 缓存行(64kb), 这意味着对于内存连续的数据结构, 一次会将64kb的元素载入数据缓存 好处是: 可以用来提升缓存命中率, 比如二维数组的行优先好于列优先遍历, 比
在了解一致性哈希算法之前,最好先了解一下缓存中的一个应用场景,了解了这个应用场景之后,再来理解一致性哈希算法,就容易多了,也更能体现出一致性哈希算法的优点,那么,我们先来描述一下这个经典的分布式缓存的应用场景。 场景描述 假设,我们有三台缓存服务器,用于缓存图片,我们为这三台
收录于合集 一年之前—— 未来两年内,系统预估的总订单数量可达一亿条左右。 按Mysql单表存储500万条记录来算,暂时不必分库,单库30个分表是比较合适的水平分表方案。 于是小灰设计了这样的分表逻辑: 订单表
SpringCache SpringCache是一个框架,实现了基于注解的缓存功能。SpringCache提供了一层抽象,底层可以切换不同的cache实现。具体是通过CacheManager接口来统一不同的缓存技术. CacheManager是Spring提供的各种缓存技术抽象接口. 针对不同的缓存技术需要实现不同的CacheManager: C