Man page: Difference between revisions
m Changed forum link |
mNo edit summary |
||
(One intermediate revision by the same user not shown) | |||
Line 1: | Line 1: | ||
This page | This page should probably be deleted. | ||
It's also a place for questions in progress, so feel free to ask new questions, or answer and/or refine existing answers. | It's also a place for questions in progress, so feel free to ask new questions, or answer and/or refine existing answers. | ||
== Ask your question here: == | == Ask your question here: == | ||
== Answered Questions == | == Answered Questions == | ||
Line 16: | Line 16: | ||
How does it do that? Well, it is a little bit complicated; you've got to understand how bitcoins are created, and how they are traded. | How does it do that? Well, it is a little bit complicated; you've got to understand how bitcoins are created, and how they are traded. | ||
First, how they're created: 25 bitcoins are created approximately every 10 minutes. Everybody who is trying to create bitcoins is in a race to try to find those 25 bitcoins; they are really hard to find, but, once found, it is easy to verify that, yes, indeed, your bitcoin software found them, so you get to spend them. | First, how they're created: 6.25 bitcoins are created approximately every 10 minutes. Everybody who is trying to create bitcoins is in a race to try to find those 6.25 bitcoins; they are really hard to find, but, once found, it is easy to verify that, yes, indeed, your bitcoin software found them, so you get to spend them. | ||
Second, how they're traded: Imagine you did find | Second, how they're traded: Imagine you did find 50 bitcoins (well, your computer found them by running the bitcoin software for a few months or a year-- they are not easy to find, and are harder to find the more people who are looking for them). You trade them to me by sending them to my bitcoin address. Inside the software, a messages is created and then broadcast to everybody that says "These 50 bitcoins that we all agree are valid are hereby officially traded to somebody else (me-- well, one of my bitcoin receiving addresses, actually)." | ||
Now I've got them. If you try to trade those same | Now I've got them. If you try to trade those same 50 bitcoins to somebody else, it won't work-- everybody running Bitcoin sees all the trades, so if you try to spend the same coins a second time everybody else's software will reject your attempt to cheat. | ||
And that's it-- that's how it works. Bitcoins are scarce because only about | And that's it-- that's how it works. Bitcoins are scarce because only about 50 are created every ten minutes. And you can't claim to have more than you really have because everybody else can check to see if your coins really were created by the "race" process, or if they were from valid trades. | ||
=== Uncatagorized === | === Uncatagorized === | ||
==== Why did this generation give me more bitcoins than normal (like | ==== Why did this generation give me more bitcoins than normal (like 50.07)? ==== | ||
You collected a [[transaction fee]]. | You collected a [[transaction fee]]. | ||
==== Why must users back up their wallets | ==== Why must users back up their wallets ==== | ||
Bitcoin transactions send bitcoins to a specific public key. A Bitcoin address is an encoded hash of a public key. In order to use received bitcoins, you need to have the private key matching the public key you received with. This is sort of like a super long password associated with an account (public key). Your Bitcoin wallet contains all of the private keys necessary for spending your received transactions. If you delete your wallet without a backup, then you no longer have the authorization information necessary to claim your coins, and the coins associated with those keys are lost forever. | Bitcoin transactions send bitcoins to a specific public key. A Bitcoin address is an encoded hash of a public key. In order to use received bitcoins, you need to have the private key matching the public key you received with. This is sort of like a super long password associated with an account (public key). Your Bitcoin wallet contains all of the private keys necessary for spending your received transactions. If you delete your wallet without a backup, then you no longer have the authorization information necessary to claim your coins, and the coins associated with those keys are lost forever. | ||
Creating a new address generates a new pair of public and private keys | Creating a new address generates a new pair of public and private keys. Each keypair is mostly random numbers, but if you are using a HD wallet with a seed, they are derived from a special seed key, so as long as you back that up, you have a good chance of recovering your complete wallet. | ||
The situation is made somewhat more confusing because the receiving addresses shown in the UI are not the only keys in your wallet. Each Bitcoin generation is given a new public key, and, more importantly, each sent transaction also sends a random number of bitcoins back to yourself at a new key. When sending bitcoins to anyone, you generate a new keypair for yourself and simultaneously send bitcoins to your new public key and the actual recipient's public key. This is an anonymity feature -- it makes tracking Bitcoin transactions much more difficult. | The situation is made somewhat more confusing because the receiving addresses shown in the UI are not the only keys in your wallet. Each Bitcoin generation is given a new public key, and, more importantly, each sent transaction also sends a random number of bitcoins back to yourself at a new key. When sending bitcoins to anyone, you generate a new keypair for yourself and simultaneously send bitcoins to your new public key and the actual recipient's public key. This is an anonymity feature -- it makes tracking Bitcoin transactions much more difficult. | ||
So if you create a backup, send some bitcoins, and then restore from the backup, | So if you create a backup, send some bitcoins, and then restore from the backup, as long as you use a seed-based wallet, no bitcoins should be lost. | ||
Linux users can setup cron by running 'crontab -e' and adding this line: | Linux users can setup cron by running 'crontab -e' and adding this line: | ||
Line 57: | Line 55: | ||
~/bin/bitcoind backupwallet $WALLET | ~/bin/bitcoind backupwallet $WALLET | ||
/usr/bin/gpg -r "$GPGU" --output $WALLET_E --encrypt $WALLET | /usr/bin/gpg -r "$GPGU" --output $WALLET_E --encrypt $WALLET | ||
The shell script does: | The shell script does: | ||
* Call bitcoind backupwallet to create a time/date-stamped wallet file. | * Call bitcoind backupwallet to create a time/date-stamped wallet file. | ||
* GPG encrypt the wallet with my public key. | * GPG encrypt the wallet with my public key. | ||
==== How many nodes are there? ==== | |||
Luke-Jr maintains a statistics page which is currently the best way to see an estimate of the current number of real nodes. | |||
[https://luke.dashjr.org/programs/bitcoin/files/charts/software.html Luke's Node Count Pie Chart] | |||
=== Economics === | === Economics === | ||
Line 79: | Line 74: | ||
==== Where does the value of Bitcoin stem from? What backs up Bitcoin? ==== | ==== Where does the value of Bitcoin stem from? What backs up Bitcoin? ==== | ||
Bitcoin has value because it is accepted as payment by many. The initial market value was achieved when people speculated | Bitcoin has value because it is accepted as payment by many. The initial market value was achieved when people shared Bitcoins with each other, and speculated that because of its properties, the currency would be accepted by others later on. | ||
When we say that a currency is backed up by gold, we mean that there's a promise in place that you can exchange the currency for gold. In a sense, you could say that Bitcoin is "backed up" by the price tags of merchants and currency exchangers - a price tag is a promise to exchange goods for a specified amount of currency. Of course, price tags may or may not be as long-term promises as those made by central banks or governments. | When we say that a currency is backed up by gold, we mean that there's a promise in place that you can exchange the currency for gold. In a sense, you could say that Bitcoin is "backed up" by the price tags of merchants and currency exchangers - a price tag is a promise to exchange goods for a specified amount of currency. Of course, price tags may or may not be as long-term promises as those made by central banks or governments. | ||
Line 85: | Line 80: | ||
It's a common misconception that Bitcoins gain their value from the cost of electricity required to generate them. Cost doesn't equal value - hiring 1,000 men to shovel a big hole in the ground may be costly, but not valuable. Also, even though scarcity is a critical requirement for a currency to be useful, it alone doesn't make anything valuable. Your fingerprints are scarce, but that doesn't mean they have any exchange value. | It's a common misconception that Bitcoins gain their value from the cost of electricity required to generate them. Cost doesn't equal value - hiring 1,000 men to shovel a big hole in the ground may be costly, but not valuable. Also, even though scarcity is a critical requirement for a currency to be useful, it alone doesn't make anything valuable. Your fingerprints are scarce, but that doesn't mean they have any exchange value. | ||
At the time of this writing, Bitcoin's chain of proof is the result of over | At the time of this writing, Bitcoin's chain of proof is the result of over 120,000,000,000,000,000,000 cryptographically secure, verified calculations per second carried out by many independent computers. The total amount of work that has been put into Bitcoin recently passed 2^93 hashes. This large and growing input of energy and technology is part of Bitcoin's value, and represents a substantial investment of resources by Bitcoin users in creating the benefits of a trustworthy medium of exchange. | ||
==== Isn't the minting process a waste of resources? ==== | ==== Isn't the minting process a waste of resources? ==== | ||
Line 97: | Line 92: | ||
Currently a generating node can charge whatever [[transaction fee]] they want. A transaction that doesn't pay the fee won't be included in any blocks produced by that node, but it will appear in later blocks by cheaper generators. | Currently a generating node can charge whatever [[transaction fee]] they want. A transaction that doesn't pay the fee won't be included in any blocks produced by that node, but it will appear in later blocks by cheaper generators. | ||
It is [ | It is [http://www.bitcoin.org/smf/index.php?topic=165.msg1595#msg1595 possible] for the network to enforce a fee rate, but this is not currently implemented. If [[Satoshi]] tried to implement this, only ''generating'' nodes would have a vote in whether the change would be accepted, so the change would have to be beneficial in some way to generators (ie, not too low). | ||
==== Does including more transactions in your block slow down your hashing rate? ==== | ==== Does including more transactions in your block slow down your hashing rate? ==== | ||
Line 105: | Line 100: | ||
==== Why is it using so much CPU? ==== | ==== Why is it using so much CPU? ==== | ||
If you have "Generate coins" turned on, Bitcoin will calculate millions of [[hash|hashes]] per second in an attempt to solve the current [[block]]. | If you have "Generate coins" turned on, Bitcoin will calculate millions of [[hash|hashes]] per second in an attempt to solve the current [[block]]. You will probably never solve a block with a CPU, a GPU, or even a room full of either. Best not to bother. | ||
==== Why can't it be doing something useful for humanity instead? ==== | ==== Why can't it be doing something useful for humanity instead? ==== | ||
Line 112: | Line 107: | ||
This CPU time and electricity is not entirely wasted, though: it helps protect the network from attack. | This CPU time and electricity is not entirely wasted, though: it helps protect the network from attack. | ||
==== Can we expand the transaction protocol so it includes a message as well as an amount? ==== | ==== Can we expand the transaction protocol so it includes a message as well as an amount? ==== | ||
Don't. | |||
==== What happens when two nodes generate a block at the same time? ==== | ==== What happens when two nodes generate a block at the same time? ==== | ||
Line 148: | Line 126: | ||
You don't need to have a client running to receive bitcoins. | You don't need to have a client running to receive bitcoins. | ||
Once you create an address, any coins sent to it will just sit there waiting for you to spend them. | Once you create an address, any coins sent to it will just sit there waiting for you to spend them. | ||
=== Technical (Windows) === | === Technical (Windows) === | ||
Line 162: | Line 136: | ||
==== Is there a mailing list? ==== | ==== Is there a mailing list? ==== | ||
Yes. | Yes. https://lists.linuxfoundation.org/mailman/listinfo/bitcoin-dev | ||
==== Is there a test network? ==== | ==== Is there a test network? ==== | ||
Yes, run Bitcoin or bitcoind with the -testnet switch. | |||
==== How do I build bitcoin? ==== | ==== How do I build bitcoin? ==== | ||
Instructions for building on various platforms: https://github.com/bitcoin/bitcoin/tree/master/doc | |||
{{fromold|more_faqs}} | |||
[[Category:Technical]] | [[Category:Technical]] |
Latest revision as of 03:09, 12 August 2021
This page should probably be deleted.
It's also a place for questions in progress, so feel free to ask new questions, or answer and/or refine existing answers.
Ask your question here:
Answered Questions
How does it work (for non-geeks)
Why can't somebody just create a version of the software that gives you extra bitcoins?
When you spend some bitcoins, the software on your machine has to prove to the software running on everybody else's machine that those bitcoins are valid.
How does it do that? Well, it is a little bit complicated; you've got to understand how bitcoins are created, and how they are traded.
First, how they're created: 6.25 bitcoins are created approximately every 10 minutes. Everybody who is trying to create bitcoins is in a race to try to find those 6.25 bitcoins; they are really hard to find, but, once found, it is easy to verify that, yes, indeed, your bitcoin software found them, so you get to spend them.
Second, how they're traded: Imagine you did find 50 bitcoins (well, your computer found them by running the bitcoin software for a few months or a year-- they are not easy to find, and are harder to find the more people who are looking for them). You trade them to me by sending them to my bitcoin address. Inside the software, a messages is created and then broadcast to everybody that says "These 50 bitcoins that we all agree are valid are hereby officially traded to somebody else (me-- well, one of my bitcoin receiving addresses, actually)."
Now I've got them. If you try to trade those same 50 bitcoins to somebody else, it won't work-- everybody running Bitcoin sees all the trades, so if you try to spend the same coins a second time everybody else's software will reject your attempt to cheat.
And that's it-- that's how it works. Bitcoins are scarce because only about 50 are created every ten minutes. And you can't claim to have more than you really have because everybody else can check to see if your coins really were created by the "race" process, or if they were from valid trades.
Uncatagorized
Why did this generation give me more bitcoins than normal (like 50.07)?
You collected a transaction fee.
Why must users back up their wallets
Bitcoin transactions send bitcoins to a specific public key. A Bitcoin address is an encoded hash of a public key. In order to use received bitcoins, you need to have the private key matching the public key you received with. This is sort of like a super long password associated with an account (public key). Your Bitcoin wallet contains all of the private keys necessary for spending your received transactions. If you delete your wallet without a backup, then you no longer have the authorization information necessary to claim your coins, and the coins associated with those keys are lost forever.
Creating a new address generates a new pair of public and private keys. Each keypair is mostly random numbers, but if you are using a HD wallet with a seed, they are derived from a special seed key, so as long as you back that up, you have a good chance of recovering your complete wallet.
The situation is made somewhat more confusing because the receiving addresses shown in the UI are not the only keys in your wallet. Each Bitcoin generation is given a new public key, and, more importantly, each sent transaction also sends a random number of bitcoins back to yourself at a new key. When sending bitcoins to anyone, you generate a new keypair for yourself and simultaneously send bitcoins to your new public key and the actual recipient's public key. This is an anonymity feature -- it makes tracking Bitcoin transactions much more difficult.
So if you create a backup, send some bitcoins, and then restore from the backup, as long as you use a seed-based wallet, no bitcoins should be lost.
Linux users can setup cron by running 'crontab -e' and adding this line:
01 */1 * * * /usr/local/bin/backupwallet.sh
backupwallet.sh:
#!/usr/bin/env bash GPGU="My GPG User" TS=$(date "+%Y%m%d-%H-%M") WALLET=/tmp/wallet${TS} WALLET_E=/tmp/wallet${TS}.crypt ~/bin/bitcoind backupwallet $WALLET /usr/bin/gpg -r "$GPGU" --output $WALLET_E --encrypt $WALLET The shell script does: * Call bitcoind backupwallet to create a time/date-stamped wallet file. * GPG encrypt the wallet with my public key.How many nodes are there?
Luke-Jr maintains a statistics page which is currently the best way to see an estimate of the current number of real nodes. Luke's Node Count Pie ChartEconomics
I've lost my wallet, is there a way to recreate the lost coins in the system?
No, coins that are lost are lost forever. The lost coins will not be recovered or regenerated at any time.Where does the value of Bitcoin stem from? What backs up Bitcoin?
Bitcoin has value because it is accepted as payment by many. The initial market value was achieved when people shared Bitcoins with each other, and speculated that because of its properties, the currency would be accepted by others later on. When we say that a currency is backed up by gold, we mean that there's a promise in place that you can exchange the currency for gold. In a sense, you could say that Bitcoin is "backed up" by the price tags of merchants and currency exchangers - a price tag is a promise to exchange goods for a specified amount of currency. Of course, price tags may or may not be as long-term promises as those made by central banks or governments. It's a common misconception that Bitcoins gain their value from the cost of electricity required to generate them. Cost doesn't equal value - hiring 1,000 men to shovel a big hole in the ground may be costly, but not valuable. Also, even though scarcity is a critical requirement for a currency to be useful, it alone doesn't make anything valuable. Your fingerprints are scarce, but that doesn't mean they have any exchange value. At the time of this writing, Bitcoin's chain of proof is the result of over 120,000,000,000,000,000,000 cryptographically secure, verified calculations per second carried out by many independent computers. The total amount of work that has been put into Bitcoin recently passed 2^93 hashes. This large and growing input of energy and technology is part of Bitcoin's value, and represents a substantial investment of resources by Bitcoin users in creating the benefits of a trustworthy medium of exchange.Isn't the minting process a waste of resources?
All currencies need a method for regulating the money supply and creating circulation. To make Bitcoin secure, a large amount of computer work is required. The Bitcoin process for introducing new coins into circulation is designed to make the currency secure by encouraging users to perform the necessary computational work by awarding the role of introducing new coins into circulation in rough proportion the amount of computer power contributed to this goal.Technical
Can generating nodes charge different transaction fees, or is this enforced by the network?
Currently a generating node can charge whatever transaction fee they want. A transaction that doesn't pay the fee won't be included in any blocks produced by that node, but it will appear in later blocks by cheaper generators. It is possible for the network to enforce a fee rate, but this is not currently implemented. If Satoshi tried to implement this, only generating nodes would have a vote in whether the change would be accepted, so the change would have to be beneficial in some way to generators (ie, not too low).Does including more transactions in your block slow down your hashing rate?
Not at all. You're hashing the block header, which contains only a fixed-size hash of all the transactions.Why is it using so much CPU?
If you have "Generate coins" turned on, Bitcoin will calculate millions of hashes per second in an attempt to solve the current block. You will probably never solve a block with a CPU, a GPU, or even a room full of either. Best not to bother.Why can't it be doing something useful for humanity instead?
SHA-256 hashing has very specific properties that we need. In particular, it generates (with predictable CPU required) numbers that are for all practical purposes purely random, but in a way that is easily verifiable. There are no known "beneficial" calculations that could replace this. This CPU time and electricity is not entirely wasted, though: it helps protect the network from attack.Can we expand the transaction protocol so it includes a message as well as an amount?
Don't.What happens when two nodes generate a block at the same time?
This is very unlikely to happen but if it does: The tiebreak is which block the NEXT block builds on. Each node sends out it's 'winning' block. Some nodes on the network will hear about 'block A' first and assume it is the winning block, and some will hear about 'block B' first and assume it is the winning block. Then each 'half' will proceed hashing from there trying to generate the next block as normal. If a machine with 'block B' as its predecessor wins the next race by generating 'block C', it becomes the official winner, and the nodes who were working on A give up and start on C. (In this case the generator of 'block A' might be disappointed, because he thought he generated some coins, but he didn't because the network decided his block was no longer valid.) Note: block A and block B will usually contain the same list of transactions. Transactions not included will be made available to other future blocks for inclusion into the chain.What happens if someone sends me some coins but I am not connected?
Any transfer to a 'valid' address should be successful. You don't need to have a client running to receive bitcoins. Once you create an address, any coins sent to it will just sit there waiting for you to spend them.Technical (Windows)
Why am I not downloading any blocks?
Add bitcoin.exe to the "Excluded processes" list of Microsoft Security Essentials.Developing
Is there a mailing list?
Yes. https://lists.linuxfoundation.org/mailman/listinfo/bitcoin-devIs there a test network?
Yes, run Bitcoin or bitcoind with the -testnet switch.How do I build bitcoin?
Instructions for building on various platforms: https://github.com/bitcoin/bitcoin/tree/master/doc This article uses content from the old wiki. The list of contributors to the old page is available here.