字节跳动后端二面

news2025/2/13 23:46:42
📍1. 数据库的事务性质,InnoDB是如何实现的?

数据库事务具有ACID特性,即原子性、一致性、隔离性和持久性。InnoDB通过以下机制实现这些特性:

🚀 实现细节:

  • 原子性:通过undo log实现事务回滚。
  • 一致性:通过事务的ACID属性和数据库约束保证。
  • 隔离性:使用锁和MVCC(多版本并发控制)实现不同隔离级别。
  • 持久性:利用redo log确保数据在系统崩溃后能够恢复。

🔧 MySQL事务示例:

START TRANSACTION;
UPDATE accounts SET balance = balance - 100 WHERE id = 1;
UPDATE accounts SET balance = balance + 100 WHERE id = 2;
COMMIT;

📍2. MySQL中数据的存储结构?

MySQL中的数据存储结构涉及表空间、段、区、页和行。InnoDB使用B+树结构存储数据和索引,聚簇索引将数据和主键索引存储在一起。

🚀 存储层次:

  • 表空间:逻辑存储单元。
  • :表空间内的逻辑部分,如数据段、索引段。
  • :由连续的页组成。
  • :最小存储单位,通常16KB。
  • :实际数据记录。

🔧 InnoDB数据存储示例:

SHOW TABLE STATUS LIKE 'table_name';

📍3. MySQL的主从复制原理以及主从延迟的解决方案?

MySQL主从复制通过binlog和中继日志实现数据同步。主从延迟可通过以下方法解决:

🚀 复制原理:

  • 主库记录binlog。
  • 从库I/O线程获取binlog并写入中继日志。
  • SQL线程执行中继日志中的SQL。

🚀 延迟解决方案:

  • 优化网络和硬件。
  • 并行复制。
  • 减少主库负载。
  • 使用半同步复制。

🔧 主从配置示例:

[mysqld]
log-bin=mysql-bin
server-id=1

📍4. Kafka怎么保证消息不丢、重复发了怎么办?

Kafka通过生产者、broker和消费者的协调保证消息不丢失。重复消息通过幂等性和去重机制处理。

🚀 消息不丢:

  • 生产者:设置acks=all。
  • Broker:使用持久化和min.insync.replicas。
  • 消费者:手动提交偏移量。

🚀 重复消息处理:

  • 幂等性生产者。
  • 消息去重。

🔧 Kafka生产者配置示例:

acks=all
retries=3

📍5. 你的项目中,接口调用如何保证幂等?

接口幂等性通过唯一标识符、乐观锁、分布式锁、状态机和Token机制实现,确保重复请求产生相同结果。

🚀 幂等实现:

  • 唯一标识符:使用UUID和数据库唯一索引。
  • 乐观锁:版本号控制。
  • 分布式锁:Redisson或ZooKeeper。

🔧 幂等性示例代码:

// 使用UUID生成唯一标识符
UUID uuid = UUID.randomUUID();

📍6. 你的项目中,如何保证分布式事务的一致性?

分布式事务一致性可通过两阶段提交、补偿事务、基于消息的最终一致性、最大努力通知和Saga模式实现。

🚀 一致性策略:

  • 两阶段提交(2PC):XA协议。
  • 补偿事务(TCC):Try-Confirm-Cancel。
  • 基于消息的最终一致性:消息队列。

🔧 Seata分布式事务示例:

<dependency>
    <groupId>io.seata</groupId>
    <artifactId>seata-all</artifactId>
    <version>1.4.2</version>
</dependency>

📍7. 项目中的限流怎么做的,为什么这么做?

限流通过固定窗口、滑动窗口、令牌桶和漏桶算法实现,保护系统稳定性、防止资源耗尽和恶意攻击。

🚀 限流算法:

  • 固定窗口:Guava RateLimiter。
  • 滑动窗口:Redis滑动窗口。
  • 令牌桶:令牌生成和消耗。

🚀 限流原因:

  • 保护系统稳定性。
  • 防止资源耗尽。

🔧 Guava RateLimiter示例:

RateLimiter rateLimiter = RateLimiter.create(10.0); // 每秒10个请求
rateLimiter.acquire(); // 获取令牌

📍8. 如何设计群消息已读?

群消息已读通过存储已读状态、消息发送接收同步、已读列表展示和批量更新实现,优化使用分页加载和缓存。

🚀 设计思路:

  • 已读状态存储:数据库或缓存。
  • 消息发送和接收:更新已读状态。
  • 已读列表展示:展示已读成员。

🔧 已读状态更新示例:

// 更新消息已读状态
updateMessageReadStatus(userId, messageId, true);

