不要好奇为啥我这博客名字从编码妙妙屋变成了编程小屋。

那是因为我现在正在更新备案,编码妙妙屋这名字不能用,可是我以前的备案就是编码妙妙屋通过的,2019年迷惑行为+1

 

国庆啥都没干,笔记本也没有带回家,就纯玩了7天。太怠惰了,让我心有愧疚。

不过除了国庆假期之外我还是有在好好提升自己的,慢慢的缓缓地,每天都进步一点点。

淘宝工程师写的那本《深入分析 java web 技术内幕》 已经看了一半了,这本书有丶厚,400+页。说收获了什么还说不准,感觉知识并没有那么多,没有我当时看effective java和深入分析jvm的那种感觉。

 

话说我也一直想换下主题,主要是感觉本博客有丶太花里胡哨了,各种控件、图片啥的。我用的是共享虚拟主机,三天两头超出资源限制,有点顶不住。再加上万恶的换页面时歌也会跟着重新加载,让我很难受。

就一直想换个 pjax+极简的那种,就可以在页面跳转时歌曲不会变化,找了很久很久找到一个,不过还不够满足我的需求,所以我在其上进行了二次开发(魔改)

现在也在龟速修改中,至于最后改好了换不换我还不知道,看着来吧,换的代价也挺大的,主要是代码高亮这方面。 龟速修改的主题-> https://github.com/skypyb/pure-sky

阅读全文

说起Feign,那又是老东西了啊

我以前写Netfilx的时候就详细讲过Feign这玩意,其实用起来基本是一样的。

以前的文章地址 : 分布式微服务项目如何使用 Feign 实现声明式 REST 调用,以及自定义 Feign 配置

 

虽说切换到了Alibaba,但是也没啥变化,Feign该怎么用就怎么用,这就不详细说了。主要还是Sentinel

其实Sentinel 和Hystrix在代码里写起来也是一样的

首先肯定是要上pom.xml配置起来。加上对应的依赖。

 

接着写个Feign接口

调用的话就是这样子调用:

 

哎,观察我的NacosHelloFeign类,这里可以看到,我这用了一个fallback回退,这个回退指定的就是Sentinel 的实现,其实写起来和特么的Hystrix一模一样。不得不说SpringCloud这一点是真的做得好。

 

当然,配置肯定是得配置的,他也不会直接就给你用了。

Sentinel 虽说是适配了 Feign 组件。但默认是关闭的。需要在配置文件中配置打开它,在配置文件增加以下代码:

 

其实到现在,整个Feign的使用+熔断限流机制就已经配完了。

不过Sentinel 比起Hystrix真正优越的地方还没来呢。

那就是: 控制台

这个控制台功能丰富、UI好看,比Hystrix那是高到不知道哪里去了。

要是用控制台,又不得不下载代码、打包、编译、运行。

 

所幸,我们有神器docker。我在docker hub 上找了个镜像,直接用就可以了,镜像地址:https://hub.docker.com/r/bladex/sentinel-dashboard

直接执以下命令,将sentinel控制台起开绑到8858端口

 

然后自己的yml文件也得改一下,毕竟都上控制台了,也得把自己这个服务给注册进去。

全部的yml文件如下所示:

可以看到配置里有一个 sentinel.transport.port属性,这个属性的意思是在自己本体这个服务里边,在开个新的端口专门用来和 Sentinel 控制台交互

Sentinel 控制台自身也有,默认端口则是8719

 

到这里就差不多了,所有东西打开,然后就可以访问 http://ip:8858 进入Sentinel 控制台,默认账号密码都是sentinel

有一点还需要注意,那就是为了确保客户端有访问量,Sentinel 会在客户端首次调用的时候进行初始化,开始向控制台发送心跳包。意思就是说你一个服务注册进我这来,首先还是看不到的。

你得先经过别人的请求,我才会去监控你,所以在服务刚启动的时候进入Sentinel 控制台找不到自己的服务是很正常的,只要启动时没有报错就不会有问题。

 

 

阅读全文

 

