编程习惯
1、接口
接口路由和参数格式:
路由以 https://xx.xxx.com/xxx/xx/is-bind-card 形式对外,后面的形式统一以 - 连接字符,参数以 access_token 形式对外,小写加下划线
2、代码格式
每进去一个公司在编写代码前,都必须要询问公司的代码格式是怎样的,路由形式、参数格式、变量格式、代码风格等,保持一致美观。。。如无,则按照上面的形式。。。
3、返回接口格式:
借鉴下大公司代码的返回格式,尽量json,一个值的情况也用 object 形式
4、检查写的每个接口的执行时间,尽量优化,减少IO、数据库连接、减少内存消耗等
5、日志
任何接口、重要位置都要留下执行日志:
任何接口调用的参数和返回值、功能函数执行的重要步骤、脚本执行的重要步骤、出错记录的错误
日志规范,标准定义等:FATAL、ERROR、WARN、INFO、DEBUG
日志不要有过多无效的、没用的,无法定位问题的,需优化更新
debug.log:业务调试信息。
info.log:业务关键步骤信息。
warn.log:业务的警告信息,例如超过临界值。
error.log:业务发生的错误以及堆栈信息。
sql_info.log:超过10ms的SQL调用。
api_info.log:api调用的关键信息。
rpc_info.log:rpc调用的信息。
日志格式参考:
traceId,日志追踪使用的唯一ID
UID
请求客户端IP(rpc日志中记录目标服务端IP端口)
请求路由
请求方式
请求参数
请求body
请求头信息
响应状态
响应body
处理耗时
日志的参数一定要带有能够标识用户的唯一ID,uid、phone或者其他都可以,不要用会失效或变化的值,如:token
6、任何代码都要有 try...catch...,正式环境绝对不要输出错误,PHP的内置函数记得在前面加 @
7、php 换行不要再用 \n,一律用 PHP_EOL
8、类名、函数名用小驼峰写法,变量名用小写加下划线(go是小驼峰),常量名用大写加下划线(go无下划线)
9、接口超时记得设置重试策略,重试再报错就放进缓存,缓存一定要容易辨识和使用,由脚本或人工解决
10、调用第三方接口防范不稳定的风险,可以将不是实时更新的信息保存一份到缓存,获取接口失败时就用缓存的数据,但是数据比较重要的就还是实时报错
11、使用消息中间件,提高使用体验,其他处理丢给后续任务处理,即异步处理
12、接口的幂等性很重要,特别只要是更新、插入、删除操作都应当是幂等性
13、能同步的尽量同步,可以异步的分开异步
14、避免多个if-else:
1、if 直接 return
2、确定值变成数组或map,取值返回
15、优化旧业务时要使用配置,并在配置里设置开关,可起到不更新代码实时切换新旧业务的作用
16、能设置成配置的一定要设置成配置,不要写死在代码里,可随时切换或更改变量
17、上线三把斧:可灰度、可回滚、可
18、http连接应考虑连接数、请求超时、连接释放等
19、对应并发量很低的业务或者后台管理的简单请求,可直接查库;但是假如连接几个表的,或者运行很久的,或者数量级很高的,要使用缓存
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现