📍9. 多线程题目:10个线程模拟赛马,所有马就绪后才能开跑,所有马到达终点后裁判宣布赛马成绩。

问题描述:
使用多线程模拟赛马比赛,要求所有马(线程)都准备好后才能开始比赛,所有马到达终点后裁判宣布比赛结果。

解题思路:

  • 使用sync.WaitGroup来同步多个线程。
  • 使用sync.Mutex来保护共享资源的访问。
  • 每个马(线程)在准备好后通知主线程,主线程在所有马都准备好后发出开始信号。
  • 所有马到达终点后,裁判宣布比赛结果。

代码实现(Golang):

package main

import (
	"fmt"
	"sync"
	"time"
)

type Horse struct {
	ID     int
	Ready  bool
	Finish bool
	mu     sync.Mutex
}

func (h *Horse) run(start, finish *sync.WaitGroup) {
	defer finish.Done()

	// 马准备好
	h.mu.Lock()
	h.Ready = true
	h.mu.Unlock()
	fmt.Printf("Horse %d is ready!\n", h.ID)

	// 等待所有马准备好
	start.Wait()

	// 模拟赛跑
	time.Sleep(time.Duration(h.ID) * time.Second)
	h.mu.Lock()
	h.Finish = true
	h.mu.Unlock()
	fmt.Printf("Horse %d has finished!\n", h.ID)
}

func main() {
	const numHorses = 10
	var start, finish sync.WaitGroup
	horses := make([]*Horse, numHorses)

	// 初始化马
	for i := 0; i < numHorses; i++ {
		horses[i] = &Horse{ID: i + 1}
	}

	// 设置WaitGroup
	start.Add(1)
	finish.Add(numHorses)

	// 启动赛马线程
	for _, horse := range horses {
		go horse.run(&start, &finish)
	}

	// 等待所有马准备好
	for {
		allReady := true
		for _, horse := range horses {
			horse.mu.Lock()
			if !horse.Ready {
				allReady = false
			}
			horse.mu.Unlock()
		}
		if allReady {
			break
		}
		time.Sleep(100 * time.Millisecond)
	}

	// 所有马准备好,开始比赛
	fmt.Println("All horses are ready! Start racing!")
	start.Done()

	// 等待所有马到达终点
	finish.Wait()
	fmt.Println("All horses have finished! Race is over!")
}

代码解析:

  • Horse结构体:包含马的ID、准备状态、完成状态和一个互斥锁。
  • run函数:每个马(线程)的执行函数,模拟马的准备、等待开始信号、赛跑和到达终点。
  • 主函数:初始化马、设置WaitGroup、启动线程、等待所有马准备好、发出开始信号、等待所有马到达终点并宣布比赛结果。

📍10. LeetCode 394,给定一个经过编码的字符串,返回它解码后的字符串。

问题描述:
给定一个编码字符串,格式为k[encoded_string],其中k是一个正整数,encoded_string是一个字符串。要求解码这个字符串,返回解码后的结果。

解题思路:

  • 使用栈来处理嵌套的编码字符串。
  • 遍历字符串,遇到数字、字母、[]时分别处理。
  • 遇到数字时,解析完整的数字并压入数字栈。
  • 遇到[时,将当前的字符串压入字符串栈,并重置当前字符串。
  • 遇到]时,弹出数字栈和字符串栈,将当前字符串重复相应次数后与弹出的字符串拼接。
  • 遇到字母时,直接拼接到当前字符串。

代码实现(Golang):

package main

import (
	"fmt"
	"strconv"
	"strings"
)

func decodeString(s string) string {
	var numStack []int
	var strStack []string
	var currentNum int
	var currentStr strings.Builder

	for i := 0; i < len(s); i++ {
		char := s[i]

		switch {
		case char >= '0' && char <= '9':
			// 解析数字
			num, _ := strconv.Atoi(string(char))
			currentNum = currentNum*10 + num
		case char == '[':
			// 将当前数字和字符串压入栈
			numStack = append(numStack, currentNum)
			strStack = append(strStack, currentStr.String())
			// 重置当前数字和字符串
			currentNum = 0
			currentStr.Reset()
		case char == ']':
			// 弹出数字和字符串
			num := numStack[len(numStack)-1]
			numStack = numStack[:len(numStack)-1]
			prevStr := strStack[len(strStack)-1]
			strStack = strStack[:len(strStack)-1]
			// 重复当前字符串并拼接到前一个字符串
			currentStr.WriteString(strings.Repeat(currentStr.String(), num))
			currentStr = strings.Builder{}
			currentStr.WriteString(prevStr)
		default:
			// 字母直接拼接到当前字符串
			currentStr.WriteByte(char)
		}
	}

	return currentStr.String()
}

