实用指南:52.前端的后端模式:为每个客户端定制专属「管家服务」
目录
- 一、传统API的"万人迷困境"
- 二、BFF模式三**重奏**
- 2.1 网关路由层
- 2.2 响应裁剪器
- 2.3 协议转换层
- 三、四大核心武器库
- 3.1 声明式响应模板
- 3.2 智能缓存策略
- 3.3 实时数据推送
- 四、性能优化擂台
- 五、典型事故现场
- 六、未来扩展方向
- 6.1 智能适配引擎
- 6.2 边缘计算集成
- 6.3 自动化BFF生成
- 七、动手训练营
当你的移动端喊着要精简数据,Web端吵着要复杂交互,IoT设备又需要特殊协议——是时候给每个「小祖宗」配专属管家了!今天我们用Java搭建这套「分封制」服务体系,让前端和后端从此不再相爱相杀!
一、传统API的"万人迷困境"
典型的通用接口问题:
// 传统通用API服务
@RestController
public class CommonController
{
@GetMapping("/api/data")
public ResponseEntity<
Map<
String, Object>
> getData() {
// 同时满足三种客户端的万能接口
Map<
String, Object> data = new HashMap<
>();
data.put("user", userService.getFullProfile());
// Web端需要完整数据
data.put("preview", postService.getPreview());
// 移动端需要摘要
data.put("sensor", iotService.getRawData());
// IoT设备需要原始数据
return ResponseEntity.ok(data);
// 所有客户端都得到冗余数据
}
}
二、BFF模式三重奏
2.1 网关路由层
// Spring Cloud Gateway配置
@Bean
public RouteLocator customRouteLocator(RouteLocatorBuilder builder) {
return builder.routes()
.route("mobile-bff", r -> r.path("/mobile/**")
.filters(f -> f.stripPrefix(1))
.uri("lb://mobile-bff-service"))
.route("web-bff", r -> r.path("/web/**")
.filters(f -> f.addRequestHeader("X-Client-Type", "browser"))
.uri("lb://web-bff-service"))
.route("iot-bff", r -> r.path("/iot/**")
.filters(f -> f.rewritePath("/iot/(?<segment>.*)", "/${segment}")).uri("lb://iot-bff-service")).build();}
2.2 响应裁剪器
// 移动端BFF服务
@RestController
public class MobileBFFController
{
@GetMapping("/profile")
public MobileProfile getProfile() {
User user = userService.getFullProfile();
return new MobileProfile(
user.getAvatar(),
user.getNickname(),
user.getLastLogin()
);
// 只返回移动端需要的核心字段
}
@Data
@AllArgsConstructor
private static class MobileProfile
{
private String avatarUrl;
private String nickname;
private LocalDateTime lastActive;
}
}
2.3 协议转换层
// IoT设备BFF的MQTT转换器
@MessageMapping("/sensor/{deviceId}")
public void handleSensorData(@Payload String payload, @DestinationVariable String deviceId) {
SensorData data = protobufConverter.convert(payload);
iotService.processDeviceData(deviceId, data);
// 推送到WebSocket
simpMessagingTemplate.convertAndSend(
"/topic/device/" + deviceId,
new WebSocketMessage(data.getTemperature(), data.getHumidity())
);
}
三、四大核心武器库
3.1 声明式响应模板
// 使用JSON Views定制响应
public class ViewProfiles
{
public interface MobileView {
};
public interface WebView extends MobileView {
};
}
@RestController
public class ProfileController
{
@JsonView(ViewProfiles.MobileView.class)
@GetMapping("/mobile/profile")
public User getMobileProfile() {
return userService.getCurrentUser();
}
@JsonView(ViewProfiles.WebView.class)
@GetMapping("/web/profile")
public User getWebProfile() {
return userService.getCurrentUser();
}
}
// User实体类配置
public class User
{
@JsonView(ViewProfiles.MobileView.class)
private String nickname;
@JsonView(ViewProfiles.WebView.class)
private String email;
// 其他字段...
}
3.2 智能缓存策略
// 分层缓存配置
@Configuration
@EnableCaching
public class CacheConfig
{
@Bean
public CacheManager mobileCache() {
return new ConcurrentMapCacheManager("mobile-profile");
}
@Bean
public CacheManager webCache() {
CaffeineCacheManager manager = new CaffeineCacheManager();
manager.setCaffeine(Caffeine.newBuilder()
.expireAfterWrite(10, TimeUnit.MINUTES)
.maximumSize(1000));
return manager;
}
}
// BFF服务中的缓存应用
@Cacheable(cacheManager = "mobileCache", cacheNames = "mobile-profile")
public MobileProfile getMobileProfile(String userId) {
// 获取并处理数据...
}
3.3 实时数据推送
// WebSocket实时更新
@RestController
@RequiredArgsConstructor
public class RealTimeController
{
private final SimpMessagingTemplate messagingTemplate;
@Scheduled(fixedRate = 5000)
public void pushNotifications() {
List<
Notification> notifications = notificationService.fetchNew();
notifications.forEach(notify ->
messagingTemplate.convertAndSendToUser(
notify.getUserId(),
"/queue/notifications",
new NotificationDTO(notify)
)
);
}
}
四、性能优化擂台
压力测试对比(10000并发):
模式 | 响应时间 | 吞吐量 | 错误率 |
---|---|---|---|
传统API | 450ms | 1200 | 2.5% |
基础BFF | 220ms | 2500 | 0.8% |
优化后BFF | 150ms | 3800 | 0.2% |
加速秘籍:
- 客户端缓存策略
- 响应结果预生成
- 协议缓冲区传输
- 流式响应处理
- 边缘节点计算
五、典型事故现场
// 反面教材1:BFF间代码复制
public class MobileBFF
{
// 与WebBFF重复的验证逻辑
private boolean validateUser() {
...
}
}
public class WebBFF
{
// 复制粘贴的相同代码
private boolean validateUser() {
...
}
}
// 正确方式:将公共逻辑下沉到共享库
// 反面教材2:过度聚合
@GetMapping("/super-api")
public SuperResponse getEverything() {
// 聚合20+微服务调用
// 导致响应时间不可控
}
// 反面教材3:客户端耦合
public class BFFController
{
// 直接返回前端组件结构
@GetMapping("/mobile/home")
public ReactComponent renderHome() {
...
}
}
六、未来扩展方向
6.1 智能适配引擎
// 自适应BFF架构
public class AdaptiveBFF
{
public ResponseEntity<
?> dynamicResponse(HttpServletRequest request) {
ClientProfile profile = clientDetector.detect(request);
return responseGenerator.generate(profile);
}
}
6.2 边缘计算集成
public class EdgeBFF
{
@PostMapping("/process")
public Mono<
ProcessResult> edgeComputing(@RequestBody SensorData data) {
return aiModel.predict(data)
.timeout(Duration.ofMillis(50))
.onErrorResume(e -> fallbackService.predict(data));
}
}
6.3 自动化BFF生成
// 基于OpenAPI生成BFF
@OpenAPIGenerator(
spec = "user-service.yml",
target = "mobile",
operations = {
@GeneratedOperation(path = "/profile", method = "GET")
}
)
public class AutoBFFController
{
// 自动生成的端点代码
}
七、动手训练营
毕业设计:构建支持以下特性的BFF系统:
- 动态客户端识别
- 自动协议转换
- 智能缓存分层
- 实时异常熔断
初始化模板:
public class SmartBFFSystem
{
public static void main(String[] args) {
BFFEngine engine = new BFFEngine()
.withClientDetector(new AIRequestAnalyzer())
.withProtocolConverter(new AutoConverter())
.withCircuitBreaker(new ReactiveCircuitBreaker())
.withCacheLayer(new MultiLevelCache());
engine.start();
}
}
相关文章:
实用指南:52.前端的后端模式:为每个客户端定制专属「管家服务」
实用指南:52.前端的后端模式:为每个客户端定制专属「管家服务」pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New&q…...
Agilent 34401A台式万用表远程读表
Agilent 34401A台式万用表支持RS232和GPIB的方式读数据。 一、RS232读表 将台式万用表的模式调为RS232-9600-8-1-none测试代码class MultimeterStrategy:def __init__(self, port, baudrate=9600):self.port = portself.baudrate = baudrateself.serial = Noneself.retry_max =…...
Java 在大数据处理与人工智能中的应用
在数字化时代,数据成为新的生产要素,人工智能成为新的驱动引擎。大数据与人工智能的结合,使得企业能够从海量数据中提取价值,驱动业务创新与智能决策。虽然很多人提到 AI 就会联想到 Python,但 Java 在大数据和人工智能的工程化落地中仍然不可或缺。它凭借成熟的生态体系、…...
马克思,本就是一位独立研究者
ECT-OS-JiuHuaShan/ORCID:0009-0006-8591-1891▮ 推理请求接收:历史人物本质定位 ▮ 公理锚定:自然辩证法第5定理(文明演进个体作用力) ▮ 因果算符启动:独立研究者与文明级公理发现的相关性验证 绝对结论:卡尔马克思是文明级公理架构师的先驱形态,其独立研究性质为历史…...
产品二期,从GPT5规划开始
具有产品研发经验的应该知道,GPT5提供的规划设计,兼顾了完善和可执行两个关键维度。经常使用大模型都有的感受是:如果在某个领域有0-1的入门,那么AI可以带你快速的进行1-100的尝试。背景简介 楼里App一期开发完成,开始进行二期的网站开发,想以此需求作为驱动,探索整个流…...
Redis能抗住百万并发的秘密
前言 今天想和大家深入聊聊Redis为什么能够轻松抗住百万级别的并发请求。 有些小伙伴在工作中可能遇到过这样的场景:系统访问量一上来,数据库就扛不住了,这时候大家第一时间想到的就是Redis。 但你有没有想过,为什么Redis能够承受如此高的并发量?它的底层到底做了什么优化…...
接受 “未完成态”,是一种能力
正文这个标题,写给你们,也写给我自己。我不知道有多少人有这种类似的问题:我们很难把一个没有写完的字、一件没有完成的事情给别人看。这种做到半路的样子如果拿出来展示的话,非常难为情。尤其是如果还要中途易辙的话,那就更不好解释了。网上经常有那种开玩笑说熬夜的,说…...
深入理解JNI、安全点与循环优化:构建高健壮性Java应用
🔥🔥🔥来都来了 ~ 先赞后看 效果翻倍哦 ~ 👍👍👍 引言 在Java开发者的工具箱中,有一些看似神秘却极其重要的底层概念。你是否曾听说过在循环中插入Thread.sleep(0)可以"唤醒"GC?或者疑惑为什么一个简单的循环计数器类型选择会影响整个应用的稳定性?本…...
英语_阅读_fascinating facts about water_待读
Did you know these fascinating facts about water? They might change the way you think about every drop!你知道这些关于水的奇妙事实吗?它们可能会改变你对每一滴水的看法! Scientists have discovered something incredible - the amount of water on the Earth toda…...
AI自动化测试全攻略:从AI 自动化测试实战到AI 智能测试平台开发!
最新一期 AI + 全栈测试开发训练营震撼来袭,课程内容全面升级,月薪轻松对标 30k + !今日开放 5 个特价名额,零基础小白与测试老司机皆可在此找到专属学习路径,涵盖从AI 自动化测试实战到AI 智能测试平台开发等前沿内容,覆盖 AI 时代测试开发核心能力,帮你构建完整知识体…...
LG9691
考虑 dp。设 \(f_i\) 表示到位置 \(i\) 所需的最小花费,且第 \(i\) 个位置必选,现在要找上一个决策点 \(j\),这个点应该要在此前所有区间的左端点的后面,才能保证这些区间能被覆盖(即确保至少一个在之前每个区间内),则 \(j\) 应满足 \(\max_{r_k<i}l_k \le j < i\…...
即时通讯小程序 - 实践
即时通讯小程序 - 实践pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", monospace !important; font-size: 1…...
PHP serialize 序列化完全指南
PHP serialize 序列化完全指南 介绍 如果你和我一样,第一次在 PHP 中看到序列化字符串时会觉得很困惑。我当时在做一个 Laravel 项目,想搞清楚将任务推送到队列时到底发生了什么。我发现一些数据被序列化了,但不知道为什么以及怎么工作的。不过在我花时间研究序列化后,发现…...
CF2112D
注意到一条边无论方向如何,都能使两端的某一个点到达另一个点,即至少有 \(n-1\) 对。如果只需要 \(n-1\) 对,那么只需要在每一条链上相邻的边方向相反即可。对于剩下的一对,我们可以找到一个度数为 \(2\) 的点,并把连接的两条边由反向改为同向,那么附近的三个点产生的对数…...
CF2112C
设 Alice 取的位置为 \(i,j,k\) 且 \(i<j<k\),则 Bob 的最优策略有两种:取 \(n\) 或 \(k\)。为了使 Alice 必胜,必须同时满足 \(a_i+a_j+a_k>a_n,a_i+a_j>a_k\)。枚举 \(i,j\),显然满足两个条件的 \(k\) 都是一段连续的区间。分别二分算出两个区间的边界,那么…...
CF342C
显然,每一层恰好能放下两个球(事实上这也是最优的方案),那么下面一共可以放 \(\lfloor \frac{h}{r} \rfloor \times 2\) 个球,剩余 \(h - \lfloor \frac{h}{r} \rfloor \times r+r\) 的高度,记 \(h=h-\lfloor \frac{h}{r} \rfloor\times r\) 为立方体部分剩余高度。最上面…...
ICPC/XCPC 做题记录
[SNCPC2019] Unrooted Trie 发现不满足题意的情况就是一个节点到多个子节点的边的字母相同,那么合法当且仅当每个节点到子节点的字母互不相同。那么可以统计每个节点连接的字母数量,并运用类似换根 dp 的思路,快速更新这个数量并实时维护符合条件的点的数量即可。时间复杂度…...
LG9648
发现不满足题意的情况就是一个节点到多个子节点的边的字母相同,那么合法当且仅当每个节点到子节点的字母互不相同。那么可以统计每个节点连接的字母数量,并运用类似换根 dp 的思路,快速更新这个数量并实时维护符合条件的点的数量即可。时间复杂度 \(O(nA)\),其中 \(A=26\) …...
LG5689
设 \(f_u\) 表示以 \(u\) 为根的子树构成不同多叉堆的方案数。显然最小的 \(0\) 应该分配给 \(u\),剩下的分给子节点 \(v_1,v_2,\cdots,v_k\),根据乘法原理,有 \[f_u=\prod_{i=1}^k \binom{siz_u-1-\sum_{j=1}^{i-1}siz_{v_j}}{siz_{v_i}}f_{v_i} \]将组合数和 \(f\) 分开,…...
近五年 CSP NOIP 补题记录
2025.6.18 NOIP2024 T4 树上查询 To be updated. Submission CSP-S2019 江西 T3 网格图 To be updated. Submission 2025.6.19 CSP-S2019 D1T2 括号树 To be updated. Submission CSP-S2021 T3 回文 To be updated. Submission CSP-S2019 江西 T1 日期 To be updated. Submissi…...
CF2111C
显然,操作的方式一定是一段数字相等的极长连续段向左右拓展(包括长度为 \(1\) 的段)。故只需扫一遍并维护每段的值和长度即可,并更新答案。时间复杂度 \(O(\sum n)\)。 #include<iostream> #include<cstdio> #define int long long #define N 500010 using nam…...
唐人日记
唐注意看函数返回值!!!!!!!...
CF2111B
首先最大的 \(f_n\) 必须放的下,即 \(f_n \le \min(w,l,h)\)。此外,\(f_{n-1}\) 紧贴在 \(f_n\) 的一个面上,故要 \(f_n+f_{n-1} \le \max(w,l,h)\)。剩下的第 \(i\) 个正方体由于满足 \(f_{i+2}=f_{i}+f_{i+1}\),故只需与第 \(i+1,i+2\) 个正方体共用一条棱即可,且一定不…...
ABC394F
在同一棵树中,选择任意一个点作为根,效果都是相同的。不妨以 \(1\) 为树根,考虑树上 dp,记 \(f_u\) 为以 \(u\) 为根的子树的点数最大值。注意到根节点度数可为 \(1\) 可为 \(4\),而非根非叶子节点度数必须为 \(4\)。由此可以分两类转移。假设子树中 \(u\) 度数为 \(1\),…...
LG11793
注意到 \(N \times M \le 2\times 10^7\),因此不难得到一个 dp 做法。设 \(f_i\) 表示把前 \(i\) 个橙子装进箱子内的最小成本,则不难得到以下转移式: \[f_i=\min_{i-j\le m,0 \le j < i} f_j+k+ ( i - j ) \times ( \max_{j < k \le i} a_k - \min_{j < k \le i} …...
ABC394G
题目要求最小化爬楼梯的次数,那么我们就要让楼层的变化尽量小,即沿线楼房高度越高越好。不难发现影响答案的是路线中的楼房高度的最小值,则需要最大化最小值。那么就不难用 Kruskal 重构树做了。对每个点进行唯一编号,相邻的点建边权为较小的的楼房高度的双向边。剩下的就是…...
MX 炼石 2026 NOIP #5
qwq2026 --【炼石计划 NOIP】-- 第五套 链接:link 题解:link 时间:4h (2025.09.11 14:00~18:00) 题目数:4 难度:A B C D估分:[40,60] + 80 + 32 + ? = [152,172]+? 得分:40 + 60 + 32 + 10 = 142 Rank:场祭补题天依宝宝可爱!...
0126_状态模式(State)
状态模式(State) 意图 允许对象在内部状态改变时改变它的行为。对象看起来似乎修改了它的类。 UML 图优点行为与状态绑定:将特定状态下的行为局部化到对应的状态类中 消除条件判断:避免了大量的if-else状态判断逻辑 状态转换明确:使状态转换流程更加清晰和可管理 易于扩展:…...
Visual Studio 2026 预览体验版现已发布,一起来看看带来哪些新功能!
前言 2025 年 9 月 9 日微软 Visual Studio 团队正式推出了 Visual Studio 2026 预览体验版(Visual Studio 2026 Insiders),此次发布标志着 Visual Studio 迎来一个全新的时代,它将人工智能深度集成到平台中,基础功能更强大,性能也得到进一步提升。 下载 Visual Studio 2…...
基于RK3568/RK3576/RK3588/全志H3/飞腾芯片/国产UOS等/国标GB28181监控系统
一、前言说明 之前从最底层协议通信把gb28181实现了一遍,没有用到exosip或者pjsip等任何第三方库,通过熟读gb28181国标文档几百页,看了一遍又一遍,根据对应的官方文档,一行行代码底层实现,其实就是网络通信,可选tcp或者udp,和http都是同类型的协议,有消息头和消息体,…...
Go语言读写锁(RWMutex)底层原理详解
Go语言读写锁(RWMutex)底层原理详解 概述 Go语言的sync.RWMutex是一种读写锁,允许多个读操作同时进行,但写操作是互斥的。这种锁机制在读多写少的场景下能显著提高并发性能。底层通过互斥锁和原子计数器实现复杂的并发控制。 核心数据结构 type rwmutex struct {rLock m…...
【GitHub每日速递】无需提示词!Nano Bananary香蕉超市:AI绘画玩法多到停不下来
原文:【GitHub每日速递】无需提示词!Nano Bananary香蕉超市:AI绘画玩法多到停不下来 AutoGPT来袭!搭建、部署、运行AI智能体全攻略揭秘 AutoGPT 是一个基于自主任务执行的AI代理工具。简单讲,它能让AI自动拆解目标并执行一系列操作来完成任务,无需持续人工干预。适用人群…...
小题狂练 (J)
solset-J\[\newcommand{\diag}{\operatorname{diag}} \]目录 目录[AGC070B] Odd Namori[JOI Open 2025] 冒泡排序机 / Bubble Sort Machine[AGC039F] Min Product Sum[AGC070B] Odd NamoriMatrix-Tree 定理:给一张带权有向图 \(G\),求 \(G\) 所有以 \(1\) 为根的内向生成树边…...
Drift数据库开发实战:类型安全的SQLite解决方案
Drift数据库开发实战:类型安全的SQLite解决方案本文基于BeeCount(蜜蜂记账)项目的实际开发经验,深入探讨如何使用Drift构建类型安全、高性能的Flutter数据库层。项目背景 BeeCount(蜜蜂记账)是一款开源、简洁、无广告的个人记账应用。所有财务数据完全由用户掌控,支持本地存…...
DELPHI FireDAC连接EXCEL文件
重要提示: xls后缀的文件与xlsx后缀的文件,连接方法不一样. 可以使用代码来实现:FDConnection1.Connected := false;FDConnection1.Params.Clear;FDConnection1.DriverName := ODBC;FDConnection1.Params.Values[DriverID] := ODBC;FDConnection1.Params.Values[ODBCDriver] :=…...
读人形机器人09教育行业
读人形机器人09教育行业1. 教育行业 1.1. 教育是社会进步的基石,是指引后代走向启蒙与创新的明灯 1.2. 人形机器人通过使学习互动化、沉浸化、趣味化,革新了教学方法 1.3. 借助技术创造兼具教育性与吸引力的体验,培养学生成为主动学习者和批判性思考者 2. 个性化学习体验 2.…...
PHP判断字符串是否包含中文
function hasChinese($str) { return preg_match(/[\x{4e00}-\x{9fa5}]/u, $str);} // 使用示例$string = "Hello 你好";if (hasChinese($string)) { echo "字符串包含中文";} else { echo "字符串不包含中文";}每天进步一点点...
当我们红尘作伴,活得潇潇洒洒
为了证明我是真的睡不着而非摆到凌晨三点,先来一点正经东西。平面等腰直角三角形加,查询矩形和。经典问题,但我刚刚才会。考虑矩形加矩形和是咋做的,通过一堆拆拆拆把 4-side 变成 2-side,然后扫描线扫掉一维,数据结构维护另一维。那等腰直角三角形肯定也要拆拆拆。认为下…...
诡异的mysql8的问题
同样是使用 mysql8的镜像 在其他三台服务器上能正常执行druid:initial-size: 5min-idle: 5max-active: 20max-wait: 60000# 调整为 1800000 毫秒 (30 分钟),需大于数据库 wait_timeoutmin-evictable-idle-time-millis: 1800000# 调整检查间隔为 120000 毫秒 (2 分钟)time-betwe…...
二叉树理论
满二叉树:只有度数为0或者2的节点,并且度数为0的节点在同一层;完全二叉树 除了底层节点可能没填满以外其他都填满了,并且最下面一层的节点都集中在该层最左边的若干位置。 之前我们刚刚讲过优先级队列其实是一个堆,堆就是一棵完全二叉树,同时保证父子节点的顺序关系。 二…...
支付中心的熔断降级要怎么做
下面我会把支付中心在流量骤增 / 下游通道故障时的熔断与降级策略拆成(1)原则与常见策略,(2) 业务级降级/路由策略,(3) 具体落地组件(行业实践与参考),以及(4)可直接落地的 Java 示例(使用 Resilience4j + fallback + 速率限制 + 隔离)。 1) 基本原则(5 条行业共识…...
协议版iM蓝号检测,批量筛选iMessages数据,无痕检测是否开启iMessage服务
一、实现iMessage数据检测的两种方式:1.人工筛选,将要验证的号码输出到文件中,以逗号分隔。再将文件中的号码粘贴到iMessage客户端的地址栏,iMessage客户端会自动逐个检验该号码是否为iMessage账号,检验速度视网速而定。红色表示不是iMessage账号,蓝色表示iMessage账号。2…...
栈和队列总结
栈和队列理论C++中stack,queue 是容器么? 我们使用的stack,queue是属于那个版本的STL? 我们使用的STL中stack,queue是如何实现的? stack,queue 提供迭代器来遍历空间么?stack和queue是STL中的容器适配器,不是类似list,vector那样的容器; 容器适配器本质上是基于底层真…...
工业互联网认知实训台-一句话介绍
工业互联网认知实训台主要由传感器、PLC控制器、工业以太网设备、人机界面(HMI)、步进电机和伺服电机等设备组成。步进电机:通过电脉冲信号控制电机每步旋转固定角度,结构简单、成本低,适合精确定位,但效率较低且可能失步。实训台中使用PLC(如1212C系列)通过脉冲信号控…...
1
<meta name="description" content="加载中... 如白屏请[ 点击刷新页面 ]"> <meta property="og:description" content="加载中... 如白屏请[ 点击刷新页面 ]"> <meta http-equiv="Cache-Control" content=&…...
湾区杯 SilentMiner WP
攻击者的ip地址查看文件 /var/log/btmp 发现短时间内大量登录,可确定攻击者 ip 为 192.168.145.131 lastb -f /var/log/btmp192.168.145.131攻击者共进行多少次ssh口令爆破失败?根据 /var/log/btmp 文件计数 lastb -f btmp | grep 192.168.145.131 | wc -l也可以在 /var/log/…...
Python-课后题题目-1.1编程世界初探
1.1编程世界初探(单选题) 1.程序设计语言的主要目的是什么? A让计算机变得更便宜 B使人类能够以高效,清晰,结构化的方式表达计算机逻辑和数据操作 C取代数学和逻辑学 D仅用于编写游戏程序 2.机器语言是由什么组成的? A十进制数字 B英文字母 C二进制代码 D特殊符号 3.汇…...
Python-课后题题目-1.2初识python语言
1.2初识python语言(单选题)Python语言最初由谁创建? A.林纳斯托瓦兹 B.吉多范罗苏姆 C.詹姆斯高斯林 D.布雷丹艾奇 Python 0.9.0版本首次发布于哪一年? A.1989 B.1991 C.1994 D.2000 Python 1.0版本引入了以下哪项特性? A.异步编程 B.类型注释 C.循环和异常处理 D.垃圾回收…...
node和npm相关的记录
1 npm install --loglevel verbose 安装的啰嗦模式会打印日志2 3 npm config get registry 查看镜像源信息。 淘宝的镜像源已经关闭了。4 5 #windwos可以安装一个nvm,可以切换node和npm的版本。6 nvm下载地址 https://github.com/coreybutler/nvm-windows/releases7 8 nvm in…...
在Spring boot 中使用@master 设置主从数据库
基础配置 application.ymlspring: datasource: master: url: jdbc:mysql://localhost:3306/master_db username: root password: 123456 driver-class-name: com.mysql.cj.jdbc.Driver …...