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 微信会员卡接入微信支付商户号收款
  • ¥15 如何获取烟草零售终端数据
  • ¥15 数学建模招标中位数问题
  • ¥15 phython路径名过长报错 不知道什么问题
  • ¥15 深度学习中模型转换该怎么实现
  • ¥15 HLs设计手写数字识别程序编译通不过
  • ¥15 Stata外部命令安装问题求帮助!
  • ¥15 从键盘随机输入A-H中的一串字符串,用七段数码管方法进行绘制。提交代码及运行截图。
  • ¥15 TYPCE母转母,插入认方向
  • ¥15 如何用python向钉钉机器人发送可以放大的图片?