前言

作为一个典型的分布式项目,Kubernetes 的部署一直以来都是挡在初学者前面的一只“拦路虎”。尤其是在 Kubernetes 项目发布初期,它的部署完全要依靠一堆由社区维护的脚本。

其实,Kubernetes 作为一个 Golang 项目,已经免去了很多类似于 Python 项目要安装语言级别依赖的麻烦。但是,除了将各个组件编译成二进制文件外,用户还要负责为这些二进制文件编写对应的配置文件、配置自启动脚本,以及为 kube-apiserver 配置授权文件等等诸多运维工作。

这几年,在跟朋友探讨 k8s 落地时,也有一些问题被反反复复地提及,比如:

  • 为什么容器里只能跑“一个进程”?
  • 原先一直用的某个 JVM 参数,在容器里就不好使了?
  • 为什么 kubernetes 不能固定 IP 地址?容器网络连不通,该如何 debug?
  • k8s 中 statefulSet 和 operator 到底什么区别?pv 和 pvc 又该怎么用?

在这里分享我偶然间得到的一份文档,该文档将K8S分为理论和实践两个部分进行讲解,双管齐下,事半功倍,让我们来看看文档内容

/**

  • 5秒更新一次

*/

@Scheduled(fixedDelay = 5000)

public void doWork(){

if (!IPV4Util.ipCompare(this.jobService.serviceUrl(serviceName))) {

return;

}

System.out.println(serviceName+“服务,地址为:”+IPV4Util.getIpAddress()+“,正在执行task任务”);

}

}

定时任务中我们可以看到this.jobService.serviceUrl方法,这个方法的作用则是获取SpringCloud集群中服务信息,IPV4Util.ipCompare这个作用就是将当前服务IP和集群所有IP进行对比,如果当前服务IP是集群服务IP最小则返回true,反之返回false。

接下来我们再看一下,如果来获取SpringCloud集群信息:

@Service

public class JobServiceImpl implements IJobService {

@Autowired

private DiscoveryClient discoveryClient;

@Override

public List serviceUrl(String serviceName) {

List serviceInstanceList = discoveryClient.getInstances(serviceName);

List urlList = new ArrayList();

if (CollectionUtils.isNotEmpty(serviceInstanceList)) {

serviceInstanceList.forEach(si -> {

urlList.add(si.getUri());

});

}

return urlList;

}

}

其实主要还是用到DiscoveryClient类中方法,我们就可以很轻松获取到集群信息。

最后我们再来看看IPV4Util这个工具类到底是怎么进行对比的呢?

