前言
作为一个典型的分布式项目,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)]