当我输入uname -a时,它会给出以下输出。
Linux mars 2.6.9-67.0.15.ELsmp #1 SMP Tue Apr 22 13:50:33 EDT 2008 i686 i686 i386 GNU/Linux
我怎么知道给定的操作系统是32位还是64位?
这在编写配置脚本时很有用,例如:我为什么体系结构构建?
当我输入uname -a时,它会给出以下输出。
Linux mars 2.6.9-67.0.15.ELsmp #1 SMP Tue Apr 22 13:50:33 EDT 2008 i686 i686 i386 GNU/Linux
我怎么知道给定的操作系统是32位还是64位?
这在编写配置脚本时很有用,例如:我为什么体系结构构建?
如果您运行的是64位平台,那么在uname -a的输出中会看到x86_64或类似的东西
运行特定的机器硬件名称
uname -m
你也可以打电话
getconf LONG_BIT
哪个返回32或64
试试uname -m。它缺少uname——machine,输出:
x86_64 ==> 64-bit kernel
i686 ==> 32-bit kernel
否则,对于Linux内核,而是CPU,输入:
cat /proc/cpuinfo
or:
grep flags /proc/cpuinfo
在“flags”参数下,您将看到各种值:参见“/proc/cpuinfo中的flags是什么意思?” 其中一种是lm: Long Mode (x86-64: amd64,又称Intel 64,即64位)
lm ==> 64-bit processor
或者使用lshw(如下文由Rolf of Saxony所述),而不使用sudo(只是为了控制cpu宽度):
lshw -class cpu|grep "^ width"|uniq|awk '{print $2}'
注意:你可以安装一个64位CPU和一个32位内核。 (正如ysdx在他/她自己的回答中提到的,“现在,一个系统可以是多拱的,所以它无论如何都没有意义。你可能想要找到编译器的默认目标”)
该系统是32位的。uname中的iX86意味着它是32位体系结构。如果它是64位的,它会返回
Linux mars 2.6.9-67.0.15.ELsmp #1 SMP Tue Apr 22 13:50:33 EDT 2008 x86_64 i686 x86_64 x86_64 GNU/Linux
如果您使用的是64位操作系统,uname -a的输出信息中有x86_64或ia64,而不是i686。因为你没有这两条弦中的任何一条;你有一个32位的操作系统(注意,这并不意味着你的CPU不是64位)。
关于答案“getconf LONG_BIT”。
我用C语言写了一个简单的函数:
/*
* check_os_64bit
*
* Returns integer:
* 1 = it is a 64-bit OS
* 0 = it is NOT a 64-bit OS (probably 32-bit)
* < 0 = failure
* -1 = popen failed
* -2 = fgets failed
*
* **WARNING**
* Be CAREFUL! Just testing for a boolean return may not cut it
* with this (trivial) implementation! (Think of when it fails,
* returning -ve; this could be seen as non-zero & therefore true!)
* Suggestions?
*/
static int check_os_64bit(void)
{
FILE *fp=NULL;
char cb64[3];
fp = popen ("getconf LONG_BIT", "r");
if (!fp)
return -1;
if (!fgets(cb64, 3, fp))
return -2;
if (!strncmp (cb64, "64", 3)) {
return 1;
}
else {
return 0;
}
}
“getconf”是个好主意!
我想知道在Debian中构建软件的具体情况(安装的Debian系统可以是32位版本,具有32位内核、库等,也可以是64位版本,其中的内容是为64位而不是32位的兼容模式编译的)。
Debian包本身在实际创建包含所有元数据(包括平台体系结构)的包时需要知道它们是用于什么体系结构的(当然),因此有一个打包工具可以输出它以供其他打包工具和脚本使用,称为dpkg-architecture。它既包括它被配置为构建的目的,也包括当前主机。(通常情况下,这些都是一样的。)64位机器上的输出示例:
DEB_BUILD_ARCH=amd64
DEB_BUILD_ARCH_OS=linux
DEB_BUILD_ARCH_CPU=amd64
DEB_BUILD_GNU_CPU=x86_64
DEB_BUILD_GNU_SYSTEM=linux-gnu
DEB_BUILD_GNU_TYPE=x86_64-linux-gnu
DEB_HOST_ARCH=amd64
DEB_HOST_ARCH_OS=linux
DEB_HOST_ARCH_CPU=amd64
DEB_HOST_GNU_CPU=x86_64
DEB_HOST_GNU_SYSTEM=linux-gnu
DEB_HOST_GNU_TYPE=x86_64-linux-gnu
您可以只打印其中一个变量,或者使用命令行选项对dpkg-architecture的值进行测试。
我不知道dpkg-architecture是如何推导体系结构的,但是您可以查看它的文档或源代码(dpkg-architecture和dpkg系统的大部分代码都是Perl)。
如果一个二进制文件在可用的二进制文件中受到严重限制(例如在initramfs中),我的同事建议:
$ ls -l /lib*/ld-linux*.so.2
在我的ALT Linux系统中,i586有/lib/ld-linux.so。2和x86_64有/lib64/ld-linux-x86-64.so.2。
在Bash中,使用整数溢出:
if ((1 == 1<<32)); then
echo 32bits
else
echo 64bits
fi
它比调用另一个进程或打开文件要高效得多。
如果将1向左移32,得到1,系统就是32位的。 如果将1向左移动64位得到1,系统就是64位的。
换句话说,
如果echo $((1<<32))给出1,则系统是32位的。
如果echo $((1<<64))返回1,则系统为64位。
简单的脚本获得64位或32位
if $(getconf LONG_BIT | grep '64'); then
echo "64 bit system"
else
echo "32 bit system"
fi
如今,一个系统可以是多拱的,所以无论如何它都没有意义。你可能想要找到编译器的默认目标:
$ cc -v 2>&1 | grep ^Target Target: x86_64-pc-linux-gn
你可以尝试编译一个hello world:
$ echo 'int main() { return 0; }' | cc -x c - -o foo $ file foo foo: ELF 64-bit LSB executable, x86-64, version 1 (SYSV), dynamically linked, interpreter /lib64/ld-linux-x86-64.so.2, for GNU/Linux 2.6.32, BuildID[sha1]=b114e029a08abfb3c98db93d3dcdb7435b5bba0c, not stripped
Getconf使用最少的系统调用:
$ strace getconf LONG_BIT | wc -l
253
$ strace arch | wc -l
280
$ strace uname -m | wc -l
281
$ strace grep -q lm /proc/cpuinfo | wc -l
301
你也可以使用环境变量进行检查:
echo $HOSTTYPE
结果:
I386 -> 32位
X86_64 -> 64位
摘自:http://www.sysadmit.com/2016/02/linux-como-saber-si-es-32-o-64-bits.html
[-z ' uname -m | grep 64 '] && echo "32-bit" || echo "64-bit"
基于64位通常是x86_64, 32位是i686等等的事实。