func main() {
	encoded := "3[a2[c]]"
	decoded := decodeString(encoded)
	fmt.Println(decoded) // 输出: "accaccacc"
}

代码解析:

  • numStack:用于存储数字的栈。
  • strStack:用于存储字符串的栈。
  • currentNum:当前解析的数字。
  • currentStr:当前解析的字符串。
  • 遍历字符串:根据字符类型分别处理数字、[]和字母。
  • 解码过程:通过栈的压入和弹出操作,处理嵌套的编码字符串。

欢迎关注我的小红书一起来讨论。
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2297602.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Django在终端创建项目(pycharm Windows)

1.选择目录 选择或新建一个文件夹&#xff0c;作为项目保存的地方 2.右键在终端打开 3.确定django-admin.exe安装位置 找到自己安装django时&#xff0c;django-admin.exe安装的位置&#xff0c;例如 4.运行命令 使用django-admin.exe的绝对路径&#xff0c;在刚才打开的终端…

echarts 3d中国地图飞行线

一、3D中国地图 1. 一定要使用 echarts 5.0及以上的版本; 2. echarts 5.0没有内置中国地图了。点击下载 china.json&#xff1b; 3. 一共使用了四层地图。 &#xff08;1&#xff09;第一层是中国地图各省细边框和展示南海诸岛&#xff1b; &#xff08;2&#xff09;第二层是…

在本地校验密码或弱口令 (windows)

# 0x00 背景 需求是验证服务器的弱口令&#xff0c;如果通过网络侧校验可能会造成账户锁定风险。在本地校验不会有锁定风险或频率限制。 # 0x01 实践 ## 1 使用 net use 命令 可以通过命令行使用 net use 命令来验证本地账户的密码。打开命令提示符&#xff08;CMD&#xff0…

【Elasticsearch】Elasticsearch检索方式全解析:从基础到实战(二)

接着上一篇文章&#xff1b;我们继续来研究es的复杂检索 文章目录 (1) bool用来做复合查询&#xff08;2&#xff09;Filter【结果过滤】&#xff08;3&#xff09;term&#xff08;4&#xff09;Aggregation&#xff08;执行聚合&#xff09; (1) bool用来做复合查询 复合语…

游戏引擎学习第96天

讨论了优化和速度问题&#xff0c;以便简化调试过程 节目以一个有趣的类比开始&#xff0c;提到就像某些高端餐厅那样&#xff0c;菜单上充满了听起来陌生或不太清楚的描述&#xff0c;需要依靠服务员进一步解释。虽然这听起来有些奇怪&#xff0c;但实际上&#xff0c;它反映…

(Xshell 8 + Xftp 8)下载安装miniconda至服务器指定目录+配置虚拟环境

一一一一 Xshell 8 Xftp 8均已登录&#xff0c;miniconda.sh安装包已经放在服务器指定目录中 二二二二 赋予脚本执行权限 chmod x Miniconda3-latest-Linux-x86_64.sh安装miniconda ./Miniconda3-latest-Linux-x86_64.sh -p /data1/huyan/zhangyifeng/miniconda3一直Enter…

多机器人系统的大语言模型:综述

25年2月来自 Drexel 大学的论文“Large Language Models for Multi-Robot Systems: A Survey”。 大语言模型 (LLM) 的快速发展为多机器人系统 (MRS) 开辟新的可能性&#xff0c;从而增强通信、任务规划和人机交互。与传统的单机器人和多智体系统不同&#xff0c;MRS 带来独特…

Python----PyQt开发(PyQt基础,环境搭建,Pycharm中PyQttools工具配置,第一个PyQt程序)

一、QT与PyQT的概念和特点 1.1、QT QT是一个1991年由The Qt Company开发的跨平台C图形用户界面应用程序开发 框架&#xff0c;可构建高性能的桌面、移动及Web应用程序。也可用于开发非GUI程序&#xff0c;比如 控制台工具和服务器。Qt是面向对象的框架&#xff0c;使用特殊的代…

MT6835 21位 磁编码器 SPI 平台无关通用驱动框架 STM32

MT6835 21位 磁编码器 SPI 平台无关通用驱动框架 STM32 1. 获取代码&#xff1a;2. 加入你的项目2.1 以 STM32 为例:2.2 以 ESP-IDF 为例: 3. 对接 API3.1 以 STM32 为例&#xff1a; 4. 更多函数说明5. 写入 EEPROM 示例 MT6835 Framework 纯C语言实现&#xff0c;跨平台&…

嵌入式WebRTC压缩至670K,目标将so动态库压缩至500K,.a静态库还可以更小

