I saw some cheap development boards in ebay that seem ideal for what I want like this one:
The world is full of AVR development boards. As long as the board is of reasonable quality it really doesn't matter what you chose as a beginner. There is enough stuff in an AVR, or any other up-to-date microcontroller, that you can be busy for ages just learning all the on-chip periphery.
There are a gazillion ways to program an AVR. With AVRs I prefer the following programming techniques in that order.
1) ISP SPI (available on almost any AVR),
2) JTAG (available only on larger AVRs, programmers are typically more expensive),
3) PDI (only on the XMegas),
4) TPI (only on some of the more obscure ATTiny's, must ATTiny's use ISP instead),
5) bootloader (there are many different types)
6) High-Voltage serial or parallel programming (this is from the stone-age and can't be done in-system, not fun)
Note that using a bootloader is almost my least popular programming technique. To get a bootloader into an AVR you need to have a normal programmer first. The chicken-egg problem.
Exceptions: You buy an expensive AVR where someone already programmed a bootloader into. The prices for these are inflated and after buying a few you have spent so much you could have bought a good programmer. The second exception are some of the USB AVRs, as they come with a bootloader from the factory.
And High-Voltage programming? Mehhh. Some market it as the great way to rescue a bricked AVR. I say, just avoid bricking an AVR. But if you brink one, get a new one. It is a waste of time and often also money to do AVR high-voltage programming.
I highly recommend to use an original Atmel programmer (programmer == programming hardware), especially for beginners. No clones, no shit from some Chinese fly-by-night-operation, no ghetto-style DIY programming cable, no contraption the guy around the corner suggests, no on-board programmer on the dev board of dubious quality, no stuff you found in some garbage bin. Yes, they work sometimes, for some people. But I promise you, if such junk doesn't work for you, you will spend an endless amount of time fighting the problem and ripping your hair of. $35 for an original Atmel AVR MkII ISP programmer then won't look so bad any more.
Again, don't fall for clones. Just because some company uses the same enclosure in the same color and pretends to deliver an MkII programmer doesn't mean the junk will work.
Get a dev board that has an ISP interface, or at least all ISP pins should be available, and not unduly loaded by external periphery. I prefer the official 6-pin ISP connector, but especially cheap Chinese boards like to have the old 10-pin ISP connector. Then you need to build an adapter.
Regarding programming software, there are only few usable, however not perfect, classes of programming software.
1) The original Atmel programming software (typically part of AVR Studio, Windows only, except the FLIP programming software, which is anyhow shit)
2) avrdude (many operating systems)
3) dfu-programmer (if you need a working replacement for FLIP, which is for a particular kind of bootloader, called DFU)
Don't get lured into programming software shit just because it has a GUI. Stay away from PoS like ponyprog and other rubbish. Again, the PoS works for some people some time. But if it doesn't work for you, you are toast.
The worst combination is a dubious programmer with dubious programming software. Especially as a beginner you won't know where the problem is. The programmer, the programming software or your code. Using a trusted and tried programmer and programming software takes two factors out if the equation.
C compiler: There are good commercial compilers available, an OK free compiler (GCC based, several variants, see below), and at least one rubbish commercial compiler (MikroE C).
Free GCC compiler:
WinAvr is a pre-made AVR GCC for Windows and can be integrated into AVR Studio 4 and 5.
"Toolchain" (what a rubbish, unimaginative name), is a Windows AVR GCC hacked by Atmel in unknown ways, and comes with AVR Studio 5. But AVR Studio 5 has a general problem: Most of it doesn't work. My recommendation, if you want to work on Windows, stay away from Studio 5, and instead use Studio 4. Studio 4 requires you separately find, download and install WinAvr.
avr-gcc is the GCC version for Linux and Unix systems. Always build your own avr-gcc if you work on Linux or Unix. The ones that typically come with Linux distributions are outdated and miss important patches. Look for the "bingo600 scripts" if you want to build your avr-gcc on Linux.
IDEs:
Atmel has an own free IDE. They only support Windows. The working, but mediocre and boring IDE is the already mentioned AVR Studio 4. Their latest IDE is the fucked-up AVR Studio 5.
In general you can use any IDE you like, as long as the IDE allows to integrate a compiler. Programming is a problem, because the only programming software Atmel officially supports is the one coming with AVR Studio. Some people therefore use their own IDE and hop over to Studio if they need to program. Deep down hidden in the Studio distribution are a few command-line versions of programming software. Some integrate those in their Windows IDEs.
On Linux or Unix it doesn't matter what you use, because Atmel gives a shit about Linux/Unix programmers. Use what you like and know, use a tool called Mfile to generate a Makefile for managing compilation, and use avrdude as programming software.
And a final hint:
As a beginner, do not mess with the fuses until you have understood them. Really, really read the datasheet, word by word, notice the difference between an external crystal and an external oscillator, and don't mess the corresponding fuses up. Plan fuse settings ahead and tripple-check that you have got the right values. Even the descriptive fuse settings in AVR Studio have been known to be wrong. And the 3rd party online tool
http://www.engbedded.com/fusecalc/ is based on the same database.