前言

作为一个典型的分布式项目,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. unity5x --------Music Mixer参数详解
  2. Python会干掉Java, 一统天下?
  3. linux图形界面鼠标变成小手_加载Linux系统,树莓派变身桌面电脑
  4. 2020年进军 AI,想年薪 40 万,没这个能力不行
  5. 多个计算机之间触发事件,相互通信的一种方法----通过文件的办法
  6. 图片:“给你五十行代码把我变成字符画!” 程序:“太多了,一半都用不完!”
  7. 369亿估值的AI市场下,中国AI学习者的野心与实力
  8. php汉字全是问号_PHP-PHP中文显示问号问题
  9. 微信小程序如何实现文本换行
  10. mysql 关闭一个实例_mysql 多实例关闭、启动、查看状态
  11. SQL Server中的快捷键
  12. leetcode--344. 反转字符串
  13. win7 更新service pack 1 失败解决办法
  14. 【Moasure魔尺】一款来自未来科技的测量设备
  15. BZOJ 4407: 于神之怒加强版|莫比乌斯反演
  16. 也谈男士品牌(综合版)
  17. top命令显示参数详解
  18. kettle的bug
  19. 远程 桌面 上, root 用户切换到普通用户, sudo su cheng 到普通用户。这样就可以进行pip了
  20. excel基础图形笔记(柱状图、条形图、折线图、饼图、散点图、箱线图、漏斗图)

热门文章

  1. 两张图搞定IJK源码
  2. Kyligence 荣获“高新技术企业”认证称号
  3. 【中科院】分子生物学-朱玉贤第四版-笔记-第 9 讲 重组 DNA 克隆技术
  4. 微生物实验室布局设计宗旨
  5. 1.用户界面原理和界面库编程模型
  6. 联发科嵌入式linux笔试
  7. comsol-超导线1
  8. SpringCloud Alibaba 之Nacos集群部署-高可用保证
  9. 基于sqlite3的利用数据库实现简单通讯录
  10. 绝对零度和自然常数e之间是否存在某种关系?