中秋佳节当天,人在异乡,无法和家人团聚,既然如此 不如提升一波自己的姿势水平,免得浪费这假期大好光阴。

说道微服务,现在可不流行Netfilx那一套了, 现在都9102年9月了,Spring Cloud Aliabba都已经孵化完毕,再加上Netfilx将他旗下的项目通通打入冷宫,现在在不学习SpringCloudAlibaba体系就赶不上时代的潮流了。 Netfilx那套体系我都搭过demo 写过博客,各种配置啊注意点啊都挺详细的,感兴趣的可以翻我以前的文章。

 

 

https://github.com/alibaba/spring-cloud-alibaba 这是 SpringCloudAlibaba 的项目 git。

这篇文章主要是开个SpringCloudAliabba篇的头,正式开始SpringCloudAlibaba的学习。

 

 

废话不多说,进入正题。

今天就从微服务最重要的地方开始,当然,也只能从这个地方开始。

那就是服务治理。

 

在 Spring Cloud Netflix 使用的是Eureka,而SpringCloudAlibaba 给我们提供的就是Nacos。

而且,Nacos比Eureka 更加强大,他还可以用来当配置中心。

 

这里我就简单的先完成他基本的职责:服务注册与发现。

首先nacos和Eureka有点不同。

他这个应用。不是我们自己写的,Eureka这个东西他需要我们自己创建一个应用。然后在编写代码,然后再将项目打包,在启动。

Nacos这个东西他和Zipkin有点像,是那种直接下载下来运行就完事了的。

 

我这儿用Docker来运行一个单机的 Nacos 镜像添加到8848端口(默认端口),当然,集群是肯定可以集群的,我这先不玩。

对了,不知道为啥我用网易的docker镜像地址下载会卡住,之后换了alibaba的来下就没问题了。

nacos登陆地址:http://ip:8848/nacos   默认账号密码是nacos/nacos

 

开启Nacos服务完毕后,就要开始写服务提供者和服务消费者了。

其实这俩都差不多,反正注册进服务治理中心了,A可以调用B的服务,自然B也可以调用A的服务,导入的配置也一样,我这就以服务消费者来举例子,避免贴两份基本相同的代码了。

 

我这使用的是最新的版本,要用就用最新的,不然没意思。我之前写的Netflix项目也是使用的最新的,当时用的是SpringCloud F版第三版

现在这个项目用的是SpringCloud G版第三版,SpringBoot 2.1.8.RELEASE

 

先创个依赖项目进行最基本的统一依赖管理

 

这个项目集成了SpringBoot 然后导入了SpringCloud的依赖和SpringCloudAlibaba的依赖。

依赖项目写完之后就是正式开工编写服务。

这个服务就直接继承我刚刚写的依赖项目就可以了。

 

然后在其中,引入web、actuator、test几个SpringBoot依赖。当然还有必不可少的SpringCloudAlibaba Nacos 依赖。

启动类:

 

这个启动类用了个 @EnableDiscoveryClient 这个注解,该注解是SpringCloud内置的,Nacos实现了这个注解,导入了Nacos的依赖的话就代表要注册进Nacos里边。

这样的好处就是以后要是换个新的服务治理中心,代码都不用改就可以轻易的更换,完美符合里式替换原则

 

 

既然能注册进去了,那接着还是老规矩,来个RestTemplate进行远程服务的调用,@LoadBalanced代表负载均衡,这些东西我以前的文章都有讲过啊,这儿就不详细说了。

 

这里就是编写一个控制层,来进行接口对外暴露,内部就是使用RestTemplate+LoadBalancerClient 来进行负载均衡的调用其他服务。

 

当然,yml是肯定要写的。

 

对了,这个management.endpoints 下边端点一定得打开。

因为 SpringCloudAlibaba 的 Nacos 在实现的时候提供了一个 EndPoint, EndPoint 的访问地址为 http://ip:port/actuator/nacos-discovery。

这玩意和服务注册发现息息相关,要是Nacos访问不了这个端点,那你就注册不了。

 

