每周更新Go技术交流群的群问答内容,有需要可发我Go加群讨论学习。

并发控制

waitGroup.done()不是必须写在main方法中吗? 为什么我的协程没有成功等待?

:如果用了wait group,请求就直接卡住了,如果只有一个goroutine那和直接调用函数没有区别其实。你是想请求立刻返回,然后其他数据稍后返回的话,用中间件比如kafka。或者用回调callback

错误现场

错误原因:没有能成功等待goroutine执行完,done要放goroutine里,外面是wait

参考用例

var wg sync.WaitGroup
sList := []string{"a", "b"}
wg.Add(len(sList))
for _, d := range sList {go func() {defer wg.Done()fmt.Println(d)}()}
wg.Wait()

数据竞争

如果不同的线程写同一个map的不同key内容是不是不用sync.Map了?会存在数据竞争吗?但是如果我make的时候提前指定容量呢?

:会影响的,估计map中的hmap会影响到,有几率会在运行时报错

机器马:你在用之前没法确定会用哪个key啊,除非你再用结构体封装一层

:我想到两个办法,1是用这个,还有一个是弄个channel,如果数据用途不一样,弄成结构体channel,用一个goroutine来接收他们。单独用一个线程来接受数据,go这个东西就是个语言,怎么好用怎么来,虽然一直是在推channel,但只要实现需求。

sync.Map为什么没有len测长度方法?

Mike: 看来有人也遇到这么问题,为杀map支持len(),而sync.Map不支持。有兴趣的可以看看issue. 简单说官方认为 map 本来就不应该有length的实现。

机器马: 2017年社区就在吵要不要加个len方法了。一般syncmap都不会单独使用,而是封装到结构体里,然后再写一层方法,所以一般就会在这一层做count,用原子操作计数。

追问sync.Map 这个Range 方法有个返回值,是bool是用来返回是否rangemap吗?range如何处理碰到到空的?

:这个bool是传入函数的返回值,调用完以后如果是Map是空的,实际上就什么也没做,不会给返回。里面给迭代,你传入的函数处理下k v的行了。没办法判断是否为空。

登陆验证

我们可以用UUID生成我们的token,为什么还要用jwt呢(redis中存储token和用户信息对应关系)?

Mike: 无状态 jwt不在服务端存储任何状态。RESTful API的原则之一是无状态,通过redis存储token和用户信息,违背了无状态原则。

Mike: JWT的优点:

  1. 可扩展性好 应用程序分布式部署的情况下,session 需要做多机数据共享,通常可以存在数据库或者redis里面。而jwt不需要。
  2. 无状态 jwt不在服务端存储任何状态。RESTful API的原则之一是无状态,发出请求时,总会返回带有参数的响应,不会产生附加影响。用户的认证状态引入这种附加影响,这破坏了这一原则。另外jwt的载荷中可以存储一些常用信息,用于交换信息,有效地使用 JWT,可以降低服务器查询数据库的次数。

Mike: 缺点:由于jwtpayload是使用base64编码的,并没有加密,因此jwt中不能存储敏感数据。而session的信息是存在服务端的,相对来说更安全。

:关于前端现实当前是哪个用户的问题,只需要后端把用户基本信息存cookie里就可以了。后端用token获取用户信息,把二者分离开。

:关于Mike所述的第一个优点,实际上也有弊端,因为必须等待token记录的时间到期,jwt才会判定token过期,服务端无法主动过期。也无法做多平台挤出登陆,类似于QQ那样子。
gtoken就是存redis

此用户名已被占用: jwt一般还要再加密吧?我记得是有rsa
:确实是要加密的

宋跑跑:签名加密?

此用户名已被占用: 难道不是吗? 不然token裸奔。

宋跑跑 (宋跑跑): 害 信息其实都能拿到了。

异常处理

go你们在项目中都是怎么异常处理的呀,java是抛出自定义有业务异常然后全局异常捕获?

张朝胤Golang不是if err=nil?全局try catch怎么处理?

Mikefmt. Errorf 可以包装多层错误,再用 errors.ls集中判断。没必要把java里面那一套带进Go,这两门语言的哲学本来就不一样。

宋跑跑recover

国玮exception != error,错误是错误 异常是异常,错误是可以考虑降级处理 不影响程序运行的 异常反之。例如最常用的 error 级别,Go 语言贡献者 Davio 认为,对错误进行降级处理后,应该打印 info 级别的日志,这意味着我处理了错误,或者往上抛并 warp 它。不过我不是很赞同这个观点 infoerror 的处理是完全不同的。错误就该打出来。

国玮: 对于错误 其实Go的哲学就是 error is value,你把它当做一个值来处理,exception 是那种会让程序崩溃的,崩溃恢复用recover就行。

吆吆好叼啊:可以这么理解吗?service层出现异常直接返回,controller层调用service层方法进行处理,如果出现错误,controller层返回前端自定义异常json数。

国玮: 可以,调用者处理错误。不需要像java那样抛出业务异常,有个专门的对controller层处理的异常处理类。但是这句话里面,要注意,是错误,不是异常!要弄清楚它们的概念呀。

国玮Java 中的异常,是可以继承的,那么就是说父 exception 可以接收一切 子 exception,这就没有做到细分。

国玮: 错误可以用 Wrap 一层一层往上抛(error std lib 的一个方法),大概意思就是 Warp 去包装错误,为错误提供更多的“证据”和“线索”,但是并没有真正的处理错误,处理错误本质上还是交给调用者。

