HTTPS是怎么建立的?
HTTP + TLS = HTTPS
HTTP + TLS = HTTPS
顺序写、复制状态机、分区、多副本、时间轮
tcpdump、tshark、editcap、wireshark
跳表 + SSTable + LogCompact + 顺序写
单线程、全内存、AOF、RDB、单点、哨兵、集群
Golang的内存分配算法都是跟我学的
觉得TCP太慢了,何不试试我?
放开那个女孩,让我来
模式 实模式 特点 寻址特点 寻址范围为1MB,地址总线20位 寄存器只使用来16位,采用单一寄存器来寻址的话只能访问到2^16=64KB的空间 访问内存采用 段基址 + 段内偏移地址的方式 程序引用的地址都是真实的物理地址,不灵活也不安全 程序可以随意修改自己的段基址,任意访问改变所有内存 一次只能运行一个程序 地址总线只有20位,最大可用内存只有1M 保护模式 起源 CPU发展到32位后,推出保护模式,为了区别两种模式,便将之前的模式称为实模式。刚开机时,32位的CPU是先处于16位的实模式,再进入保护模式的 64位系统也一样吗? 地址总线32位 通用寄存器、标志寄存器、指令指针寄存器扩展到来32位 总结
Leetcode刷题见过我吧
ECDH算法 ECDH全称是椭圆曲线迪菲-赫尔曼秘钥交换(Elliptic Curve Diffie–Hellman key Exchange),主要是用来在一个不安全的通道中建立起安全的共有加密资料,一般来说交换的都是私钥,这个密钥一般作为“对称加密”的密钥而被双方在后续数据传输中使用。 算法流程 我们通过一个经典的场景,Alice和Bob要在一条不安全的线路上交换秘钥,交换的秘钥不能被中间人知晓。 首先,双方约定使用ECDH秘钥交换算法,这个时候双方也知道了ECDH算法里的一个大素数P,这个P可以看做是一个算法中的常量。 P的位数决定了攻击者破解的难度。还有一个整数g用来辅助整个秘钥交换,g不用很大,一般是2或者5,双方知道g和p之后就开始了ECDH交换秘钥的过程了。 Alice生成一个整数a作为私钥,需要利用p,g,a通过公式 g^a mod p = A 生成A作为公钥传递。 Bob通过链路收到Alice发来的p,g,A,知道了Alice的公钥A。这个时候Bob也生成自己的私钥b,然后通过公式 g^b mod p = B 生成自己公钥B。 Alice收到Bob发来的公钥B以后,同样通过 B^a mod p = K 生成公共秘钥K,这样Alice和Bob就通过不传递私钥a和b完成了对公共秘钥K的协商。 举个栗子 我们通过代入具体的数字来重复一下上面的过程: Alice和Bob同意使用质数p和整数g: p = 83, g = 8 Alice选择秘钥 a = 9, 生成公钥 g^a mod p = A 并发送 (8^9) mod 83 = 5 Bob选择秘钥 b = 21, 生成公钥 A^b mod p = K 并发送 (8^21) mod 83 = 18...
TCP退下,让我来!
留存计算 DELIMITER $$ CREATE DEFINER=`vpRoot`@`%` PROCEDURE `retention`(IN datestr VARCHAR(20)) BEGIN DECLARE s INT DEFAULT 0; DECLARE sdate VARCHAR(20) CHARACTER SET utf8; DECLARE country_zh VARCHAR(20) CHARACTER SET utf8; DECLARE pkg_name VARCHAR(50) CHARACTER SET utf8 ; DECLARE register_num INT DEFAULT 0; DECLARE keep_number_1 INT DEFAULT 0; DECLARE keep_number_2 INT DEFAULT 0; DECLARE keep_number_3 INT DEFAULT 0; DECLARE keep_number_7 INT DEFAULT 0; DECLARE keep_number_15 INT DEFAULT 0; DECLARE keep_number_30 INT DEFAULT 0; DECLARE report CURSOR FOR SELECT t5....
数组、栈、链表、队列、hash表…
Leetcode刷题见过我吧
B树和B+树
数据库锁 按锁的粒度划分(即,每次上锁的对象是表,行还是页):表级锁,行级锁,页级锁 按锁的级别划分:共享锁、排他锁 按加锁方式分:自动锁(存储引擎自行根据需要施加的锁)、显式锁(用户手动请求的锁) 按操作划分:DML锁(对数据进行操作的锁)、DDL锁(对表结构进行变更的锁) 最后按使用方式划分:悲观锁、乐观锁 共享锁 共享锁(S)表示对数据进行读操作。因此多个事务可以同时为一个对象加共享锁。(对于写作来说就是,如果文章处于「已发布」的状态,则所有人都可以同时看。) SELECT ... LOCK IN SHARE MODE; 排他锁 排他锁表示对数据进行写操作。如果一个事务对对象加了排他锁,其他事务就不能再给它加任何锁了。(对于写作来说就是,如果文章正在被修改的时候,其他的读者无法看到这篇文章,其他的编辑也无法修改这篇文章。) SELECT ... FOR UPDATE; 悲观锁 在关系数据库管理系统里,悲观并发控制(又名“悲观锁”,Pessimistic Concurrency Control,缩写“PCC”)是一种并发控制的方法,即为悲观的思想,认为并发问题总会出现,所以每次一个事务读取某一条记录后,就会把这条记录锁住,这样其它的事务要想更新,必须等以前的事务提交或者回滚解除锁。 悲观并发控制主要用于数据争用激烈的环境,以及发生并发冲突时使用锁保护数据的成本要低于回滚事务的成本的环境中。 乐观锁 总是假设最好的情况,每次去拿数据的时候都认为别人不会修改,所以不会上锁,但是在更新的时候会判断一下在此期间别人有没有去更新这个数据,乐观锁假设认为数据一般情况下不会造成冲突,所以在数据进行提交更新的时候,才会正式对数据的冲突与否进行检测,如果发现冲突了,则让返回用户错误的信息,让用户决定如何去做,一般来说可以使用版本号机制和 CAS 算法实现。 版本号机制 一般是在数据表中加上一个数据版本号 version 字段,表示数据被修改的次数,当数据被修改时,version 值会加一,当读取数据时,将 version 字段的值一同读出,数据每更新一次,对此 version 值加一。当我们提交更新的时候,判断数据库表对应记录的当前版本信息与第一次取出来的 version 值进行比对,如果数据库表当前版本号与第一次取出来的 version 值相等,则予以更新,否则认为是过期数据。 CAS 算法 即 compare and swap(比较与交换),是一种有名的无锁算法。 无锁编程,即不使用锁的情况下实现多线程之间的变量同步,也就是在没有线程被阻塞的情况下实现变量的同步,所以也叫非阻塞同步(Non-blocking Synchronization)。CAS 算法涉及到三个操作数: 需要读写的内存值 V 进行比较的值 A 拟写入的新值 B 当且仅当 V 的值等于 A 时,CAS 通过原子方式用新值B来更新V的值,否则不会执行任何操作(比较和替换是一个原子操作)。一般情况下是一个自旋操作,即不断的重试,与 version 事务机制类似,CAS 事务也是一种细粒度的锁。然而,version 为行级锁,粒度过大, 而 CAS 事务为列级锁,粒度更小。根据锁机制的一般原则,粒度越小,并发性能越高。...
我其实是个缝合怪,UDP + TLS + HTTP/2
IT界的老大难,面试手撕红黑树