./startup.sh -m standalone
Nacos是一个内部微服务组件,需要在可信的内部网络中运行,不可暴露在公网环境,防止带来安全风险。
Nacos提供简单的鉴权实现,为防止业务错用的弱鉴权体系,不是防止恶意攻击的强鉴权体系。
鉴权
https://nacos.io/zh-cn/docs/v2/guide/user/auth.html
在Spring Boot后端中,RPC代表远程过程调用(Remote Procedure Call)。RPC是一种通信机制,它允许不同计算机或进程间的程序能够相互调用彼此的函数或方法,就像调用本地函数一样。
在分布式系统中,当应用程序的各个部分分布在不同的服务器上,需要相互之间进行通信和协作时,RPC是非常有用的。通过RPC,应用程序可以将请求发送到远程服务器上的方法或服务,并获取返回结果,就好像这些方法或服务是在本地执行的一样。
Spring Boot本身并不提供RPC的实现,但是它可以与其他RPC框架集成,如:
gRPC: 由Google开发的高性能、跨语言的RPC框架,使用Protocol Buffers(protobuf)作为默认的序列化协议。
Apache Dubbo: 一种基于Java的高性能、轻量级的RPC框架,提供了丰富的功能和可插拔的扩展点。
Apache Thrift: 由Apache开发的跨语言的RPC框架,支持多种编程语言,并提供了丰富的数据类型和服务定义。
Spring Cloud: 尽管不是专门的RPC框架,但它提供了在微服务架构中实现RPC风格通信的能力,例如通过RESTful API或Feign客户端。
要在Spring Boot应用程序中使用RPC,您需要:
选择一个适合您的需求的RPC框架,并在项目中添加相关的依赖。
根据RPC框架的文档和示例配置和实现服务端和客户端。
在客户端中调用远程服务的方法,将请求发送到远程服务器并处理返回结果。
需要注意的是,RPC通常比本地方法调用涉及更多的网络通信,因此在设计RPC接口时需要考虑网络延迟和异常处理,以确保系统的可靠性和性能。
与硬件通信交互在物联网应用中是一种常见的需求。Spring Boot作为后端框架,可以与硬件进行通信,实现物联网功能。下面是一般实现物联网的基本步骤以及后端处理的方法:
硬件设备选择:首先,您需要选择适合您物联网项目的硬件设备。这可以是传感器、执行器、嵌入式设备等,取决于您的具体应用场景。
通信协议选择:在与硬件通信时,您需要选择合适的通信协议。常见的通信协议有MQTT、CoAP、HTTP等。您应该根据硬件设备和网络环境的特点选择最适合的协议。
连接硬件设备:在Spring Boot后端中,您可以使用相应的通信库或框架来实现与硬件设备的通信。例如,如果选择MQTT协议,您可以使用Eclipse Paho或者Spring Integration的MQTT支持来建立与硬件设备的连接。
设计API和数据格式:定义与硬件设备交互的API和数据格式。这涉及到如何发送命令到硬件设备,以及如何解析硬件设备发送回来的数据。使用JSON或其他轻量级的数据格式可以方便数据交换。
处理数据和业务逻辑:一旦与硬件设备建立了连接,并通过API交互,后端需要处理从硬件设备接收到的数据。您可以编写相应的业务逻辑来处理这些数据,例如存储到数据库、进行实时分析等。
安全性:在物联网应用中,安全性非常重要。确保与硬件设备之间的通信是安全的,可以使用加密和身份验证机制来保护通信的安全性。
异常处理:在与硬件设备通信时,可能会出现通信故障或其他异常情况。后端需要做好异常处理,保证系统的稳定性和可靠性。
Sentinel 环境
熔断降级组件,https://github.com/alibaba/Sentinel/releases
java -Dserver.port=8080 -Dcsp.sentinel.dashboard.server = localhost:8080 -Dproject.name = sentinel-dashboard -jar sentinel-dashboard-1.8.x.jar
1、docker安装sentinel
docker pull bladex/sentinel-dashboard
2、启动镜像
docker run --name sentinel -d -p 8858:8858 -d bladex/sentinel-dashboard
3、开放端口
firewall-cmd --permanent --add-port=8858/tcp
4、登录:
http://192.168.1.58:8858/#/dashboard/flow/sentinel-dashboard
账号密码默认均为:sentinel
brew install redis
brew services restart redis
ps -ef|grep redis
cd /Users/xiaolige/app
## 创建 redis master 节点配置文件目录
mkdir -p redis/redisSentinel/master
## 创建 redis slave 节点配置文件目录
mkdir -p redis/redisSentinel/slave
## 创建 redis sentinel 节点配置文件目录
mkdir -p redis/redisSentinel/sentinel
## 创建 redis 启动相关脚本目录
mkdir -p redis/redisSentinel/script
## 创建 redis 日志目录
mkdir -p redis/redisSentinel/logs
把下载好的sentinel-dashboard-1.7.2.jar
包上传到服务器/usr/local中
进入/usr/local目录启动
cd /usr/local
启动Sentinel
直接启动sentinel控制台
java -jar sentinel-dashboard-1.7.2.jar
后台进程方式启动
nohup java -jar sentinel-dashboard-1.7.2.jar >sentinel.log &
管理Sentinel
浏览器访问:http://localhost:8080
默认账号密码
账号:sentinel
密码:sentinel
nacos is starting with standalone
./startup.sh -m standalone
nacos is starting,you can check the /Users/jeskson/Downloads/nacos/logs/start.out
Docker安装Sentinel(Mac)
java -jar sentinel-dashboard-1.8.6.jar
startup.cmd -m standalone
拉取依赖java:8-alpine镜像
docker pull java:8-alpine
创建Dockerfile
在目录 /Users/xxx/docker/sentinel
(根据需要自定义) 下创建Dockerfile文件,并授权
sentinel % pwd /Users/luyou/docker/sentinel
sentinel % touch Dockerfile # 授权目录
chmod -R 777 sentinel
cd sentinel
将 sentinel-dashboard-1.8.4.jar
放入 /Users/xxx/docker/sentinel
目录下
FROM java:8-alpine
COPY ./sentinel-dashboard-1.8.4.jar /tmp/sentinel-dashboard-1.8.4.jar
EXPOSE 8081 8719
ENTRYPOINT java -Dserver.port=8081 -Dcsp.sentinel.dashboard.server=localhost:8081 -Dproject.name=sentinel-dashboard -jar /tmp/sentinel-dashboard-1.8.4.jar
docker build . -t sentinel-dashboard:1.8.4
创建容器
docker run --name sentinel -p 8081:8081 -p 8719:8719 -d sentinel-dashboard:1.8.4
docker ps
docker start sentinel
docker stop sentinel
docker rm sentinel
docker logs -f sentinel
进入容器
docker exec -it sentinel bash
退出容器
exit
Docker安装Seata
Docker安装Nacos
Docker安装Mongodb
Docker安装RabbitMQ
java -jar sentinel-dashboard-1.8.6.jar
nslookup github.com 8.8.8.8
java -jar -Dserver.port=8080 sentinel-dashboard-1.8.6.jar
java -jar -Dserver.port=8718 sentinel-dashboard-1.8.6.jar
./startup.sh -m standalone
http://localhost:8848/nacos/#
8718
问题 异常提示:JWT signature does not match locally computed signature. JWT validity cannot be asserted and should not be trusted.
中文意思是:JWT签名与本地计算的签名不匹配。无法断言JWT有效性,不应信任JWT有效性。
解决 出现这种异常的情况有:
1、生成token时用的密钥和验签时用的密钥不一致。通过打断点的方式debug检查对比两个地方的密钥是否一致。
2、验签时使用的令牌不对。通过打断点的方式debug检查,生成的令牌和回传的令牌是否一致。
public static void addAuthentication(HttpServletResponse res, String username, String role) {
String JWT = Jwts.builder()
.setSubject(username)
.setExpiration(new Date(System.currentTimeMillis() + EXPIRATIONTIME))
.claim("roleName", role)
.signWith(SignatureAlgorithm.HS512, SECRET)
.compact();
res.addHeader(HEADER_STRING, TOKEN_PREFIX + " " + JWT);
}
// parse the token.
Claims body = Jwts.parser()
.setSigningKey(SECRET)
.parseClaimsJws(token.replace(TOKEN_PREFIX, ""))
.getBody();
String username = body.getSubject();
加群联系作者vx:xiaoda0423
仓库地址:https://github.com/webVueBlog/JavaGuideInterview