- 博客(673)
- 收藏
- 关注
原创 人一生平均900个月
一、时间消耗表 算上每天中午休息,老年和婴儿的时间取平均,75年共计:8.5*365*75/24/30=323个月,27年。刷牙洗脸+泡脚洗澡+换衣服等等,每天1小时,35.5个月,3 年。每天1小时,1*365*70/24/30=35.5个月,3年。每天1.5小时,4.4年。上学,从小学到研究生共计20年,每学期21周,8*5*21*2*20/24/30=46.7个月,4年...
2018-11-01 12:37:34 2311
原创 RocketMQ控制台用java -jar方式启动存在缓慢的HTTP拒绝服务攻击
HTTP拒绝服务(DDoS)攻击是一种常见的网络攻击方法,它试图使目标服务器无法处理合法用户的请求。运行并且直接暴露在Internet上,可能会成为此类攻击的目标。Java应用程序如果通过。
2024-07-15 11:23:08 99
原创 Meilisearch的高可用方案
MeiliSearch 设计目标针对数据在 500GB 左右的搜索需求,极快,单文件,超轻量。Elasticsearch 做为老牌搜索引擎,功能基本满足,但复杂,重量级,适合大数据量。Meilisearch的高可用方案需要借助于 Meilisearch Cloud。所以,对于中小型项目来说,我们可以考虑另一种搜索引擎:MeiliSearch。
2024-06-21 09:47:47 222 1
原创 Protected and unprotected Meilisearch projects(/health)
MeiliSearch 设计目标针对数据在 500GB 左右的搜索需求,极快,单文件,超轻量。Elasticsearch 做为老牌搜索引擎,功能基本满足,但复杂,重量级,适合大数据量。所以,对于中小型项目来说,我们可以考虑另一种搜索引擎:MeiliSearch。
2024-06-12 15:44:22 232
原创 meilisearch,老版本的文档
MeiliSearch 设计目标针对数据在 500GB 左右的搜索需求,极快,单文件,超轻量。Elasticsearch 做为老牌搜索引擎,功能基本满足,但复杂,重量级,适合大数据量。所以,对于中小型项目来说,我们可以考虑另一种搜索引擎:MeiliSearch。
2024-06-12 15:35:28 224
原创 meilisearch的分页
MeiliSearch 设计目标针对数据在 500GB 左右的搜索需求,极快,单文件,超轻量。Elasticsearch 做为老牌搜索引擎,功能基本满足,但复杂,重量级,适合大数据量。所以,对于中小型项目来说,我们可以考虑另一种搜索引擎:MeiliSearch。
2024-06-12 15:31:54 203
原创 meilisearch的索引(index)的最佳实践
Elasticsearch 做为老牌搜索引擎,功能基本满足,但复杂,重量级,适合大数据量。MeiliSearch 设计目标针对数据在 500GB 左右的搜索需求,极快,单文件,超轻量。所以,对于中小型项目来说,我们可以考虑另一种搜索引擎:MeiliSearch。
2024-06-12 15:25:11 329
原创 生产环境部署meilisearch(Running a self-hosted Meilisearch project in production)
Elasticsearch 做为老牌搜索引擎,功能基本满足,但复杂,重量级,适合大数据量。MeiliSearch 设计目标针对数据在 500GB 左右的搜索需求,极快,单文件,超轻量。所以,对于中小型项目来说,我们可以考虑另一种搜索引擎:MeiliSearch。
2024-06-12 15:18:35 242
原创 meilisearch的Managing API keys,自己趟过的坑
Elasticsearch 做为老牌搜索引擎,功能基本满足,但复杂,重量级,适合大数据量。MeiliSearch 设计目标针对数据在 500GB 左右的搜索需求,极快,单文件,超轻量。所以,对于中小型项目来说,我们可以考虑另一种搜索引擎:MeiliSearch。
2024-06-12 11:01:58 269
原创 抛弃Elasticsearch ,MeiliSearch 从入门到入门,现在不精通
Elasticsearch 做为老牌搜索引擎,功能基本满足,但复杂,重量级,适合大数据量。MeiliSearch 设计目标针对数据在 500GB 左右的搜索需求,极快,单文件,超轻量。所以,对于中小型项目来说,我们可以考虑另一种搜索引擎:MeiliSearch。
2024-05-09 12:01:58 457 2
原创 MeiliSearch的安装
你可以使用 Docker 很方便的安装 MeiliSearch。如果你本地有 Rust 环境的话,也可以直接克隆项目源码运行。
2024-05-09 10:14:43 501
原创 Meilisearch vs Elasticsearch
2个所有引擎的比较(官方说法):Meilisearch vs Elasticsearch
2024-05-09 09:59:22 660 1
原创 如果你只想更新一条记录,请在在update语句末尾加个 limit 1
如果你只想更新一条记录,为了安全,请在在update语句末尾加个 limit 1
2023-03-03 14:02:06 1472 1
原创 linux命令3剑客(grep、sed、awk)
在操作linux过程中,当熟练掌握了grep、sed、awk这几个命令,可以极大的提升运维效率。==接下来慢慢实践
2022-06-02 17:31:22 202
原创 023 MySQL索引优化口诀-索引失效的常见情况
索引优化总结口诀:全值匹配我最爱,最左前缀要遵守;带头大哥不能死,中间兄弟不能断;索引列上少计算,范围之后全失效;like 百分写最右, 覆盖索引不写 * ;不等控制还有or,索引失效要少用;var引号不能丢, sql 高级也不难;1、全值匹配 :对索引中所有列都指定具体值。该情况下,索引生效,执行效率高2、最左前缀:又叫做最左匹配原则,最左匹配原则是和MySQL的InnoDB存储引擎的B+Tree的数据结构紧密关联的,可以去看这几篇博客:第1篇:MySQL的InnoDB存储引擎中.
2022-05-23 17:02:03 562
原创 004 ConcurrentHashMap 和 Collections.synchronizedMap(Map<K,V> m)的比较
写在前面的话,最好还是去看源码和源码上面的注释。1、ConcurrentHashMap的源码里面有个重要的:concurrencyLevel就是并发级别/** * A hash table supporting full concurrency of retrievals and * adjustable expected concurrency for updates. This class obeys the * same functional specification as {@
2022-04-18 13:57:07 285
转载 谈谈Java内存模型,你是不是开始说“Java 运行时内存区域”了?
我们常说的JVM内存模式指的是JVM的内存分区;而Java内存模式是一种虚拟机规范。Java虚拟机规范中定义了Java内存模型(Java Memory Model,JMM),用于屏蔽掉各种硬件和操作系统的内存访问差异,以实现让Java程序在各种平台下都能达到一致的并发效果,JMM规范了Java虚拟机与计算机内存是如何协同工作的:规定了一个线程如何和何时可以看到由其他线程修改过后的共享变量的值,以及在必须时如何同步的访问共享变量。原始的Java内存模型存在一些不足,因此Java内存模型在Jav...
2022-04-16 18:00:03 125
原创 014 到官网看Redis分布式锁的实现原理
读读Redis的官网,学第一手的资料:Redid官方文档地址Redis中国用户组:Redis中国用户组网址或者看看书《Redis 深度历险: 核心原理和应用实践》1、Redis官网上关于Redission的描述2、Redisson的GitHub上的说明进去之后内容很多,我们主要看分布式锁的部分:8.4. 红锁(RedLock)基于Redis的Redisson红锁RedissonRedLock对象实现了Redlock介绍的加锁算法。该对象也可以用来将多个RLock对象.
2022-04-16 05:42:37 744
原创 01 Dubbo框架设计
写在前面的话,虽然Dubbo已经发布了3.X的版本,但是很多公司的一些项目仍然使用Dubbo2.x的版本,所以这里我们看的是Dubbo2.x的版本。逛逛Dubbo的官网:Dubbo2.x的框架设计很多的时候面试官可能会问:假如让你设计一个RPC框架,你该如何设计,谈谈你的思路。对于这样的问题,就是些原理的东西,可以参考Dubbo的整体设计图图例说明:图中左边淡蓝背景的为服务消费方使用的接口,右边淡绿色背景的为服务提供方使用的接口,位于中轴线上的为双方都用到的接口。 图中从下至.
2022-04-15 13:31:39 139
原创 02 聊一聊已经停更的Ribbon
去Spring Cloud官网逛逛吧:Spring Cloud官网Ribbon停更了。。。目前为止,Ribbon已经停更,但是仍然有很多公司使用。负载均衡,它分为集中式负载均衡与进程内负载均衡。1、集中式负载均衡即在服务的消费方和提供方之间使用独立的负载均衡设施,可以是硬件,如F5 ,也可以是软件如nginx,由该设施负责把访问请求通过某种策略转发至服务的提供方。2、进程内负载均衡将负载均衡逻辑集成到消费方,消费方从服务注册中心获知有哪些地址可用,然后自己再从这些地址中选择出.
2022-04-14 14:21:53 2562
转载 013 Redis单机、主从、哨兵、集群
话说有一名意大利程序员,在 2004 年到 2006 年间主要做嵌入式工作,之后接触了 Web,2007 年和朋友共同创建了一个网站,并为了解决这个网站的负载问题(为了避免 MySQL 的低性能),于是亲自定做一个数据库,并于 2009 年开发完成,这个就是 Redis。这个意大利程序员就是 Salvatore Sanfilippo 江湖人称 Redis 之父,大家更习惯称呼他 Antirez。 Redis 技术越来越火爆,其超高的性能,简洁轻量的设计,易上手,分布式架构的支持,...
2022-04-14 10:39:12 336
转载 001 Kafka如何保证消息的顺序性
kafka的Consumer均衡算法在说顺序性这个问题之前,我们要先搞明白的是消费者是怎么消费分区上的数据。我们这里不详细讨论该算法,这不是本文的重点。简单的说:kafka的消费组的组员最多增加到和partition数量一致,超过的组员只会占用资源,而不起作用;kafka的partition的个数一定要大于消费组组员的个数,并且partition的个数对于消费组组员取模一定要为0,不然有些消费者会占用资源却不起作用;我们一般将消费组里组员的个数设置为和parti
2022-04-13 17:47:31 1702 1
原创 001 替代Eureka、Feign、Ribbon、Zuul、Hystrix、Config的解决方案
1、Spring Cloud官网:spring-cloud官网由于Eureka等闭源问题,不得不思考替代方案了。1、服务注册中心:Eureka:官方停止更新,并且已经有更好的替代产品可以使用。Nacos:来自于SpringCloudAlibaba,在企业中经过了百万级注册考验的,不但可以完美替换 Eureka,还能做其他组件的替换,所以强烈建议使用,是学习的重点。Consul:go语言开发的,也是一个优秀的服务注册框架,但是使用量较少,风头都被Nacos抢了。Zook...
2022-04-13 12:28:53 1562
原创 02 Nginx是如何做高可用集群的?
淘宝服务平台核心人员出品:Nginx开发从入门到精通Nginx的官方网站:Nginx的英文官方网站另外一篇还不错的博客:nginx配置高可用集群Keepalived是一款由C编写的软件,一般解决负载均衡器的高可用性问题,提供了负载均衡、健康检查和高可用的功能,高可用功能是由VRRP协议来实现的。...
2022-04-12 16:36:17 2802
翻译 01 Nginx是如何做限流的
淘宝服务平台核心人员出品:Nginx开发从入门到精通Nginx的官方网站:Nginx的英文官方网站还有一篇好的博文:Nginx限流模块初探1、ngx_http_limit_conn_module 先看看这个模块The ngx_http_limit_conn_module module is used to limit the number of connections per the defined key, in particular, the number of connections
2022-04-12 16:21:19 117
原创 012 Redis 的并发竞争问题是什么?如何解决这个问题(分布式锁)?了解 Redis 事务的 CAS 方案吗(WATCH)?
读读Redis的官网,学第一手的资料:Redid官方文档地址或者看看书《Redis 深度历险: 核心原理和应用实践》1、Redis 的并发竞争问题是什么?看到这个标题,有人可能会有疑问了,redis不是单线程的吗,怎么还会有并发竞争问题?其实是这样的,redis并发竞争是多个客户端并发写一个key,本来应该是先到的请求先写key,但可能由于网络环境差异,先发起的请求后到了,导致value最终被后发起的请求修改,最终数据错乱了。或者是多个客户端同时获取一个key,修改值后再写回去,只要
2022-04-11 10:18:17 2296 1
原创 011 如何保证缓存与数据库的双写一致性?先删缓存后更新数据库的数据不一致问题的处理
读读Redis的官网,学第一手的资料:Redid官方文档地址或者看看书《Redis 深度历险: 核心原理和应用实践》1、剖析一般来说,如果允许缓存可以稍微的跟数据库偶尔有不一致的情况,也就是说如果你的系统不是严格要求 “缓存+数据库” 必须保持一致性的话,最好不要做这个方案,即:读请求和写请求串行化,串到一个内存队列里去。串行化可以保证一定不会出现不一致的情况,但是它也会导致系统的吞吐量大幅度降低,用比正常情况下多几倍的机器去支撑线上的一个请求。2、Cache Aside Pattern
2022-04-09 11:06:35 315
转载 010 如何保证缓存与数据库的双写一致性?双写的四种情况
为了解决高并发的流量问题,通常我们都会添加缓存这一层,来扛住大量的读请求。虽然缓存能够帮数据库分担大量的读请求,但是也伴随着一个问题就是缓存中的数据怎么跟数据库中的数据保持一致,又是一个新问题数据实时性等级这里我们需要保证缓存和数据库的数据一致性,也可以根据数据所要求的实时性等级去评估,并不是所有的数据我们都需要保证强一致性,这里根据数据要求实时性不同大致分为2个等级:强一致性数据,弱一致性数据强一致性数据:比如一些支付数据,金额数据,涉及到钱的数据对实时性要求就比较...
2022-04-08 17:35:21 832
原创 009 谈谈Redis的雪崩、穿透和击穿,以及出现这些情况后的应对方案
读读Redis的官网,学第一手的资料:Redid官方文档地址或者看看书《Redis 深度历险: 核心原理和应用实践》
2022-04-08 10:31:39 207
原创 008 Redis 的持久化有哪几种方式?不同的持久化机制都有什么优缺点?持久化机制具体底层是如何实现的?
读读Redis的官网,学第一手的资料:Redid官方文档地址或者看看书《Redis 深度历险: 核心原理和应用实践》1、RDB、AOF(Redis官网中关于持久化的解释)Redis persistence | RedisHow Redis writes data to disk (append-only files, snapshots, etc.)Persistence refers to the writing of data to durable storage, such as
2022-04-06 16:34:38 1086
原创 007 Redis内存淘汰机制,引出LRU算法问题,简述LRU在常用框架中的使用
读读Redis的官网,学第一手的资料:Redid官方文档地址或者看看书《Redis 深度历险: 核心原理和应用实践》1、之前整理过2篇关于LRU的博客024 Java实现LRU(Least recently used,最近最少使用)算法 之 LinkedHashMap022 LRU算法用在哪些地方,LRU算法如何实现2、Redis官网中关于LRU的描述Approximated LRU algorithmRedis LRU algorithm is not an exact
2022-04-06 09:57:14 2253
原创 006 Redis的过期策略有哪些?内存淘汰机制有哪些?
读读Redis的官网,学第一手的资料:Redid官方文档地址或者看看书《Redis 深度历险: 核心原理和应用实践》1、redis 过期策略是:定期删除+惰性删除所谓定期删除,指的是 redis 默认是每隔 100ms 就随机抽取一些设置了过期时间的 key,检查其是否过期,如果过期就删除。假设 redis 里放了 10w 个 key,都设置了过期时间,你每隔几百毫秒,就检查 10w 个 key,那 redis 基 本上就死了,cpu 负载会很高的,消耗在你的检查过期 key 上了。注意,
2022-04-02 18:00:08 131
空空如也
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人