412 lines
14 KiB
Markdown
412 lines
14 KiB
Markdown
|
Bitcoin Core version 0.9.0 is now available from:
|
||
|
|
||
|
https://bitcoin.org/bin/0.9.0/
|
||
|
|
||
|
This is a new major version release, bringing both new features and
|
||
|
bug fixes.
|
||
|
|
||
|
Please report bugs using the issue tracker at github:
|
||
|
|
||
|
https://github.com/bitcoin/bitcoin/issues
|
||
|
|
||
|
How to Upgrade
|
||
|
--------------
|
||
|
|
||
|
If you are running an older version, shut it down. Wait until it has completely
|
||
|
shut down (which might take a few minutes for older versions), uninstall all
|
||
|
earlier versions of Bitcoin, then run the installer (on Windows) or just copy
|
||
|
over /Applications/Bitcoin-Qt (on Mac) or bitcoind/bitcoin-qt (on Linux).
|
||
|
|
||
|
If you are upgrading from version 0.7.2 or earlier, the first time you run
|
||
|
0.9.0 your blockchain files will be re-indexed, which will take anywhere from
|
||
|
30 minutes to several hours, depending on the speed of your machine.
|
||
|
|
||
|
On Windows, do not forget to uninstall all earlier versions of the Bitcoin
|
||
|
client first, especially if you are switching to the 64-bit version.
|
||
|
|
||
|
Windows 64-bit installer
|
||
|
-------------------------
|
||
|
|
||
|
New in 0.9.0 is the Windows 64-bit version of the client. There have been
|
||
|
frequent reports of users running out of virtual memory on 32-bit systems
|
||
|
during the initial sync. Because of this it is recommended to install the
|
||
|
64-bit version if your system supports it.
|
||
|
|
||
|
NOTE: Release candidate 2 Windows binaries are not code-signed; use PGP
|
||
|
and the SHA256SUMS.asc file to make sure your binaries are correct.
|
||
|
In the final 0.9.0 release, Windows setup.exe binaries will be code-signed.
|
||
|
|
||
|
OSX 10.5 / 32-bit no longer supported
|
||
|
-------------------------------------
|
||
|
|
||
|
0.9.0 drops support for older Macs. The minimum requirements are now:
|
||
|
* A 64-bit-capable CPU (see http://support.apple.com/kb/ht3696);
|
||
|
* Mac OS 10.6 or later (see https://support.apple.com/kb/ht1633).
|
||
|
|
||
|
Downgrading warnings
|
||
|
--------------------
|
||
|
|
||
|
The 'chainstate' for this release is not always compatible with previous
|
||
|
releases, so if you run 0.9 and then decide to switch back to a
|
||
|
0.8.x release you might get a blockchain validation error when starting the
|
||
|
old release (due to 'pruned outputs' being omitted from the index of
|
||
|
unspent transaction outputs).
|
||
|
|
||
|
Running the old release with the -reindex option will rebuild the chainstate
|
||
|
data structures and correct the problem.
|
||
|
|
||
|
Also, the first time you run a 0.8.x release on a 0.9 wallet it will rescan
|
||
|
the blockchain for missing spent coins, which will take a long time (tens
|
||
|
of minutes on a typical machine).
|
||
|
|
||
|
Rebranding to Bitcoin Core
|
||
|
---------------------------
|
||
|
|
||
|
To reduce confusion between Bitcoin-the-network and Bitcoin-the-software we
|
||
|
have renamed the reference client to Bitcoin Core.
|
||
|
|
||
|
|
||
|
OP_RETURN and data in the block chain
|
||
|
-------------------------------------
|
||
|
On OP_RETURN: There was been some confusion and misunderstanding in
|
||
|
the community, regarding the OP_RETURN feature in 0.9 and data in the
|
||
|
blockchain. This change is not an endorsement of storing data in the
|
||
|
blockchain. The OP_RETURN change creates a provably-prunable output,
|
||
|
to avoid data storage schemes -- some of which were already deployed --
|
||
|
that were storing arbitrary data such as images as forever-unspendable
|
||
|
TX outputs, bloating bitcoin's UTXO database.
|
||
|
|
||
|
Storing arbitrary data in the blockchain is still a bad idea; it is less
|
||
|
costly and far more efficient to store non-currency data elsewhere.
|
||
|
|
||
|
Autotools build system
|
||
|
-----------------------
|
||
|
|
||
|
For 0.9.0 we switched to an autotools-based build system instead of individual
|
||
|
(q)makefiles.
|
||
|
|
||
|
Using the standard "./autogen.sh; ./configure; make" to build Bitcoin-Qt and
|
||
|
bitcoind makes it easier for experienced open source developers to contribute
|
||
|
to the project.
|
||
|
|
||
|
Be sure to check doc/build-*.md for your platform before building from source.
|
||
|
|
||
|
Bitcoin-cli
|
||
|
-------------
|
||
|
|
||
|
Another change in the 0.9 release is moving away from the bitcoind executable
|
||
|
functioning both as a server and as a RPC client. The RPC client functionality
|
||
|
("tell the running bitcoin daemon to do THIS") was split into a separate
|
||
|
executable, 'bitcoin-cli'. The RPC client code will eventually be removed from
|
||
|
bitcoind, but will be kept for backwards compatibility for a release or two.
|
||
|
|
||
|
`walletpassphrase` RPC
|
||
|
-----------------------
|
||
|
|
||
|
The behavior of the `walletpassphrase` RPC when the wallet is already unlocked
|
||
|
has changed between 0.8 and 0.9.
|
||
|
|
||
|
The 0.8 behavior of `walletpassphrase` is to fail when the wallet is already unlocked:
|
||
|
|
||
|
> walletpassphrase 1000
|
||
|
walletunlocktime = now + 1000
|
||
|
> walletpassphrase 10
|
||
|
Error: Wallet is already unlocked (old unlock time stays)
|
||
|
|
||
|
The new behavior of `walletpassphrase` is to set a new unlock time overriding
|
||
|
the old one:
|
||
|
|
||
|
> walletpassphrase 1000
|
||
|
walletunlocktime = now + 1000
|
||
|
> walletpassphrase 10
|
||
|
walletunlocktime = now + 10 (overriding the old unlock time)
|
||
|
|
||
|
Transaction malleability-related fixes
|
||
|
--------------------------------------
|
||
|
|
||
|
This release contains a few fixes for transaction ID (TXID) malleability
|
||
|
issues:
|
||
|
|
||
|
- -nospendzeroconfchange command-line option, to avoid spending
|
||
|
zero-confirmation change
|
||
|
- IsStandard() transaction rules tightened to prevent relaying and mining of
|
||
|
mutated transactions
|
||
|
- Additional information in listtransactions/gettransaction output to
|
||
|
report wallet transactions that conflict with each other because
|
||
|
they spend the same outputs.
|
||
|
- Bug fixes to the getbalance/listaccounts RPC commands, which would report
|
||
|
incorrect balances for double-spent (or mutated) transactions.
|
||
|
- New option: -zapwallettxes to rebuild the wallet's transaction information
|
||
|
|
||
|
Transaction Fees
|
||
|
----------------
|
||
|
|
||
|
This release drops the default fee required to relay transactions across the
|
||
|
network and for miners to consider the transaction in their blocks to
|
||
|
0.01mBTC per kilobyte.
|
||
|
|
||
|
Note that getting a transaction relayed across the network does NOT guarantee
|
||
|
that the transaction will be accepted by a miner; by default, miners fill
|
||
|
their blocks with 50 kilobytes of high-priority transactions, and then with
|
||
|
700 kilobytes of the highest-fee-per-kilobyte transactions.
|
||
|
|
||
|
The minimum relay/mining fee-per-kilobyte may be changed with the
|
||
|
minrelaytxfee option. Note that previous releases incorrectly used
|
||
|
the mintxfee setting to determine which low-priority transactions should
|
||
|
be considered for inclusion in blocks.
|
||
|
|
||
|
The wallet code still uses a default fee for low-priority transactions of
|
||
|
0.1mBTC per kilobyte. During periods of heavy transaction volume, even this
|
||
|
fee may not be enough to get transactions confirmed quickly; the mintxfee
|
||
|
option may be used to override the default.
|
||
|
|
||
|
0.9.0 Release notes
|
||
|
=======================
|
||
|
|
||
|
RPC:
|
||
|
|
||
|
- New notion of 'conflicted' transactions, reported as confirmations: -1
|
||
|
- 'listreceivedbyaddress' now provides tx ids
|
||
|
- Add raw transaction hex to 'gettransaction' output
|
||
|
- Updated help and tests for 'getreceivedby(account|address)'
|
||
|
- In 'getblock', accept 2nd 'verbose' parameter, similar to getrawtransaction,
|
||
|
but defaulting to 1 for backward compatibility
|
||
|
- Add 'verifychain', to verify chain database at runtime
|
||
|
- Add 'dumpwallet' and 'importwallet' RPCs
|
||
|
- 'keypoolrefill' gains optional size parameter
|
||
|
- Add 'getbestblockhash', to return tip of best chain
|
||
|
- Add 'chainwork' (the total work done by all blocks since the genesis block)
|
||
|
to 'getblock' output
|
||
|
- Make RPC password resistant to timing attacks
|
||
|
- Clarify help messages and add examples
|
||
|
- Add 'getrawchangeaddress' call for raw transaction change destinations
|
||
|
- Reject insanely high fees by default in 'sendrawtransaction'
|
||
|
- Add RPC call 'decodescript' to decode a hex-encoded transaction script
|
||
|
- Make 'validateaddress' provide redeemScript
|
||
|
- Add 'getnetworkhashps' to get the calculated network hashrate
|
||
|
- New RPC 'ping' command to request ping, new 'pingtime' and 'pingwait' fields
|
||
|
in 'getpeerinfo' output
|
||
|
- Adding new 'addrlocal' field to 'getpeerinfo' output
|
||
|
- Add verbose boolean to 'getrawmempool'
|
||
|
- Add rpc command 'getunconfirmedbalance' to obtain total unconfirmed balance
|
||
|
- Explicitly ensure that wallet is unlocked in `importprivkey`
|
||
|
- Add check for valid keys in `importprivkey`
|
||
|
|
||
|
Command-line options:
|
||
|
|
||
|
- New option: -nospendzeroconfchange to never spend unconfirmed change outputs
|
||
|
- New option: -zapwallettxes to rebuild the wallet's transaction information
|
||
|
- Rename option '-tor' to '-onion' to better reflect what it does
|
||
|
- Add '-disablewallet' mode to let bitcoind run entirely without wallet (when
|
||
|
built with wallet)
|
||
|
- Update default '-rpcsslciphers' to include TLSv1.2
|
||
|
- make '-logtimestamps' default on and rework help-message
|
||
|
- RPC client option: '-rpcwait', to wait for server start
|
||
|
- Remove '-logtodebugger'
|
||
|
- Allow `-noserver` with bitcoind
|
||
|
|
||
|
Block-chain handling and storage:
|
||
|
|
||
|
- Update leveldb to 1.15
|
||
|
- Check for correct genesis (prevent cases where a datadir from the wrong
|
||
|
network is accidentally loaded)
|
||
|
- Allow txindex to be removed and add a reindex dialog
|
||
|
- Log aborted block database rebuilds
|
||
|
- Store orphan blocks in serialized form, to save memory
|
||
|
- Limit the number of orphan blocks in memory to 750
|
||
|
- Fix non-standard disconnected transactions causing mempool orphans
|
||
|
- Add a new checkpoint at block 279,000
|
||
|
|
||
|
Wallet:
|
||
|
|
||
|
- Bug fixes and new regression tests to correctly compute
|
||
|
the balance of wallets containing double-spent (or mutated) transactions
|
||
|
- Store key creation time. Calculate whole-wallet birthday.
|
||
|
- Optimize rescan to skip blocks prior to birthday
|
||
|
- Let user select wallet file with -wallet=foo.dat
|
||
|
- Consider generated coins mature at 101 instead of 120 blocks
|
||
|
- Improve wallet load time
|
||
|
- Don't count txins for priority to encourage sweeping
|
||
|
- Don't create empty transactions when reading a corrupted wallet
|
||
|
- Fix rescan to start from beginning after importprivkey
|
||
|
- Only create signatures with low S values
|
||
|
|
||
|
Mining:
|
||
|
|
||
|
- Increase default -blockmaxsize/prioritysize to 750K/50K
|
||
|
- 'getblocktemplate' does not require a key to create a block template
|
||
|
- Mining code fee policy now matches relay fee policy
|
||
|
|
||
|
Protocol and network:
|
||
|
|
||
|
- Drop the fee required to relay a transaction to 0.01mBTC per kilobyte
|
||
|
- Send tx relay flag with version
|
||
|
- New 'reject' P2P message (BIP 0061, see
|
||
|
https://gist.github.com/gavinandresen/7079034 for draft)
|
||
|
- Dump addresses every 15 minutes instead of 10 seconds
|
||
|
- Relay OP_RETURN data TxOut as standard transaction type
|
||
|
- Remove CENT-output free transaction rule when relaying
|
||
|
- Lower maximum size for free transaction creation
|
||
|
- Send multiple inv messages if mempool.size > MAX_INV_SZ
|
||
|
- Split MIN_PROTO_VERSION into INIT_PROTO_VERSION and MIN_PEER_PROTO_VERSION
|
||
|
- Do not treat fFromMe transaction differently when broadcasting
|
||
|
- Process received messages one at a time without sleeping between messages
|
||
|
- Improve logging of failed connections
|
||
|
- Bump protocol version to 70002
|
||
|
- Add some additional logging to give extra network insight
|
||
|
- Added new DNS seed from bitcoinstats.com
|
||
|
|
||
|
Validation:
|
||
|
|
||
|
- Log reason for non-standard transaction rejection
|
||
|
- Prune provably-unspendable outputs, and adapt consistency check for it.
|
||
|
- Detect any sufficiently long fork and add a warning
|
||
|
- Call the -alertnotify script when we see a long or invalid fork
|
||
|
- Fix multi-block reorg transaction resurrection
|
||
|
- Reject non-canonically-encoded serialization sizes
|
||
|
- Reject dust amounts during validation
|
||
|
- Accept nLockTime transactions that finalize in the next block
|
||
|
|
||
|
Build system:
|
||
|
|
||
|
- Switch to autotools-based build system
|
||
|
- Build without wallet by passing `--disable-wallet` to configure, this
|
||
|
removes the BerkeleyDB dependency
|
||
|
- Upgrade gitian dependencies (libpng, libz, libupnpc, boost, openssl) to more
|
||
|
recent versions
|
||
|
- Windows 64-bit build support
|
||
|
- Solaris compatibility fixes
|
||
|
- Check integrity of gitian input source tarballs
|
||
|
- Enable full GCC Stack-smashing protection for all OSes
|
||
|
|
||
|
GUI:
|
||
|
|
||
|
- Switch to Qt 5.2.0 for Windows build
|
||
|
- Add payment request (BIP 0070) support
|
||
|
- Improve options dialog
|
||
|
- Show transaction fee in new send confirmation dialog
|
||
|
- Add total balance in overview page
|
||
|
- Allow user to choose data directory on first start, when data directory is
|
||
|
missing, or when the -choosedatadir option is passed
|
||
|
- Save and restore window positions
|
||
|
- Add vout index to transaction id in transactions details dialog
|
||
|
- Add network traffic graph in debug window
|
||
|
- Add open URI dialog
|
||
|
- Add Coin Control Features
|
||
|
- Improve receive coins workflow: make the 'Receive' tab into a form to request
|
||
|
payments, and move historical address list functionality to File menu.
|
||
|
- Rebrand to `Bitcoin Core`
|
||
|
- Move initialization/shutdown to a thread. This prevents "Not responding"
|
||
|
messages during startup. Also show a window during shutdown.
|
||
|
- Don't regenerate autostart link on every client startup
|
||
|
- Show and store message of normal bitcoin:URI
|
||
|
- Fix richtext detection hang issue on very old Qt versions
|
||
|
- OS X: Make use of the 10.8+ user notification center to display Growl-like
|
||
|
notifications
|
||
|
- OS X: Added NSHighResolutionCapable flag to Info.plist for better font
|
||
|
rendering on Retina displays.
|
||
|
- OS X: Fix bitcoin-qt startup crash when clicking dock icon
|
||
|
- Linux: Fix Gnome bitcoin: URI handler
|
||
|
|
||
|
Miscellaneous:
|
||
|
|
||
|
- Add Linux script (contrib/qos/tc.sh) to limit outgoing bandwidth
|
||
|
- Add '-regtest' mode, similar to testnet but private with instant block
|
||
|
generation with 'setgenerate' RPC.
|
||
|
- Add 'linearize.py' script to contrib, for creating bootstrap.dat
|
||
|
- Add separate bitcoin-cli client
|
||
|
|
||
|
Credits
|
||
|
--------
|
||
|
|
||
|
Thanks to everyone who contributed to this release:
|
||
|
|
||
|
- Andrey
|
||
|
- Ashley Holman
|
||
|
- b6393ce9-d324-4fe1-996b-acf82dbc3d53
|
||
|
- bitsofproof
|
||
|
- Brandon Dahler
|
||
|
- Calvin Tam
|
||
|
- Christian Decker
|
||
|
- Christian von Roques
|
||
|
- Christopher Latham
|
||
|
- Chuck
|
||
|
- coblee
|
||
|
- constantined
|
||
|
- Cory Fields
|
||
|
- Cozz Lovan
|
||
|
- daniel
|
||
|
- Daniel Larimer
|
||
|
- David Hill
|
||
|
- Dmitry Smirnov
|
||
|
- Drak
|
||
|
- Eric Lombrozo
|
||
|
- fanquake
|
||
|
- fcicq
|
||
|
- Florin
|
||
|
- frewil
|
||
|
- Gavin Andresen
|
||
|
- Gregory Maxwell
|
||
|
- gubatron
|
||
|
- Guillermo Céspedes Tabárez
|
||
|
- Haakon Nilsen
|
||
|
- HaltingState
|
||
|
- Han Lin Yap
|
||
|
- harry
|
||
|
- Ian Kelling
|
||
|
- Jeff Garzik
|
||
|
- Johnathan Corgan
|
||
|
- Jonas Schnelli
|
||
|
- Josh Lehan
|
||
|
- Josh Triplett
|
||
|
- Julian Langschaedel
|
||
|
- Kangmo
|
||
|
- Lake Denman
|
||
|
- Luke Dashjr
|
||
|
- Mark Friedenbach
|
||
|
- Matt Corallo
|
||
|
- Michael Bauer
|
||
|
- Michael Ford
|
||
|
- Michagogo
|
||
|
- Midnight Magic
|
||
|
- Mike Hearn
|
||
|
- Nils Schneider
|
||
|
- Noel Tiernan
|
||
|
- Olivier Langlois
|
||
|
- patrick s
|
||
|
- Patrick Strateman
|
||
|
- paveljanik
|
||
|
- Peter Todd
|
||
|
- phantomcircuit
|
||
|
- phelixbtc
|
||
|
- Philip Kaufmann
|
||
|
- Pieter Wuille
|
||
|
- Rav3nPL
|
||
|
- R E Broadley
|
||
|
- regergregregerrge
|
||
|
- Robert Backhaus
|
||
|
- Roman Mindalev
|
||
|
- Rune K. Svendsen
|
||
|
- Ryan Niebur
|
||
|
- Scott Ellis
|
||
|
- Scott Willeke
|
||
|
- Sergey Kazenyuk
|
||
|
- Shawn Wilkinson
|
||
|
- Sined
|
||
|
- sje
|
||
|
- Subo1978
|
||
|
- super3
|
||
|
- Tamas Blummer
|
||
|
- theuni
|
||
|
- Thomas Holenstein
|
||
|
- Timon Rapp
|
||
|
- Timothy Stranex
|
||
|
- Tom Geller
|
||
|
- Torstein Husebø
|
||
|
- Vaclav Vobornik
|
||
|
- vhf / victor felder
|
||
|
- Vinnie Falco
|
||
|
- Warren Togami
|
||
|
- Wil Bown
|
||
|
- Wladimir J. van der Laan
|