背景最近使用Nginx部署Vue项目时,发现页面不是根路由(/)的情况下会出现404的情况,网上搜寻了一下解决方法,原来是由于Vue单页面开发特性导致的,这里记录一下解决方法。方案只需要在Nginx配置中添加以下内容即可:location / { try_files $uri $uri/ @router; index index.html index.htm; } location @router { rewrite ^.*$ /index.html last; }在1panel的配置server { listen 80 ; listen 443 ssl http2 ; server_name ***; index index.php index.html index.htm default.php default.htm default.html; proxy_set_header Host $host; proxy_set_header X-Forwarded-For $proxy_add_x_for

什么是分库分表分库:按照一定的规则将数据分到多个苦中,主要解决单个库连接并发过多,单机数据库顶不住压力的问题分表:将单个数据库里的某一张表,按照某个规则分为多张表,主要解决单张表数据过多的问题,减轻单表压力怎么分分库按业务不同来分,专库专用,微服务使用数据库的场景就是典型代表分表将字段较多的表,拆分成多个表,就是大表拆分成多个小表。访问次数频繁的字段拆分至核心表,数据库加载数据时会更多只加载核心表数据到内存中,减少磁盘IO,提高性能将一张表按一定的规则(简单的有哈希)切分成多个结构相同的表,按照规则来存储/读取数据,切分出来的每张表只储存原表的一部分数据。能够解决单表数据量过大。还可以将切分的表存放至不同的库中,实现分布式,进一步提高性能Go中可以如何实现在代码中实现,如repo层/data层中手动对传入的参数进行计算,侵入性比较强,但是调试方便ORM框架中使用中间件,由中间件来解析语句并计算,应用代码中无感,如GORM的Sharding在应用于数据库中加一层代码,由数据库代理来实现,类似第二种方案,只不过是外部中间件完成

业务上碰到一个需求,用户在已经发布的web中自制vue3组件,还需要接收web在运行时产生的数据并渲染定制的页面。在最初学习vue的时候学的是vue2,当时直接在script中new Vue()以达到使用vue的功能,后来逐渐接触项目工程化,借助npm、yarn、vite直接来创建项目,渐渐忘记了vue最初的模样。经过一段时间摸索,vue3也能够实现此方法。项目背景给用户一个代码编辑页面,分别可以编辑template、js和css,然后在需要展示的地方再对用户编写的组件进行渲染。实现思路正常开发一个vue网页的流程为,使用cli创建项目、编写代码、编译最后发布,而编译这一步就会将代码编译为不需要vue也能够运行的普通代码,而用户编写的肯定不能使用这个流程,不然每次用户写完就要重新编译发布,并且用户所编写的代码文件也是存储在数据库中的,这显然不适合。前端从数据库拿到用户所写的js文件,肯定是不能直接运行的,第一步就是将字符串格式的js代码转为js对象,然后再运行。当然,转为js对象后也不能直接运行,因为本地编写的代码在编译后就没有Vue这个环境了,直接调用new Vue()方法是行不通的

使用kratos自带http transport实现文件下载上传功能,并且可以使用中间件。文件的下载接口可以使用proto定义,上传目前还未找到完美方法,为了统一,采用不定义在proto中定义,自行在server中实现。为什么上传接口不能使用proto定义?上传接口实际上可以使用proto定义,但是在解析入参时是不能解析上传的字节类型,入参的Content-Type类型只支持: x-www-form-urlencoded、json、xml、proto、yaml,而上传文件我希望以只读字节流readCloser的方式,这样可以方便使用io.Copy()的方式实现上传,而不是将文件数据转换成[]byte进行传输看一段官方的实现方式原代码 · GitHub,已简化。func downloadFile(ctx http.Context) error { f := excelize.NewFile() return f.Write(ctx.Response()) } func main() { var opts = []http.ServerOption{

限流限制某服务在一段时间可以被调用的频率。一般用于防止客户端请求过多,导致服务端拥堵的手段,也是防止ddos的一种手段。常用限流算法有三种:滑动限流漏斗限流令牌桶限流time/rate是官方实现的令牌桶算法限流器Go官方限流time/rate安装go get golang.org/x/time/rate构造限流器相关函数type Limit float64 func Every(interval time.Duration) Limit { if interval <= 0 { return Inf } return 1 / Limit(interval.Seconds()) } func NewLimiter(r Limit, b int) *Limiter { return &Limiter{ limit: r, burst: b, } }NewLimiter有两个参数:第一个是填充令牌的速度,默认已秒为单位。如r=10,则说明这个限流器会每秒填充10个令牌。第二个是为桶的容