2019java开发面试问答合集(附答案)

  • 时间:
  • 浏览:3
  • 来源:神彩大发快3_彩神大发快3官方

zookeeper的核心是原子广播,采用zab协议,主要有恢复模式(选主)和广播模式(同步)

host模式

如保批量替换文本中的字符串

内网机器要访问外网,助于 snat,防火墙修改来源ip为公网出口ip发送请求包给外网,外网机器接收到的请求包的来源是公网出口ip而有的是真正的内网ip

外网访问内网机器,助于 dnat,外网发送请求包目标地址是公网出口ip,防火墙根据路由修改请求包的目标为内网ip发送给内网机器,内网机器返回时防火墙修改源地址为公网出口ip返回给外网机器

docker

tcp/ip协议,三次握手,四次挥手

正向代理代理的是客户端,服务端我日后 知道真正的客户端是谁,场景如vpn

反向代理代理的是服务端,客户端我日后 知道真正的服务端是谁,场景如负载均衡

DNS

客户向本地dns服务器发起请求,本地dns服务器一层一层向上递归查询是否是 有域名解析,直到根服务器

根服务器返回顶级域的dns服务器地址给本地服务器,本地服务器迭代查询:根-顶级域-二级域-三级域,直到某个域服务器返回地址给本地服务器,本地服务器缓存该解析,否则返回给客户端

网络

和宿主机共用网络namesapce,端口直接使用宿主机的端口

other container模式

proxy_pass和rewrite的区别

客户端发起请求,发送fin报文,seq=x

服务端收到fin报文后,返回ack,此时ack=x+1,此步骤确认客户端已不让发送数据,否则服务端数据肯能没法 返回

服务端确认数据全版返回后,发送fin报文,seq=y,告诉客户端已处理完,后要 关闭

客户端返回ack=y+1,关闭连接

snat 和 dnat

客户端发起请求,发送syn报文,seq=x

服务端收到syn请求后,返回ack,此时ack=x+1,否则也返回1个多syn,seq=y

客户端收到syn后,返回ack,此时ack=y+1,连接建立

四次挥手

docker run = 创建容器docker create + 启动容器docker start

尽量在同一层运行更多的命令

肯能copy,add,run都会生成新的层,尽量使用run命令执行copy和add,如wget

移除编译打包依赖

使用小体积的 Alpine 基础镜像

docker的网络模式

分布式事务缘何做

分布式系统的cap理论,c一致性,a可用性,p分区容错性,肯能网络和机器因为着不可控很多p是一定要保障的,大伙儿儿都知道cap后要 了并肩满足,很多后要 了在c和a中选泽,否则有base理论,ba基本可用,s软情况报告(在最终一致前允许所处不一样的情况报告),e最终一致

集群中有 一种角色,leader,follower和observer,leader负责写操作,保证集群事务的顺序性,follower参与选举,observer负责读操作。后要 了当集群初始化和领导者抛妻弃子多数派支持都会所处领导者选举。

COPY指令助于将构建命令所在的主机本地的文件或目录,克隆qq到镜像文件系统。

ADD指令不仅助于将构建命令所在的主机本地的文件或目录,日后 能 够将远程URL所对应的文件或目录,作为资源克隆qq到镜像文件系统,还后要 解压压缩文件并把它们打上去到镜像中。

如保缩小docker镜像的体积

proxy_pass请求在后台跳转,不影响浏览器url

rewrite会发起3xx请求,影响浏览器url

nginx和tomcat的区别

将1个多大的系统拆分成多个细小的子系统,子系统之间通过网络通信的构成的大系统称为分布式系统。

域名正向解析和反向解析

使用场景

配置管理,肯能强一致性,后要 存放集群配置

集群管理,有新机器加入时在指定目录创建临时znode,否则集群所有机器对目录创建watch,当有机器断连时临时znode会自动删除,集群机器收到通知

分布式锁,集群机器并肩创建znode,创建成功的抢到锁,zonde删除释放锁

队列,采用编号znode,按照编号顺序依次执行

集群

采用基于字节的桶排序将数字分到不同的桶中,比如找到第k大数,则先找出每个桶中的第k大数,在比较。

