What is the difference between 32-bit and 64-bit Ubuntu? I've heard the 64-bit platform performs better and can detect more than 4GB of RAM. Also, while some apps haven't ported to 64-bit yet, ia32-libs
lets a 64-bit machine run them.
If so, why not promote 64-bit over 32-bit?
I believe the main question when choosing between 32 and 64 bits is not "Does my processor support 64 bits — if so then I should use 64 because that's twice as good", but "How much memory do I have?".
64-bit programs use about 50% more memory then their 32-bit counterparts. The results of this are:
less code/data can fit into processor caches -> more cache misses -> your super-fast processor waits more for memory controller to fetch data from RAM. Processor also needs to read more data because it's more bloated.
Linux uses non-allocated RAM to cache disks. Less free memory available -> less space for disk caches -> slower disk access
Once you're out of RAM and the system starts swapping - disk access is thousands times slower than RAM, so any potential benefits of 64-bit code (see below) are flying out of window.
On the other hand, in 64-bit mode processor has more registers, so it doesn't need to access memory that often, also, some calculations (64-bit numbers etc.) are more efficient. So generally, code which is not memory-restricted runs slightly faster in 64-bit mode.
So, if your system has, say, 2GiB of RAM or less then I would definitely choose 32 bits. More than 4GiB - the benefits of 64 bits are becoming more prominent. Around 4GiB is a "grey zone" - you need to make a choice yourself.
Here are screenshots of a (rather old) vanilla Ubuntu running in a VirtualBox with 1GiB RAM:
32 bit: uses 388 MiB of RAM right after booting, no additional applications running (from the screenshot, 397780KiB, which is 388MiB)
64 bit: uses 491 MiB of RAM (from the screenshot, 503452KiB = 491MiB)
Additionally, in my testing, a web-application written in Python used up to 60% more memory on a 64-bit machine which resulted in a test suite running in 380 secs on a 32-bit machine but taking 523 seconds on a 64-bit one (both with 1GiB of RAM). If the machines were not RAM-limited the results would likely be different (as phoronix tests show).
Here are some more thorough and recent tests: http://kernel.ubuntu.com/~cking/x32/Quantal-x32-power-memory-comparisons.ods
Basically, it's like giving up 30% of your RAM in exchange of possible gain of 10% CPU speed.
If you don't care to learn the technical details, select the recommended 32-bit version.
64-bit is generally faster, even if objectively hard to notice. This is has less to do with the 64-bit data width, but with the availability of 16 over 8 common CPU registers on the whole instruction set. The disadvantage of wasting more memory for management and larger pointers is thereby mostly levelled out.
The practical problem: not everyone has a AMD64 compatible CPU. Promoting 64-bit over the standard i686 version would lead to more user frustration. Therefore for the next few years, it's less confusing to present the 32-bit version to the average user. It's not exactly a problem for anyone in the know, since the 64-bit version is readily available. And we amd64 users don't have any disadvantage from that situation, except for the initial download. All packages are available in both architectures.
Under the circumstances the Ubuntu download page looks okay to me. It says "32 bit (recommended)", but that "recommended" translates to "fewer issues, if you don't know all the technical details of your computer". For the netbook edition download page, there isn't even the choice, because some Intel atom CPUs are 32-bit only even in 2010!
So in conclusion, I think eschewing the compatibility problems is still necessary. However, I agree that there should be at least a shiny footnote along the lines that -64 is faster than -32, and recommended IF (BUT ONLY IF) the target system supports it.
The general rule is that 32-bit (OS and Application) will run on 64-bit, but 64-bit (OS and Application) does not run on 32-bit:
A 64-bit compatible CPU is needed to install a 64-bit OS. Check with the manufacturer of your PC to find out if your system is 64-bit compatible.
32-bit systems have a 4 Gigabyte RAM memory limit, which means they cannot address more than 4GB of RAM even if more is installed on the system (Not all of it will be used). Workarounds are available, but hard to do for an average user.
Note: Ubuntu 12.10, and newer will support PAE automatically. Prior to 12.10, you have the option to choose PAE support depending on your CPU. PAE extends maximum RAM on 32-bit to 64GB, more inforamtion can be found here.
64-bit editions have additional advantages, including an increased bandwidth, hardware enabled DEP (data execution prevention) and better Kernel protection.
The majority of 32-bit applications will continue to work on a 64-bit systems, but some applications do not work at all, or will run slower.
For more information you can look at 32-bit and 64-bit
1Source: Microsoft
As pointed here in Phoronix: "With the Ubuntu multi-arch situation being cleared up, most applications and plug-ins now working fine on 64-bit (such as Adobe Flash and Java), and 64-bit being usually much faster than 32-bit, there really is no big reason not to move to the x86_64 version."
Although it is discussed if 64bit will be indicated as the default instead of 32bit, I think you have some performance gain with the first. See these benchmarks.
And a word of your "low" RAM memory from Phoronix: "[S]ome Ubuntu developers have been overly concerned about 32-bit netbooks being out there still and for systems that only have 2GB of RAM where using x86_64 software may lead to running low on memory and thus increased SWAP usage. However, for a far majority of users, they're much better off in a 64-bit world."
Maybe you can install it and watch if the system uses the swap often.
For me the most important was the fact that You can not use ZFS filesystem on 32bit os, because it is simply unstable there due to vmalloc limits of 32bit os (regardless of PAE or nonPAE). That was a reason for me to reinstall to 64bit, and I never looked back. Even NVIDIA has few lines about vmalloc thing in "troubleshooting" pages, ending by encouraging users to switch to 64bit kernels.
There is an adressing limit of 1GB in 32bit mode, so even if it can use up to 4GB, only 1GB is so called "low" and the rest is "high memory" which is not that general. And 1GB is really small number, nowadays.. Try #free -l
I looked into this for Ubuntu Precise LTS a while back. Here are some results of some analysis I ran:
http://kernel.ubuntu.com/~cking/power-benchmarking/blueprint-foundations-p-64bit-by-default/low-memory-systems/readme.txt
http://kernel.ubuntu.com/~cking/power-benchmarking/blueprint-foundations-p-64bit-by-default/hpmini-and-x220-tests/results-3/results.txt
Basically, if you have 4GB or less is OK, for more than 4GB consider using i386-pae or amd64. 64 bit systems consume more memory (for example, pointers are 64 bit in size) but you may see a performance win on 64 bit systems because of optimisations that use 64 bit copies or use the extra CPU registers that are available in 64 bit mode.
As stated by previous posters, 64-bit vs 32-bit refers to the size of data which can be moved in one operation by the computer. This relates to the size of the registers on the CPU and the width of the busses (a register is just holds data for the CPU to operate on, they used to be tiny in consumer hardware and have been growing since the inception of home computing. Busses connect different parts of a motherboard together, they are the highway on which the data flows around).
The issue is that most OSes had some real issues when moving over to 64-bit operations, with poor support for drivers and applications. Often applications actually had worse performance in early versions. Given that there is no real reason for most people to jump in the deep end, the Linux powers-that-be seem to be taking the move a little slower than cough _other_ OSes, slow but steady.
Basically I would say use 64 bit version if you need it.
If you are mainly browsing the web, watching youtube, hang around on facebook, watch films etc. then 32 bit is better because you don't need any good hardware to do those things.
If you play games on Steam, WINE etc., run loads of programs, do some media editing and such then 64 bit is best choice.
so casual use then 32 bit OS, Advanced use then 64 bit version.
For plain user experience official Ubuntu site suggests 32-bit versions due to more flexible tuning.
I count here also means the data consistence.
There are exists a very many points for any pro and contra. My view is a great performance of 64-bit OS on Intel Architecture 64-bit processor directly related to using 64-bit software and drivers, that can give you the chance to beat regular 32-bit performance.
Note that using of 32-bit software on 64-bit OS sometimes can cause a bad performance and even overheating in very different cases.
However, by your signed components and this reference:
Intel® Extended Memory 64 Technology: 64-Bit Desktop Computing
... better experience possible with 4Gb+ of memory.
I count this will good and not very expensive solution for you.
And yeah, using both systems in parallel able to bring you more clear understanding your configuration and versatility in the meanings.
To be honest, I haven't perceived any difference except from slightly reduced time required to compile programs and to encode video. Other than that, it feels the same to me. I have noticed tho, that what really makes a difference in terms of performance is the video driver. I guess the 32bit video drivers are better supported. I recently installed the latest nVidia 260 driver on a 32bit system and it made a LOT of difference. I'm currently using 32bit.