2020年9月

无邀自来,其他的回答者应该都能解决了你很多问题, 但我现在有一个十分严重的问题。

让我们站在一个用户的角度去看这个问题。

先问一下其他答主,你们开这个网站用了多久?

测网速和打开网页不是同步操作

随手用网页工具测试一下:

太多超时

真的太久了,我就成功打开过一次,图片什么都没加载出来!

图都没出阿来..

你想想HR突然来兴致,打开你的网站,结果等了10s,还是白屏,重新打开两次,只有一个小点在左上角。

你觉得他还会要这个人吗?

我猜一下应该有这几种情况:

  1. 伺服器宽带太小。
  2. 伺服器限制访问请求。(我觉得不可能)
  3. 目前这个问题火了,你的网站太多人访问了,压力太大,没资源返回给我。

这个IP解析后得出的消息是广州腾讯云提供服务,估计你购买的是学生伺服器?

我个人建议你先更换为阿里云的轻量伺服器,因为总网路带宽有5M,这样能够输出的内容就会多很多。

或者

搭配CDN将你大量的静态数据分离出来,让你的伺服器主要输出动态数据。宽带压力就不会很大了。


其次,我个人建议你选择好一个方向,前端还是后端。

全栈虽好,但是不精通一个方向下的底层原理,你可能会在很多情况下,不清楚一个问题的最优解。

就假设你现在最大的意愿是前端,那你完全可以找一个开源的博客,为这个开源博客做皮肤套件,例如Typecho。

首先这样做你可以减轻你在后端的压力,可以将更多的精力放在前端上用户交互,界面设计等等。

而且Typecho支持插件开发,也就是说如果你想增强博客的功能,例如微信增强分享,QQ登录,评论检测,你都可以直接再开发后端,这样前后端你都可以涉猎。

对于你现在的前端设计,我个人还是觉得不错的,只是还有很多小细节需要注意,例如:手机端持续hover,阴影过大。

如果我是面试官,会给予机会,但个人还是需要能够知道一些快速开发的项目库。至于能有多少K,取决于你的周边范围和你目前能够知道的一个量,很多大学生会出现会使用无深度,往往就是给自己致命的一击。

毕业后找工作一时半会找不到确实会有焦虑感,但放轻松吧。(可能偏题)


这是一个可能不成熟但还在努力学习的我的回答,如果大家对于这个回答哪里需要完善的,欢迎指点,感谢!

查看原文

原文来源:脉脉-Redis 到底是单线程还是多线程?我要吊打面试官!

https://maimai.cn/article/detail?fid=1462427779&efid=1jt-7kkbTGNkYZgeOsFWow&use_rn=1

如有侵权,请在本站留言删除

最近发布的文章,其中有一道题:

Redis是多线程还是单线程?(回答单线程的请回吧,为什么请回,请往下看)

好些粉丝在后台问我:为什么请回,Redis不是单线程吗?

大家注意审题:Redis是多线程还是单线程?

这个问题你要从多个方面回答,如果你仅仅只回答 "单线程" 肯定是说不过去的,为什么呢?

所以今天,栈长利用工作时间紧急把这个问题紧急梳理了下,希望对大家有帮助。

1、Redis 单线程到底指什么?

没错,大家所熟知的 Redis 确实是单线程模型,指的是执行 Redis 命令的核心模块是单线程的,而不是整个 Redis 实例就一个线程,Redis 其他模块还有各自模块的线程的。

下面这个解释比较好:

Redis配图 (1).png

Redis基于Reactor模式开发了网络事件处理器,这个处理器被称为文件事件处理器。它的组成结构为4部分:多个套接字、IO多路复用程序、文件事件分派器、事件处理器。

因为文件事件分派器队列的消费是单线程的,所以Redis才叫单线程模型。

参考:http://www.jianshu.com/p/6264fa82ac33

2、Redis 不仅仅是单线程

一般来说 Redis 的瓶颈并不在 CPU,而在内存和网络。如果要使用 CPU 多核,可以搭建多个 Redis 实例来解决。

其实,Redis 4.0 开始就有多线程的概念了,比如 Redis 通过多线程方式在后台删除对象、以及通过 Redis 模块实现的阻塞命令等。

来源官方的解释:

Redis配图 (2).png

如果你能说到这里,对 Redis 单/多线程的理解也有你自己更多的认识了。

另外,前些天 Redis 6 正式发布了,其中有一个是被说了很久的多线程IO:
Redis配图 (3).png

这个 Theaded IO 指的是在网络 IO 处理方面上了多线程,如网络数据的读写和协议解析等,需要注意的是,执行命令的核心模块还是单线程的。

所以,你要是再把 Redis 6.0 网络处理多线程这块回答上了,你也不至于 "请回" 了。

之前有的人在后台和我杠精说:Redis 6 不是还没发布吗?

Redis 6 Beta 版本多线程这个说了多久了,作为一个程序员,如果这个还不能 get 到的话,那就有点 OUT 了,如果确实没听说还好,如果听说了,还要和我杠精,我就无言以对了,对于新技术的发展和学习不就是我们和面试官的谈资吗?!

3、为什么网络处理要引入多线程?

之前的段落说了,Redis 的瓶颈并不在 CPU,而在内存和网络。

内存不够的话,可以加内存或者做数据结构优化和其他优化等,但网络的性能优化才是大头,网络 IO 的读写在 Redis 整个执行期间占用了大部分的 CPU 时间,如果把网络处理这部分做成多线程处理方式,那对整个 Redis 的性能会有很大的提升。

网上也有对 Redis 单/多线程情况下的 get/set 操作性能做了对比:

Redis配图 (4).png

Redis配图 (5).png

参考:blog.csdn.net/weixin_45583158/article/details/100143587

从上面的性能测试图来看,多线程的性能几乎是单线程的两倍了,从该文章来看,这个只是简单的针对多线程性能的验证,并没有做很多严谨的测试,不能作为线上指标参考。

但可以知道的是,Redis 在网络处理方面上了多线程确实会让 Redis 性能上一个新台阶,不过 Redis 6.0 刚发布,不可能有企业马上上生产环境,可能还需要一段时间的优化和验证,我们再期待吧。

最后,目前最新的 6.0 版本中,IO 多线程处理模式默认是不开启的,需要去配置文件中开启并配置线程数,有兴趣的研究下吧。

总结

这篇文章只是对 Redis 单线程/多线程有个基本的认识和总结,吊打面试官可能还说不上,但是在面对面试官提问的时候,不要只是单纯的说单线程,你要回答的还要比这个更多。