douxie9347 2019-01-15 00:15
浏览 203
已采纳

如何在不同平台和容器内确定GOMAXPROCS?

I am curious how does Go runtime determine runtime.NumCPU() (count of CPUs) on various platforms with wildly different characteristics like Linux, macOS and Windows?

For example on Linux: I'm curious if it uses sysfs (/sys) to look at paths like /sys/fs/cgroup/cpu/cpu.cfs_quota_us to determine how many CPUs exist, or procfs (/proc/cpuinfo) (this will be the wrong value in a container environment where container may have access to fewer CPUs than the host CPU count exposed in this file).

Similarly on macOS, how is this value determined?

I know some applications like JVM relies on cgroups memory info exposed on /sys to set their internal heap size etc.

  • 写回答

2条回答 默认 最新

  • doubi4491 2019-01-15 01:31
    关注

    Go GOMAXPROCS is a function of the number of CPUs. The number of CPUs is a function of the processor architecture: 386, amd64, arm, arm64, mips64, ppc64, s390, etc, The operating system provides an interface to the hardware: Linux, OpenBSD, Mac OS, etc. On Linux, we have SYS_sched_getaffinity.

    See Go source code in src/runtime.

    See Linux documentation command man sched_getaffinity.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 用ns3仿真出5G核心网网元
  • ¥15 matlab答疑 关于海上风电的爬坡事件检测
  • ¥88 python部署量化回测异常问题
  • ¥30 酬劳2w元求合作写文章
  • ¥15 在现有系统基础上增加功能
  • ¥15 远程桌面文档内容复制粘贴,格式会变化
  • ¥15 关于#java#的问题:找一份能快速看完mooc视频的代码
  • ¥15 这种微信登录授权 谁可以做啊
  • ¥15 请问我该如何添加自己的数据去运行蚁群算法代码
  • ¥20 用HslCommunication 连接欧姆龙 plc有时会连接失败。报异常为“未知错误”