整形是4byte,有32位,先按高八位建25十个 桶

肯能内存后要 了2g,则每次读取2g的数据遍历放进 25十个 桶中,并统计25十个 桶的量,2g读取事先将每个桶的数据导出到磁盘,循环读完10g数据。

这时根据25十个 桶的计数计算出中位数在哪个桶,否则刚开始建后续8位的桶,直到最后低8位也分完,这事先对桶内数据进行快排即可。

如保实现分布式锁

zookeeper

2pc,两阶段提交,服务a发prepare请求给协调器,协调器将请求写到本地日志,否则发送prepare给这些各服务,执行者收到请求后执行本地事务,但不让commit,否则将结果返回给协调器,协调器判断所有的返回肯能都成功则让所有执行者提交commit,肯能有失败的则全版回滚。

消息表,服务a在发起事务的事先执行本地事务的消息并肩写入消息表否则发送消息给服务b,服务b在完成本地事务后回消息给服务a调度器清除消息表,肯能没法 清除,则事务调度器读退还 息表发送消息给服务b,这就助于 服务b有幂等性

消息事务,消息事务是通过消息里边件实现的之类2pc功能比如rocketmq,服务a提交prepare给mq,否则执行本地事务,肯能失败则回滚,肯能成功则确认prepare消息,mq大概事务调度器会定期扫描prepare消息询问发送方是否是 要发送消息,而消费方肯能失败则助于 老是重试

TCC事务补偿,先锁住资源,否则使用锁住的资源执行业务逻辑,肯能失败则释放资源,肯能成功则落盘。

分布式cap,base理论

数据库乐观锁,利用了mysql update行锁的特点,在每次update前先select出数据否则根据数据的版本进行update,肯能版本变了就不更新并把错误抛给用户重试最终达到一致。

redis setnx,当该key不所处时就设置value,肯能肯能所处该key了就直接返回。

zookeeper 后要 了重复创建同1个多节点,创建持久结点时助于 主动删除结点释放,创建临时结点时断开连接就会释放

有哪些是分布式系统,分布式原理是有哪些

有哪些是docker容器,有哪些是docker镜像

助于 java学习路线图的私信笔者“java”领取哦!另外喜欢这篇文章的后要 给笔者点个赞,关注一下,每天都会分享Java相关文章!还有不定时的福利赠送,包括采集的学习资料,面试题,源码等~~

sed -i "s/x/y/g" *

1个多文件中后要 使用vim

tr命令替换

aws gsub函数

常用的查看cpu,内存,网络,磁盘的命令有有哪些

Docker镜像用于创建容器。使用build命令创建镜像,否则在使用run启动时它们将生成容器。

Docker容器包括应用tcp连接及其所有依赖项,但与这些容器共享内核,作为主机操作系统上用户空间中的独立tcp连接运行。

docker run和docker start有有哪些区别

和host模式很像,日后 共用的是事先容器的网络namespace

10G整数文件中寻找中位数肯能第K大数

三次握手

nginx是http server,常用做静态内容服务和代理服务器,直接外来请求转发给里边的应用服务器(tomcat,Django等)

tomcat是1个多application server,更准确的说是1个多servlet/jsp应用的容器,处理http请求并生成动态页面。

正向代理和反向代理

docker file COPY 和 ADD的区别

正向解析是指根据域名找到ip地址

反向解析是根据ip地址找到域名,通常用来屏蔽某个ip上的域名肯能邮件

1个多域名解析的过程

事务有十个 行态acid

top

查看cpu命令:mpstat

查看内存:free

查看网络:netstat lsof查看端口,统计句柄

查看磁盘:df du fdisk

nginx

a:原子性,事务中的操作不可分割,要么并肩成功,要么并肩失败

c: 一致性,数据库中的数据日后 全版的,也中有 各资源情况报告的一致

i:隔离性,事务之间要有当事人的工作空间,后要 了相互干扰

d:持久性,事务完成后数据要落盘

数据库的事务是使用undo和redo日志做的,undo会记录未提交操作的数据用来回滚,redo记录已提交操作的数据落盘。

常用的分布式事务有几种依据:

原理