public class IPV4Util {

/**

  • @param ipAddress

  • @return

*/

public static long ipToLong(String ipAddress) {

long result = 0;

String[] ipAddressInArray = ipAddress.split(“\.”);

for (int i = 3; i >= 0; i–) {

long ip = Long.parseLong(ipAddressInArray[3 - i]);

// left shifting 24,16,8,0 and bitwise OR

// 1. 192 << 24

// 1. 168 << 16

// 1. 1 << 8

// 1. 2 << 0

result |= ip << (i * 8);

}

return result;

}

/**

  • @param ip

  • @return

*/

public static String longToIp(long ip) {

StringBuilder result = new StringBuilder(15);

for (int i = 0; i < 4; i++) {

result.insert(0, Long.toString(ip & 0xff));

if (i < 3) {

result.insert(0, ‘.’);

}

ip = ip >> 8;

}

return result.toString();

}

/**

  • @param ip

  • @return

*/

public static String longToIp2(long ip) {

return ((ip >> 24) & 0xFF) + “.” + ((ip >> 16) & 0xFF) + “.” + ((ip >> 8) & 0xFF) + “.” + (ip & 0xFF);

}

/**

  • 获取当前机器的IP

  • @return

*/

public static String getIpAddress() {

try {

for (Enumeration enumNic = NetworkInterface.getNetworkInterfaces();

enumNic.hasMoreElements(); ) {

NetworkInterface ifc = enumNic.nextElement();

if (ifc.isUp()) {

《一线大厂Java面试真题解析+Java核心总结学习笔记+最新全套讲解视频+实战项目源码》开源

Java优秀开源项目:

  • ali1024.coding.net/public/P7/Java/git

总结

蚂蚁面试比较重视基础,所以Java那些基本功一定要扎实。蚂蚁的工作环境还是挺赞的,因为我面的是稳定性保障部门,还有许多单独的小组,什么三年1班,很有青春的感觉。面试官基本水平都比较高,基本都P7以上,除了基础还问了不少架构设计方面的问题,收获还是挺大的。


经历这次面试我还通过一些渠道发现了需要大厂真实面试主要有:蚂蚁金服、拼多多、阿里云、百度、唯品会、携程、丰巢科技、乐信、软通动力、OPPO、银盛支付、中国平安等初,中级,高级Java面试题集合,附带超详细答案,希望能帮助到大家。

三年1班,很有青春的感觉。面试官基本水平都比较高,基本都P7以上,除了基础还问了不少架构设计方面的问题,收获还是挺大的。


经历这次面试我还通过一些渠道发现了需要大厂真实面试主要有:蚂蚁金服、拼多多、阿里云、百度、唯品会、携程、丰巢科技、乐信、软通动力、OPPO、银盛支付、中国平安等初,中级,高级Java面试题集合,附带超详细答案,希望能帮助到大家。

[外链图片转存中…(img-giuyjX0q-1649571935383)]

【面试题,一个星期4轮面试终拿下offer相关推荐

  1. 一个星期+4轮面试终拿下offer,极致干货

    阿里巴巴一面 自我介绍这个就不说了,开头必问的 说一下StringBuilder 和 StringBuffer Spring bean加载,实例化的过程 Spring AOP源码看过吗 java内存模 ...

  2. 字节跳动面试分享:一个星期+4轮面试终拿下offer面试建议

    最重要的话 2021年,真希望行业能春暖花开. 去年由于疫情的影响,无数行业都受到了影响,互联网寒冬下,许多程序员被裁,大环境格外困难. 我被公司裁掉后,便着急地开始找工作,一次次地碰壁,完全消磨掉了 ...

  3. 一个星期+4轮面试终拿下offer,进阶学习

    京东Java研发岗一面(基础面,约1小时) 自我介绍,主要讲讲做了什么和擅长什么 springmvc和spring-boot区别 @Autowired的实现原理 Bean的默认作用范围是什么?其他的作 ...

  4. 金三银四已接近尾声,进大厂,你准备好了吗?过五关斩六将七轮面试终拿互联网大厂Offer!!(建议收藏)

    大家好,我是冰河~~ 金三银四已接近尾声,进大厂,你准备好了吗?还是那句话:进大厂临时抱佛脚是肯定不行的,一定要注重平时的总结和积累,多思考,多积累,多总结,多复盘,将工作经历真正转化为自己的工作经验 ...

  5. 34k*16 薪,3年自动化测试历经3轮面试成功拿下华为Offer....

    前言 转眼过去,距离读书的时候已经这么久了吗?,从18年5月本科毕业入职了一家小公司,到现在快4年了,前段时间社招想着找一个新的工作,前前后后花了一个多月的时间复习以及面试,前几天拿到了华为的offe ...

  6. 4 年 Java 程序员十面阿里终拿下 offer,评级 P6+ 年薪 30-40w 无股票

    前言 每个程序员都有一个大厂的梦,而互联网大厂首当其冲自然是 阿里巴巴 最吃香,今天小编就来分享一个小伙进阿里巴巴的面经! "不想进大厂的程序员不是好程序员"哈哈哈 本人也是准备了 ...

  7. Java匹马行天下之一顿操作猛如虎,框架作用知多少?,3轮技术面和1轮Hr面拿下offer

    Spring Spring框架大家都听过吧,这个框架特别重要,在目前整个市场上来看的话是基本上有一个一统江湖的趋势.Spring是整个Java体系里使用频率最高,稳定性最好,而且在各个领域都能遇到的一 ...

  8. 大专学历走社招,两个部门,六轮面试,终与字节无缘

    这个面试机会来的挺意外的,先在 Boss 投递的简历,后再某客网看到了内推人的微信,加了微信问了下进度,挂了,内推人给我打电话根据简历简单询问了一下情况(内推人很谦逊,毕业于一所 211 大学,和我说 ...

  9. 中兴面试一个星期没有回音_如何在没有回声的情况下从亚马逊获取即时时尚建议...

    中兴面试一个星期没有回音 The Echo Look is a new device from Amazon that's able to take a look at your outfits an ...

最新文章

  1. centos7系统/etc/resolv.conf 配置DNS客户
  2. 高数第六章知识点框架
  3. rust实战入门到进阶(2)
  4. 【Qt】数据库用户接口层
  5. 2019年 ICPC亚洲区预赛(上海赛区)总结
  6. LeetCode 1769. 移动所有球到每个盒子所需的最小操作数(前缀和)
  7. AI、大数据、中台、AIoT、Fintech等十余场火热专题应有尽有,年度盛会BDTC 2019邀您共赴!...
  8. vs2012 使用mysql_vs2012连接mysql
  9. android-async-http框架之与网络进行数据交互
  10. 步进电机驱动控制器,电动云台控制。
  11. shell 脚本中常用的列表
  12. 移动安全-IOS逆向第三天——实战HOOK RSA/DES加密
  13. 【Hive】Hive数据倾斜以及解决方案
  14. Java实习生常规技术面试题每日十题Java基础(七)
  15. 递归合并PDF按文件夹和文件名生成目录
  16. .net core npoi word文字下划线
  17. 关于DMA,TCM和Cache
  18. VsCode c++环境配置(最新版)
  19. 给您支招,万网域名一元购,不再是梦
  20. 作为程序员,对中年危机的思考

热门文章

  1. 检测指定进程是否存在是否运行
  2. mysql%3e= %3c=某个时间_乐视网某站SQL注入3枚
  3. matlab联立两个方程组求解,实验二 Matlab求解数学问题(终稿)2
  4. 《请别叫我奥特曼,我只是你望尘莫及的神话》
  5. Python 十六进制,十进制转换
  6. IntelliJ IDEA 最佳使用方式
  7. 无效的源发行版,解决方案
  8. 如何应对学习知识、技能不用就会忘(节选自《穷查理宝典》第十一讲:人类误判心理学之不用就忘倾向)
  9. 《安全周报》2011年7月第3期
  10. [附源码]计算机毕业设计JAVA代驾服务系统