Mike: 其实很灵活的,对于错误处理完全看业务需要,有些错误可以跳过,有些不行,必须得返回。

国玮: 嗯嗯,在实际编码中,确实是这样的,不过 Dave 认为,如果你对错误不关心,那么你也不应该关心它返回的值。可能是提醒我们要谨慎吧!

其他

大家有go 单体项目推荐吗,我阅读阅读(最好是格式规范)?

https://github.com/golang-standards/project-layout

本文由mdnice多平台发布

一期Go群问答-并发控制-数据竞争-错误与异常相关推荐

  1. MYSQL 集群的数据节点错误信息归档

    1.数据节点的IP地址和其它的客户端主机冲突导致的错误. 管理节点报告: ndb_mgm> Node 4: Forced node shutdown completed. Caused by e ...

  2. Redis集群CentOS系统配置企业级数据备份方案以及数据恢复的操作(在开启AOF功能下恢复冷备RDB文件数据,保持AOF和RDB双开情况下恢复数据及错误的数据恢复步骤详解)

    1. 设置每小时保存一份 /var/redis/6379/dump.rdb 文件至指定目录(我这边存放在 /usr/local/redis_backup 目录下),并删除48小时前的文件.     为 ...

  3. 咱们的课程里,有微信的这种菜单示例吗?---酷课堂iOS交流群问答整理(201810期)...

    酷课堂iOS交流群 我们是一个什么样的组织: 酷课堂iOS交流群,聚集了一群热爱技术.有趣.有料,平均Q龄在10年以上的"老司机",他们遍布在全国/球各地,有知名企业iOS工程师. ...

  4. 问下这个审核被拒怎么解决呢?——酷课堂iOS交流群问答整理(201806期)

    酷课堂iOS交流群问答整理(201806期) 以下内容由@客服妹子爬楼整理,希望小伙伴的这些提问,对你有帮助/启发,感谢资源贡献者:Mi~.appleMan.赖着.蒋哥.Rocky.群主.诚绅.思.其 ...

  5. 求大神帮忙看一下,这个问题我百度也没有答案!(酷课堂iOS交流群问答整理201811期)

    酷课堂iOS移动开发交流群问答精华整理(201811期) 以下内容由@小课(coolketang001) 爬楼整理,希望小伙伴碰到的这些问题,对你有帮助/启发.   我们是一个什么样的组织: 很干.很 ...

  6. 数据竞争(data race)问题分析的利器——valgrind的Helgrind

    数据竞争(data race)是指在非线程安全的情况下,多线程对同一个地址空间进行写操作.一般来说,我们都会通过线程同步方法来保证数据的安全,比如采用互斥量或者读写锁.但是由于某些笔误或者设计的缺陷, ...

  7. 拆分命令_在MongoDB分片集群中拆分数据块chunks

    MongoDB Manual (Version 4.2)> Sharding > Data Partitioning with Chunks > Split Chunks in a ...

  8. mysql双节点安装_快速安装及配置MySQL Replication双主节点集群--及改变数据保存目录...

    192.168.1.101  master/slave 192.168.1.102  slave 192.168.1.103  slave 操作系统均为centos6.5 原理图: 1. 分别安装my ...

  9. 并发编程的数据竞争问题以及解决之道

    Go语言以容易进行并发编程而闻名,但是如果稍不注意,并发程序可能导致的数据竞争问题(data race)就会经常出现在你编写的并发程序的待解决Bug列表中-- 如果你不幸在代码中遇到这种错误,这将是最 ...

最新文章

  1. 使用Python,OpenCV+OCR检测护照图像中的机器可读区域(MRZ Machine-Readable Zones)
  2. 2020秋季人工神经网络作业登记与批改
  3. python3用什么系统好_学python用什么系统【怎么学好python】
  4. thinkphp5 消息队列thinkphp-queue扩展
  5. kudu参数优化设置,让集群飞起来~
  6. a 标签中 rel=“noopener noreferrer“属性的含义和功能
  7. 并查集的补集 (关押罪犯)
  8. eclipse中设置java注释模板
  9. 把一个服务器的数据库导入到另一台服务器中
  10. VS Code:4个中文乱码问题及解决方法
  11. url 在线解码 工具
  12. 国际贸易基础(一)找客户
  13. Unterminated regular expression 和正则表达式
  14. 2021年声纹识别研究与应用学术研讨会笔记
  15. 一文带你了解什么是API和SDK
  16. MySQL忘记密码,如何重置
  17. mysql error 1146错误解决办法
  18. Android 音视频入门/进阶教程
  19. 无需工具修改文件创建时间
  20. weex项目实战篇(二)

热门文章

  1. css彩色波浪动画,纯css实现波浪动画【转】
  2. GitHub图片不能正常显示的解决办法
  3. 猿如意|程序员的如意神器之【chat GPT】测评。
  4. python编程midi键盘按键错乱_电脑键盘按键错乱怎么回事 电脑键盘按键错乱原因【图文】...
  5. 小荷才露尖尖角,和Flutter应用说你好
  6. java生成随机数字和字母
  7. 第一模块 jdk与jre、==与equals、Math.round(-1.5)、 String、操作字符串的类、字符串反转、抽象类必须要有抽象方法吗、普通类和抽象类、BIO NIO AIO
  8. Linux ftp服务器虚拟用户的建立
  9. 升级Windows11后鼠标卡顿
  10. 嵌入式开发专业术语概念汇总