最近把EasyRTC的效果发布出去给各大IPC厂商体验了一下&#xff0c;直接就用EasyRTC与各个厂商的负责人进行的通话&#xff0c;在通话中&#xff0c;用户就反馈效果确实不错&#xff01; 这两天有用户要在海思hi3516cv610上使用EasyRTC&#xff0c;工具链是&#xff1a;gcc-2024…

Rhel Centos环境开关机自动脚本

Rhel Centos环境开关机自动脚本 1. 业务需求2. 解决方法2.1 rc.local2.2 rc.d2.3 systemd2.4 systemd附着的方法2.5 tuned 3. 测试 1. 业务需求 一台较老的服务器上面业务比较简单,提供一个简单的网站,但已经没有业务的运维人员. 想达到的效果: 由于是非标准的apache或者nginx…

phpipam1.7安装部署

0软件说明 phpipam是一个开源Web IP地址管理应用程序&#xff08;IPAM&#xff09; phpipam官网&#xff1a;https://www.phpipam.net/ 1安装环境 操作系统&#xff1a;Rocky Linux9.5x86_64 phpipam版本&#xff1a;1.7 php版本&#xff1a;8.0.30 数据库版本&#xff1a…

正泰中间电磁继电器【8脚10A】DC24V 待机功率

需求&#xff1a;继电器能耗测试。 1.连接24V2A的电源&#xff0c; 2. 稳定功率为 1.4W 3. 正泰中间电磁继电器【8脚10A】直流DC24V 注&#xff1a;联通时电磁继电器会轻微发热 4.电磁继电器的工作原理基于电流的磁效应 电磁激励&#xff1a;电磁继电器主要由线圈、铁芯、衔…

Mac上搭建宝塔环境并部署PHP项目

安装Docker Desktop》搭建Centos版本的宝塔环境》部署PHP项目 1. 下载Docker for mac 软件&#xff1a;https://www.docker.com/ 或使用终端命令&#xff1a;brew install --cask --appdir/Applications docker 2. 使用命令安装宝塔环境的centos7系统&#xff1a; docker pul…

win11 终端乱码导致IDE 各种输出也乱码

因为 win11 终端乱码导致IDE 各种输出也乱码导致作者对此十分头大。所以研究了各种方法。 单独设置终端编码对 HKEY_CURRENT_USER\Console 注册表进行修改对 HKEY_LOCAL_MACHINE\Software\Microsoft\Command Processo 注册表进行修改使用命令[Console]::OutputEncoding [Syst…

LabVIEW用户界面(UI)和用户体验(UX)设计

作为一名 LabVIEW 开发者&#xff0c;满足功能需求、保障使用便捷与灵活只是基础要求。在如今这个用户体验至上的时代&#xff0c;为 LabVIEW 应用程序设计直观且具有美学感的界面&#xff0c;同样是不容忽视的关键任务。一个优秀的界面设计&#xff0c;不仅能提升用户对程序的…

23、深度学习-自学之路-激活函数relu、tanh、sigmoid、softmax函数的正向传播和反向梯度。

在使用这个非线性激活函数的时候&#xff0c;其实我们重点还是学习的是他们的正向怎么传播&#xff0c;以及反向怎么传递的。 如下图所示&#xff1a; 第一&#xff1a;relu函数的正向传播函数是&#xff1a;当输入值&#xff08;隐藏层&#xff09;值大于了&#xff0c;就输出…

【matlab优化算法-16期】基于遗传算法的电热气及储能综合优化项目实践

电热气及储能综合优化项目实践 一、前言 随着能源转型和可持续发展的推进&#xff0c;综合能源系统的优化逐渐成为研究热点。本文介绍了一个电热气及储能综合优化项目&#xff0c;旨在通过优化算法实现多能源系统的协同运行&#xff0c;提高能源利用效率&#xff0c;降低运行…

springboot239-springboot在线医疗问答平台(源码+论文+PPT+部署讲解等)

&#x1f495;&#x1f495;作者&#xff1a; 爱笑学姐 &#x1f495;&#x1f495;个人简介&#xff1a;十年Java&#xff0c;Python美女程序员一枚&#xff0c;精通计算机专业前后端各类框架。 &#x1f495;&#x1f495;各类成品Java毕设 。javaweb&#xff0c;ssm&#xf…

DeepSeek系统崩溃 | 极验服务如何为爆火应用筑起安全防线?

引言 极验服务让您的产品站在风口之时&#xff0c;不必担心爆红是灾难的开始&#xff0c;而是期待其成为驱动持续创新的全新起点。 01现象级狂欢背后&#xff0c;你的业务安全防线抗得住吗&#xff1f; “近期DeepSeek线上服务受到大规模恶意攻击&#xff0c;注册可能繁忙&am…