SpringCloudAlibaba高并发仿斗鱼直播平台实战
核心代码,注释必读
// download:
3w ukoou com
SpringCloudAlibaba介绍 Spring Cloud Alibaba 致力于提供微服务开发的一站式解决方案。 此项目包含开发分布式应用微服务的必需组件,依托Spring Cloud Alibaba,只需要添加一些注解和少量配置,就可以将Spring Cloud 应用接入阿里微服务解决方案,通过阿里中间件来迅速搭建分布式应用系统
SpringCloudAlibaba高并发仿斗鱼直播平台实战 - SpringBoot应用的Docker容器化部署
编写 Docker 脚本
下来该编写 Docker 创建镜像的打包脚本,名称必须是 Dockerfile,位置为项目根目录,还有通过 Maven 插件来操作位置不尽相同。内容如下
dockerfile
复制代码
# 使用aws 的 openjdk8
FROM amazoncorretto:8
# 作者署名
MAINTAINER Felordcn
# 挂载的容器磁盘
VOLUME ["/tmp"]
# 使用东八区时间 环境 其他环境参数也可以通过ENV 声明
ENV TZ=Asia/Shanghai
RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
# add 命令是 将主机构建环境(上下文)目录中的文件和目录、以及一个URL标记的文件 拷贝到镜像中
ADD /target/docker-springboot-0.0.1-SNAPSHOT.jar app.jar
# 暴露端口 跟springboot 默认应用端口一样
EXPOSE 8080
# 启动镜像就执行的命令操作 相当于执行 java -jar app.jar -Djava.security.egd=file:/dev/./urandom 最后的指令是为了加快启动
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","app.jar"]
构建镜像
然后在项目目录下打开命令行工具(idea 自带有)执行脚本(记得启动docker)不要忘记最后的点 代表当前路径 其他路径 写相对路径
apache
复制代码
docker build -t docker-springboot:0.0.1 .
然后进入分层构建阶段 走到最后镜像就成了如下
启动容器
命令行 执行 docker images 查看一下是否存在 一个 docker-springboot:0.0.1 的镜像,只要结果跟上图一样就一定存在。然后从镜像启动一个容器,命令行如下
apache
复制代码
docker run --name docker-app -p 8088:8080 docker-springboot:0.0.1
该命令的意思是 我前台从 docker-springboot:0.0.1 镜像启动一个名字叫 docker-app的容器应用,同时将容器内部端口8080映射到宿主机端口8088 ,这样我们可以通过本地端口8088访问容器端口8080 。然后你访问上面写好的那个接口 http://localhost:8088/docker/hello
仿斗鱼直播 - WebSocket和TCP长连接详解与性能对比
长连接
还有一种大家特别熟悉的协议:HTTP,它是无状态的协议,所谓的无状态就是请求与请求之间不存在记忆关系,服务器是不知道客户端的状态的。
HTTP无连接
那么我们今天要讲的WebSocket是什么样的协议,它的王炸特点又有哪些呢?
下面瑞哥带您揭开WebSocket的神秘面纱!
什么是WebSocket? WebSocket 是一种用于在 Web 浏览器和服务器之间创建快速双向通道的协议,通过单个 TCP 连接持续传输数据。
WebSockets 允许发送基于消息的数据,类似于 UDP,但具有 TCP 的可靠性,WebSocket 使用 HTTP 作为初始传输机制,但在收到 HTTP 响应后保持 TCP 连接处于活动状态,以便用于在客户端和服务器之间发送消息。
UDP 英文全称:User Datagram Protocol 中文名称:用户数据报协议 无连接协议 速度快 允许丢失数据包 适合需要快速、高效传输的应用 TCP 英文全称:Transmission Control Protocol 中文名称:传输控制协议 面向连接的协议 传输可靠,保证不会丢失任何数据包 速度较慢,需要更多资源 适合需要高可靠性的应用程序 HTTP 英文全称:Hypertext Transfer Protocol 中文名称:超文本传输协议 无状态协议 遵循客户端-服务器模型 广泛应用于Web 浏览器和 Web 服务器之间通信 WebSocket URL 使用ws 或者 wss,而不是http、https WebSocket 是如何工作的? 首先,让我们看看在没有WebSocket的情况下如何调用网站,在 Internet 上,网页通常通过HTTP 连接传输,数据通过协议进行通信,然后网站就会显示在浏览器中,然后用户的每个动作,比如单击或者双击某个按钮或者链接 的时候,客户端都会向服务器发送一个请求。
当通过 HTTP 调用网站时,客户端首先必须向服务器发送请求,然后服务器通过发送请求的内容进行响应,换句话说,HTTP 基于简单的请求和响应模型工作,这会产生很大的延迟。
然后我们再来看看WebSocket连接是如何进行的?
WebSocket通过握手来做到客户端与服务器的连接,握手的流程和TCP三次握手类似,握手后,通道保持打开状态,然后客户端和服务端可以保持持久通信,服务器可以独立地向客户端发送数据,而无需客户端请求。
当 WebSocket 首次启动时,会向指定的 URL 发送一个简单的 HTTP 请求,从那里,HTTP 请求“升级”到 TCP 套接字,本质上是一个安全隧道,用于在 HTTP 握手发生后数据流过,握手可以被认为是客户端和服务器之间保持连接的“协议”。