其实到这就差不多了,服务已经可以注册进Nacos里了,然后微服务之间的互相调用也是没有问题的,负载均衡也可以实现。

都没啥好说的,只要学会SpringCloud的思想,组件从一套换成另一套也就几十分钟的时间。

阅读全文

地址:

https://github.com/skypyb/code_demo/tree/master/spring-security-demo

内附 SQL 脚本

 

标准的RBAC权限设计,基于动态查询数据库的权限判定(以接口为粒度,即Request URL+Request Method)、基于JWT的认证授权流程。

当然,以上都是在SpingSecurity下实现的。

 

不得不吐槽一句:

SpingSecurity 真的是 Spring 全家桶中的异端邪教,有丶难用,研究好一段时间看了不少别人写的博客,甚至还打断点看了一些源码才给他理解。

想用这个东西是要学习的 ! 完全无法达到开箱即用的效果。比起这玩意,Spring、SpringMVC、SpringBoot、SpringData 这些一小时就能上手的比他不知道高到哪里去了。

给他写了30+个类,从上周写到这周,提交了20+个 commit 才将基本的认证、授权流程写完

不愧是一堆设计模式狂魔写出来的东西,我佛了

 

 

阅读全文

 

2019/08/02  我在上家公司上完了最后一天班,成为了无业游民。

此时,我在长沙,这个从小长到大的地方。

 

2019/08/09 ,人在上海,刚下飞机,台风就来了。

除了刚下飞机的这几小时有点小激动外,之后都非常平静,换了个地方也完全没什么违和感、不适应之类的。

 

现在,2019/09/03,上完了完整的一周班,现在已在是我在上海入职的第二周多

投简历求职面试找工作的时间,总共为一周,12号-19号,然后收offer、体检、入职,一切都是那么自然。

 

 

先随便扯扯,说说在这互联网寒冬期,我为什么离职。

之前入职的公司规模比较小,50人左右。刚进的时候还是比较有激情的。

当时加入这家公司最主要的就是该公司用的技术算比较新的,虽然项目规模小,但是也是实际在生产中用上了SpringCloud全家桶。

工作也没啥不满意的,一年下来没感觉有什么不舒服。 朝九晚六一周五天的标准工时。加班也不多,偶尔有几次加到过8点。

工资虽然不多,但是在长沙还是够得,刨去租房(40平整租)和吃喝,一个月还能剩下3K。

 

那为啥离职呢?

主要还是感觉没意思了。其实早就有这个心思,但还是苟到了待满一年,免得简历不好看。

同事们有点菜,待着待着我觉得我在同事间就变成最厉害的了,也不是自我感觉良好,当别人比你菜的时候是很容易感觉出来的。而你看着别人扭曲的代码都不好说什么,别人工作经验还比你长。

上司我至今还没看懂是个什么水平,听说6/7年开发经验,然后自己出来和曾今的大学同学一起创业。但我看其写出的代码跟一坨 ○ 一样,可拓展性可维护性吊差,没比我同事高到哪去。可能是长久将重心放在产品上技术退步了吧。对了,上司就是公司总经理之一,至于leader、架构师、产品、项目经理之类的通通都不存在。

也不是说没挑战,在这家公司里什么 缓存、消息、多线程、分布式任务调度 我全都是深度参与,其中权限啊、消息啊、服务拆分之类的基本上全是我来搭的,遇到的坑解决的坑也不少,反正前后端、运维、测试全是开发干。

我是感觉这项目规模估摸是上不去了,在搞一堆花里胡哨的又有什么用,每天写的代码慢慢的没有成就感了,待着待着就变成了摸鱼怪,天天上 v2 吹吹比,然后带薪拉屎,上司来个需求我做完了不吱声,让我在别人眼中处于一个可能有活可能很闲的中间态,以便我随时切换。

 

还有,主要是身边的同事压根不学习,都是crud boy,我待着实在难受,这种只有自己一个人在进步的感觉挺操蛋的,压根也不知道自己成长到了什么地步。

