V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX  ›  LeegoYih  ›  全部回复第 31 页 / 共 42 页
回复总数  821
1 ... 27  28  29  30  31  32  33  34  35  36 ... 42  
2022-09-15 13:50:59 +08:00
回复了 hhhhhh123 创建的主题 程序员 签名算法中的 密钥来自哪里?
加签和加密的使用场景是不一样的

MD5:例子中是为了防止报文被篡改,服务端拿到的报文会再生成一遍签名,和客户端传入的签名进行匹配,不匹配说明报文被中间人篡改了(或者是 bug ),就可以拒绝该请求。

RSA:私钥加签,公钥验签;公钥加密,私钥解密。
通常用于双方都有开发能力的场景,比如你想调用支付宝的 OpenAPI ,在注册商家时,会和你交换公钥,这样就可以安全的交互了。
打开 Chrome devtool ,把 Disable cache 勾上再试试
2022-09-15 11:34:13 +08:00
回复了 yiplee 创建的主题 MySQL 为什么这个简单的查询在 MySQL 8.0.25 这么慢?
试试用 force index
或者 order by (id+0)
2022-09-15 10:51:15 +08:00
回复了 Mr0C 创建的主题 程序员 被优化了
我想被裁
2022-09-15 09:40:43 +08:00
回复了 kalman03 创建的主题 分享创造 一个更好用的 Maven 搜索引擎
2022-09-11 00:16:32 +08:00
回复了 bestcondition 创建的主题 问与答 如何理解 elasticsearch 数据库的 index
没必要强行用数据库的思维来使用 es ,这只会让初学者更加困惑,index 就是表示一种(一类)东西,从字面意思去理解即可。


为什么删除 type 可以看官方的解释: https://github.com/elastic/elasticsearch/blob/6.5/docs/reference/mapping/removal_of_types.asciidoc


谷歌机翻:

为什么要删除映射类型?

最初,我们谈到索引类似于 SQL 数据库中的数据库,类型相当于表。

这是一个糟糕的类比,导致了错误的假设。在 SQL 数据库中,表是相互独立的。一个表中的列与另一个表中的同名列无关。对于映射类型中的字段,情况并非如此。

在 Elasticsearch 索引中,不同映射类型中具有相同名称的字段在内部由相同的 Lucene 字段支持。换句话说,使用上面的示例,用户类型中的 user_name 字段与 tweet 类型中的 user_name 字段存储在完全相同的字段中,并且两个 user_name 字段在两种类型中必须具有相同的映射(定义)。

例如,当您希望 delete 成为同一索引中一种类型的日期字段和另一种类型的布尔字段时,这可能会导致挫败感。

最重要的是,在同一索引中存储具有很少或没有共同字段的不同实体会导致数据稀疏并干扰 Lucene 有效压缩文档的能力。

由于这些原因,我们决定从 Elasticsearch 中删除映射类型的概念。
2022-09-09 10:51:17 +08:00
回复了 peterZ 创建的主题 问与答 v 友帮我看看 这种情况要不要出去
风险大于收益,涨幅高于 30%可以考虑
不接熟人的活,发生这种情况,有些人不好意思开口,有些吵了一架朋友关系破裂,很现实。
如果是不认识的客户,可以想说什么就说什么,不给钱就不给源码,甚至留点后门。
2022-09-09 09:50:06 +08:00
回复了 TomVista 创建的主题 分享创造 手搓了一个 markdown 转 html
md 转 html 的开源项目太多了,docsify 之类的都已经很好用了,重复造这种轮子没什么意义,不如专注「写笔记」这件事本身。

如果是 html 转 md ,那倒是挺期待的。
2022-09-07 20:27:09 +08:00
回复了 optk 创建的主题 Java 大家好,请大家帮我分析一下我的 Java 水平
有代码参考吗
2022-09-07 10:57:29 +08:00
回复了 franklinre 创建的主题 问与答 请教秒杀抢购架构设计问题
秒杀的主要瓶颈在数据库,尤其是 MySQL 这种,所以目标是减少无效请求,保证请求到数据库层面的都是有效的,所以用缓存是必要的。


1. 客户端按钮设置隐式冷却

OP 描述的“提交信息后跳转到指定页面”,用户点提交按钮,可能会返回上一页,然后继续提交,这样会生成很多无效的订单,我抢消费券就是这么干的,所以需要加一个冷却时间,用户一直操作,实际上每秒可能只有一次请求

2. 网关层限流

按钮冷却只能防普通用户,网关限流用来防止懂技术的脚本哥,根据 IP 或者 UserId 进行限制请求次数。
或者直接对商品进行限流,例如:如果商品只有 10 个,每秒请求有 10000 个,那么实际上大部分请求都是无效的,允许每秒 100 - 1000 请求进来即可,其他的直接返回「已抢光」,这里可以使用「令牌桶」和「滑动窗口」算法。

3. 服务层

OP 说用 UUID ,我感觉还是后台生成比较好,收到请求后,生成一个 OrderId 放到缓存中,然后通过 MQ 异步创建订单,直接把 OrderId 返回给客户端,再提供一个接口让前端轮询缓存中的订单状态。
MQ 消费完成后更新缓存中的订单状态,客户端发现订单已创建,再去查询真正的订单详情。

服务层使用 Redis 维护库存数量的优点也很明显,如果库存没了直接返回即可,不用调数据库,保证数据库扣减库存、生成订单都是有效操作。

4. 数据库层

通过数据库自身的锁保证原子性,防止超卖,此时数据库基本没什么压力。
2022-09-05 09:18:55 +08:00
回复了 jwenjian 创建的主题 分享发现 好像有人拿到 tiktok 的后台源代码了
2022-09-04 17:21:40 +08:00
回复了 blacko 创建的主题 问与答 准备单人单车去阿里
还以为是那个阿里
2022-09-04 04:43:15 +08:00
回复了 shot 创建的主题 职场话题 蔚来汽车应聘总结: 高职薪招揽,低职薪 offer
150 - 200k 指的是 150 元 至 20 万元
用事务的目的是什么,如果只是为保证多条命令原子性,可以用 lua 脚本
2022-09-02 01:58:35 +08:00
回复了 frank1256 创建的主题 MacBook Pro MBP 越用越卡咋办
https://i.v2ex.co/DhWRddna.jpeg
mac 上用久了就内存泄露,在 Windows 上打开一堆 idea goland pycharm 都没什么问题,感觉是什么 bug
遇事不决看执行计划

set optimizer_trace="enabled=on";
select count(*) from tb_task where is_deleted = 0 and data_type != 1;
select * from information_schema.optimizer_trace;
set optimizer_trace="enabled=off";
1 ... 27  28  29  30  31  32  33  34  35  36 ... 42  
关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2945 人在线   最高记录 6679   ·     Select Language
创意工作者们的社区
World is powered by solitude
VERSION: 3.9.8.5 · 37ms · UTC 09:44 · PVG 17:44 · LAX 01:44 · JFK 04:44
Developed with CodeLauncher
♥ Do have faith in what you're doing.