可以在chrome上安装
可以在chrome上安装
kuberbetes-dashboard是K8S的管理工具,下面使用helm来进行部署,参考:
1 | https://artifacthub.io/packages/helm/k8s-dashboard/kubernetes-dashboard |
1 | helm repo add kubernetes-dashboard https://kubernetes.github.io/dashboard/ |
1 | helm search repo kubernetes-dashboard |
1 | helm install my-k8s-dashboard kubernetes-dashboard/kubernetes-dashboard |
超文本传输协议(HTTP)是用于客户端-服务器通信的协议或一组通信规则。当您访问网站时,您的浏览器会向 Web 服务器发送 HTTP 请求,该服务器将以 HTTP 响应进行响应。Web 服务器将以纯文本形式与您的浏览器交换数据。简而言之,HTTP 协议是为网络通信提供支持的底层技术。
安全超文本传输协议(HTTPS)是 HTTP 的一种更安全的版本或扩展。在 HTTPS 中,浏览器与服务器会在传输数据之前建立安全的加密连接。
HTTP 传输未加密的数据,这意味着从浏览器发送的信息可能会被第三方拦截和读取。这一过程并不理想,因此将其扩展成为 HTTPS,以便为通信再增加一层安全性。HTTPS 将 HTTP 请求和响应与 SSL 和 TLS 技术相结合。
SSL 和 TLS 参考:SSL 与 TLS 之间有何区别?
HTTPS 网站必须从独立证书颁发机构(CA)获取 SSL/TLS 证书。这些网站会在交换数据之前先与浏览器共享该证书,以建立信任。SSL 证书还包含加密信息,以便服务器和 Web 浏览器可以交换加密或刻意打乱的数据。
该过程的工作原理是:
既然是加密,那肯定是不希望别人知道我的消息,所以只有我才能解密,所以可得出公钥负责加密,私钥负责解密;
同理,既然是签名,那肯定是不希望有人冒充我发消息,只有我才能发布这个签名,所以可得出私钥负责签名,公钥负责验证。
参考:RSA的公钥和私钥到底哪个才是用来加密和哪个用来解密?
在HTTPS协议中,对称加密和非对称加密都发挥了重要的作用。具体来说,HTTPS在内容传输上使用的是对称加密。这意味着在通信过程中,发送方和接收方会生成一个临时的密钥,并使用该密钥对数据进行加密和解密。由于对称加密的加解密速度快,因此可以有效地保障大量数据的传输安全。
然而,仅仅使用对称加密是不够的。为了确保通信双方的身份验证以及防止中间人攻击,HTTPS还需要用到非对称加密。在证书验证阶段,HTTPS使用非对称加密来验证服务器的身份。服务器会向客户端发送自己的证书,其中包括了公钥等信息。客户端会使用证书中的公钥来验证服务器的身份,并确保数据传输过程中的安全性。
1.对称加密算法:对称加密算法使用相同的密钥来加密和解密数据。在HTTPS通信中,客户端和服务器会协商一个对称密钥,通常是使用服务器的公钥加密生成的。这个对称密钥会用于加密和解密数据传输过程中的内容,因为对称加密效率高,适合用于加密大量数据的传输。
2.非对称加密算法:非对称加密算法包括公钥和私钥。服务器会拥有自己的私钥,而与之对应的公钥会被安全地存储在数字证书中。在建立连接时,服务器会把自己的公钥发给客户端。客户端使用服务器的公钥对协商的对称密钥进行加密,然后传输给服务器,服务器再使用自己的私钥解密该对称密钥。
云厂商一般都提供这种服务,比如AWS Certificate Manager(ACM),
官方地址下载,有mac,windows和linux版本
1 | https://www.kafkatool.com/download.html |
安装后添加kafka集群的地址,可以选择使用zk地址或者kafka的broker地址来连接集群,这里选择使用kafka broker地址来连接
可以指定topic的partition和offset查看数据
默认查出来的数据是byte数组,即16进制的,可以借助在线转换工具将其转换成字符串后进行查看,比如
1 | https://tool.lu/hexstr/ |
也可以在属性中设置value为String,这样就可以直接查看反序列化后字符串
Table API官方文档参考
1 | https://nightlies.apache.org/flink/flink-docs-master/docs/dev/table/tableapi/ |
RowKind
参考kafka官方文档,版本1.0.x
1 | http://kafka.apache.org/10/documentation.html#consumerapi |
依赖,选择 Cloudera Rel 中的 1.0.1-kafka-3.1.0
1 | <dependency> |
Kafka的生产者配置
1 | http://kafka.apache.org/10/documentation.html#producerconfigs |
其中producer api中文含义参考:kafka系列七、kafka核心配置
producer是线程安全的,通常应该在所有线程之间共享,以获得最佳性能。producer管理着一个后台线程,该线程执行I/O操作,并与每个需要通信的broker建立TCP连接。如果使用后不能关闭producer,将会泄漏这些资源。
Timer类是一种线程设施,可以用来实现在某一个时间或某一段时间后安排某一个任务执行一次或定期重复执行。
该功能要与TimerTask类配合使用。TimerTask类用来实现由Timer安排的一次或重复执行的某一任务。
使用idea来开发spring-boot项目,对于community版本的idea,由于没有spring-boot插件,所有对于开发spring-boot的web项目来说不是很方便,所以安装Ultimate版本的idea,使用的版本是2017.1.6版本
参考 :
程序中应用正则表达式则必须依靠Pattern类和Matcher类,这两个类都是在java.util.regex包中定义。
Pattern类的主要作用是进行正则规范的编写。
Matcher类主要是执行规范,验证一个字符串是否符合其规范。
1 | import java.util.regex.Pattern; |