我也不说我每天都比昨天厉害,这是大佬才能做到的。但是我基本上每个星期都会比上个星期更厉害,我休息时间一直都在看视频、看书、写代码。看我这博客就知道了,每个月都会写个几篇文章,这个博客+github大概能代表我一半的水平?因为毕竟不是所有知识都会记录上来的。写个博客太费时费力了;花一小时能写一篇算不错的,还不算写的博客内容的学习时间。

 

 

瞎扯扯完了,进入正题。

 

1、现在互联网寒冬,一线城市面试都面啥玩意?

2、从二线城市到一线城市,换城市发展,如何才能按部就班不慌不乱稳中带皮?

 

 

 

 

先从 1 开始,我这面一周都被问了啥?

 

1.1 、java核心类库方面

HashMap底层必问,无非就是数组链表红黑树,何时树化(反树化)、然后 1.7/1.8 区别(扩容机制、底层结构)、put()方法源码、rehash

ArrayList/LinkedList: 这个没有问很深的,但也会问,反正我只会1.7/1.8区别,底层数据结构和初始化大小这些东西。ArrayList初始化1.7/1.8是有区别的,注意就行了

反射/注解/代理:这个一般说下作用和使用场景就差不多了,一般是拿来切入框架原理的,框架下面再说。

多线程: 重点,还好我这块比较扎实,因为之前公司多线程场景非常多,导致我找过很多资料学习。

synchronizd: 放在普通方法上和放在静态方法上区别是啥?锁的是什么对象?还有面试官问我 synchronized 底层,我差点笑出声。我给他把偏向锁/轻量级锁/重量级锁 讲的明明白白,对象头MarkWork经历了什么变化,线程栈怎么CAS操作对象头,如何复制对象头,为什么,JIT编译器会如何优化你的synchronized。反正吹了大概有好几分钟。

volatile: 这个关键字是干嘛用的? 在哪种场景用到?底层怎么实现的? 这玩意我也给吹的明明白白的,无非还是JMM这些东西

ConcurrentHashMap: 问底层源码,为什么快,分段锁机制,1.7/1.8区别,这个我纯靠背没啥好说的

Lock接口: 主要是问 ReentrantLock ,问我ReentrantLock和synchronized区别是什么,Condition怎么用,然后还有底层,对,这玩意也问底层我佛了,我就答了是用的AQS,CLH队列,具体怎么实现的我没正面回答混过去了,讲的不大好没怎么准备

pool: 线程池七种参数都是什么作用?底层是怎么实现的,根据参数的不同 execute()/submit() 时内部如何处理? 这个很简单,没啥好说的,随便准备一下就差不多了。

Queue/JUC工具:   没人问,亏我准备好久

JVM:  虽说我不知道问这个到底有什么意义,但是我基本都答的还行

基本上就是这几个:GC算法?内存管理? 对象啥时候进入老年代? java提供的命令?OOME怎么定位?7种垃圾收集器都是哪些?有什么用?对象如何被清理(可达性分析、二次标记,F-Queue)?JMM解决什么(然后引出happens-before、volatile,或者反向)?

上边这几个我全部都会,就7种垃圾收集器都是哪些,有什么用没记那么多就答了一点点,类加载没人问我,也没问更深了。还好我看过那本JVM神书

 

1.2、java框架

SpringMVC:   MVC设计思想? 请求整体流程? 这个一般就问一下过一下,还没有问我底层源码的。从DispatcherServlet –> return ModelAndView 这个流程说清就差不多了。

Spring:  这个就是万恶之源,啥东西都能被Spring引出来, 然后大家又都很熟,基本的东西压根不问你,问的全是底层源码/设计/思想,还好,偏偏我就看了相当一部分Spring底层源码,设计模式也实操的不少。

为什么要用Spring?带来了什么好处?

用了哪些设计模式? (然后就从你的回答中引出 你实际用过哪些设计模式?  然后你就得答你在原来的项目中是怎么用的)

然后就是Spring里策略、工厂、代理、单例都是怎么用的,你一说单例那就是就是单例如何保证线程安全呢?

然后根据你的回答再下一步(静态内部类 —> JVM类加载机制) (double check  –> volatile关键字)

你说工厂/策略,那工厂模式是在哪用?(BeanFactory) 策略?(Bean实例化)  然后就开始问细节

然后你说就是代理,哪用了代理? 有哪几种代理? AOP 用的什么?  AOP 然后就自然而然引出事务,然后就是事务实现?传播机制?

还有个比较过分的,让我说Bean出生到死亡整体流程。这玩意就挺恶心了,说个三五分钟压根不是什么事。

然后就是Spring植入的一些钩子作用,别的框架是如何利用的Spring提供的钩子,AOP是怎么用的Spring的钩子?

SpringCloud: 网飞全家桶,这个一般不问底层,主要是会问一些思想。还有组件有哪些,怎么用?分别在什么环境中用?微服务为了解决什么问题,又带来了什么麻烦。只要真的用过应该没问题的。无非就是这么几个

服务这么多  如何访问

服务这么多  如何通信

服务这么多 如何管理

服务挂了 怎么办

解决方案拿出来就完事了。

 

ORM : 我说我之前公司用的是JPA,然后他们就没问我了,就问了下我会不会MyBatis,我说会啊,使用肯定没问题,我用JPA又不是不写SQL,就没问我别的了。

 

1.3、中间件(数据库、缓存、消息)

主要还是问MySQL比较多啊:

MySQL索引?索引原理?画出来?(我没画出来,这也太过分了)

事务隔离级别?脏读幻毒不可读? 基础知识,秒了

InnoDB和MyISAM区别?使用场景?表级锁行级锁区别?乐观锁如何实现? 也是基本知识,都没啥好说的

然后就是手写SQL: 我面的好几家都是有面试题的,SQL肯定是有,偏偏还都是这种很类似的表(学生、课程、分数)

主要就是一些分组聚合操作,统计平均值、不及格人数、大于80分的人数、排序, 一般来说就是表连接一下,然后 group by + having + order by 几个子句一把梭,最后在SELECT子句后面在用几个函数(max()、avg())就差不多了

Redis的话有被问到这些,一般来说要配合自己项目讲

使用场景?为啥要用?是遇到了什么瓶颈?怎么用的?  该怎么说怎么说就行了。

如何实现分布式锁?有没有用到过?Redis实现的分布式锁会有什么问题?如何解决?

缓存穿透?(这个是这样问的,面试官问我有人脚本攻击你缓存不存在的数据怎么办)

至于底层实现的话没人问我,估计是看我经验也不多

RabbitMQ:

这个也是配合项目说

有什么用?(异步削峰解耦咯)

消息中间件解决了你们系统什么问题?怎么用的? 这个也是实际是怎样就怎么说就行了

rabbitmq的几种绑定方式?Exchange怎么转发消息的? 你在项目里具体是用哪几种?

至于死信和保证消息不丢失,都没人问,我是都准备了。

 

 

我简历上写了docker,基本每家公司都有问我,我只是自己捣鼓着玩而已,真没想到这玩意被问的挺频繁,我也没准备,就说下docker的基本操作。

然后还有linux基操、还有分布式事务。这些不在以上清单内的,我不知道该咋分。不好分类,就写这了

 

1.4、项目

其实这个没什么好说的,每个人做的项目都不同,在其中发挥出的作用也不同,我说了也没有参考意义,再说,说我离职公司的项目也不太好,好歹也是有保密协议的。

之所以还是摆在这,那是因为这个东西也是必问的,而且占了相当大的比重,需要好好的捋一捋之前自己写的功能才行。

 

 

写在这些面试经验的最后,说实话,我真没想到真的问的这么深,我还以为我的水平能超过大多数一年经验的人了。

一年经验都要会这么些东西吗?上海真的吓人。还好我这一年学的也多,想到这我不禁在思考,crud boy 现在来上海肯定很难受的,这要是3年经验,该问啥啊

 

2、从二线城市到一线城市,换城市发展,如何才能按部就班不慌不乱稳中带皮?

以我亲身经历来说。

 

1、最好准备 2w 元RMB,这个数字是比较稳的,主要是要苟过前面找工作的时间拿到入职后第一份工资。

2、准备面试,准备一个月巩固知识差不多了,学新知识肯定是来不及的,这个就看平日积累,该是什么水平就是什么水平,个把两个月提升不了多少

3、裸辞,这个没什么好说,换城市不存在骑驴找马的

4、裸辞的下周五,定为离开现城市的时间

5、裸辞之后的这一周,需要做这几件事情:

5.1、下载拉钩和BOSS,因为这两个是唯二可以上传附件简历的地方,我也投了58和智联,实在是没什么卵用。

5.2、裸辞后的这一周,投目标城市的简历,把面试安排在到达目标城市时间的下周,即周五到目标城市,周一开始面。要是有电话约你面试,先申请一下看是否先可以电面、视频面

5.3、下载租房软件、合租(有钱就随意了)  推荐zuber , 房源真实,真的好用!

5.4、约看房就完事了,约在到达目标城市的之后两天(周末),就选短租的。租2、3个月是最好。房租+押金这里可以轻松消耗掉近 10k(甚至更多)资金

5.5、开始进行面试,对,本地面试,找找手感,发现自己的不足,虽说很对不起别人公司

5.6、定好机票/火车票、 酒店

5.7、以上操作,同时进行

6、裸辞后的下周周五,到达了目标城市,此时先入住自己订的酒店

7、临时落脚点最重要,此时和之前约得房东/二房东/室友 见面看房,在周末两天内搞定房子

8、短租房子租好了,入住了,临时落脚点有了,周一就开始面试

9、一切准备完毕,进入面试流程,到面试流程就没什么好说的,白天面试晚上学习,没面试也学习,直到找到工作。

 

稳!反正我是一周就找到了。薪水相比原薪水 * 2.5 , 浮夸的一批,不过也算得上对得起我这一年努力,没什么觉得运气好或者捡到漏之类的,我面试时报的价都是这个数,还想着有个讨价还价的流程来着,没想到直接给了。本来想着要是一个月找不到就在降点,还是比较顺利的。

话说其中两个面试,轮番恶战,经历1轮笔试+4/5轮技术,都走到HR面前了,偏偏最后没给我offer,我都觉得稳得不行的。我觉得还是学历的锅好伐,真的太伤了(专科)

不过现在加入的公司,我觉得也挺不错,规模几千人,965工作制。我待的这一周来看并没什么加班,其中一天项目部门开了个会开到7点半,一群人回到办公室里,灯都被灭了

 

不过既然加入了大公司(我这里的大公司指的是人多的公司),那和以前的小公司的区别还是挺大的。

一个项目组,产品、UI、测试、实施、APP、小程序、后端、前端,全都有,这阵仗我是没体验过的。

然后就是规范,龟龟,我都被惊了,接口请求和响应都要定义专门的实体(REQ、RES)来传输,数据库查询出的是PO和DTO,其中DTO用于在控制层和服务层传输等等…我之前呆的公司都是数据库实体(PO)游离于各个层面..

每改个接口/新增接口都要写文档,说麻烦还真挺麻烦的。

需求方面,说实话,我才呆一周就感受到这方面的麻烦了。尼玛一个接口下来可能改n遍,产品,不愧是你.jpg

最后就是关于技术,我觉得…可能待在这种流程规范的公司在技术方面可能难以长进了…

因为我问了下同事,我问,你呆在这一年,干了些啥? 回答是:CRUD和复杂CRUD

我问:普通开发,能参与项目架构设计么、缓存、消息、多线程 普通开发能接触么?回答:没有,就是CRUD

WTF?我在之前的公司,那使用消息来进行任务调度的流程都是我一手搭的,缓存我也出了不少力,整体项目架构和流程我都是深度参与,UML图(我画的)我还保存着。多线程那更是基本上天天玩,这一下步入到无尽的CRUD之中去总感觉心情有点微妙…

 

 

 

 

 

 

 

 

阅读全文
EA PLAYER &

历史记录 [ 注意:部分数据仅限于当前浏览器 ]清空

      00:00/00:00