You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
lnbook/preface.asciidoc

217 lines
12 KiB
Plaintext

5 years ago
[preface]
[[preface]]
== Preface
The Lightning Network (LN) is a second layer peer-to-peer network that allows us to make Bitcoin payments "off-chain," meaning without committing them as transactions to the Bitcoin blockchain.
The Lightning Network gives us Bitcoin payments that are secure, cheap, fast, and much more private, even for very small payments.
Building on the idea of payment channels, first proposed by Bitcoin's inventor Satoshi Nakamoto, the Lightning Network is a routed network of payment channels where payments "hop" across a path of payment channels from the sender to the recipient.
The initial idea of the Lightning Network was proposed in 2015 in the groundbreaking paper "The Bitcoin Lightning Network: Scalable Off-Chain Instant Payments," by Joseph Poon and Thaddeus Dryja. By 2017, there was a "test" Lightning Network running on the internet, as different groups built compatible implementations and coordinated to set some interoperability standards. In 2018, the Lightning Network went "live" and payments started flowing.
In 2019, Andreas M. Antonopoulos, Olaoluwa Osuntokun, and René Pickhardt agreed to collaborate to write this book. It appears we have been successful!
5 years ago
[[intended_audience_sec]]
=== Intended Audience
This book is mostly intended for technical readers with an understanding of the fundamentals of Bitcoin and other open blockchains.
5 years ago
[role="pagebreak-before less_space"]
5 years ago
[[conventinons_used_sec]]
=== Conventions Used in This Book
The following typographical conventions are used in this book:
5 years ago
_Italic_:: Indicates new terms, URLs, email addresses, filenames, and file extensions.
+Constant width+:: Used for program listings, as well as within paragraphs to refer to program elements such as variable or function names, databases, data types, environment variables, statements, and keywords.
**`Constant width bold`**:: Shows commands or other text that should be typed literally by the user.
_++Constant width italic++_:: Shows text that should be replaced with user-supplied values or by values determined by context.
5 years ago
[TIP]
====
This element signifies a tip or suggestion.
5 years ago
====
[NOTE]
====
This element signifies a general note.
5 years ago
====
[WARNING]
====
This element indicates a warning or caution.
5 years ago
====
[[code_examples_sec]]
=== Code Examples
The examples are illustrated in Go, C++, Python, and using the command line of a Unix-like operating system. All code snippets are available in the GitHub repository under the _code_ subdirectory. Fork the book code, try the code examples, or submit corrections via https://github.com/lnbook/lnbook[GitHub].
5 years ago
All the code snippets can be replicated on most operating systems with a minimal installation of compilers, interpreters, and libraries for the corresponding languages. Where necessary, we provide basic installation instructions and step-by-step examples of the output of those instructions.
Some of the code snippets and code output have been reformatted for print. In all such cases, the lines have been split by a backslash (+\+) character, followed by a newline character. When transcribing the examples, remove those two characters and join the lines again and you should see identical results to those shown in the example.
All the code snippets use real values and calculations where possible, so that you can build from example to example and see the same results in any code you write to calculate the same values. For example, the private keys and corresponding public keys and addresses are all real.
[[using_code_examples_sec]]
=== Using Code Examples
3 years ago
If you have a technical question or a problem using the code examples, please send email to pass:[<a class="email" href="mailto:bookquestions@oreilly.com"><em>bookquestions@oreilly.com</em></a>].
5 years ago
3 years ago
This book is here to help you get your job done. In general, if example code is offered with this book, you may use it in your programs and documentation. You do not need to contact us for permission unless youre reproducing a significant portion of the code. For example, writing a program that uses several chunks of code from this book does not require permission. Selling or distributing examples from OReilly books does require permission. Answering a question by citing this book and quoting example code does not require permission. Incorporating a significant amount of example code from this book into your products documentation does require permission.
5 years ago
We appreciate, but do not require, attribution. An attribution usually includes the title, author, publisher, ISBN, and copyright. For example: &#x201c;__Mastering the Lightning Network__ by Andreas M. Antonopoulos, Olaoluwa Osuntokun, and René Pickhardt (O'Reilly). Copyright 2022 aantonop Books LLC, René Pickhardt, and uuddlrlrbas LLC, ISBN 978-1-492-05486-3."
5 years ago
__Mastering the Lightning Network__ is offered under the Creative Commons Attribution-Noncommercial-No Derivative Works 4.0 International License (CC BY-NC-ND 4.0).
5 years ago
If you feel your use of code examples falls outside fair use or the permission given previously, feel free to contact us at pass:[<a href="mailto:permissions@oreilly.com">permissions@oreilly.com</a>].
5 years ago
=== References to Companies and Products
All references to companies and products are intended for educational, demonstration, and reference purposes. The authors do not endorse any of the companies pass:[<span class="keep-together">or products</span>] mentioned. We have not tested the operation or security of any of the products, projects, or code segments shown in this book. Use them at your own risk!
5 years ago
[[addresses_and_transactions_sec]]
=== Addresses and Transactions in This Book
5 years ago
The Bitcoin addresses, transactions, keys, QR codes, and blockchain data used in this book are, for the most part, real. That means you can browse the blockchain, look at the transactions offered as examples, retrieve them with your own scripts or programs, etc.
5 years ago
However, note that the private keys used to construct the addresses printed in this book have been "burned." This means that if you send money to any of these addresses, the money will either be lost forever or (more likely) appropriated, since anyone who reads the book can take it using the private keys printed herein.
5 years ago
[WARNING]
====
DO NOT SEND MONEY TO ANY OF THE ADDRESSES IN THIS BOOK. Your money will be taken by another reader, or lost forever.
====
3 years ago
=== O'Reilly Online Learning
5 years ago
[role = "ormenabled"]
5 years ago
[NOTE]
====
3 years ago
For more than 40 years, pass:[<a href="http://oreilly.com" class="orm:hideurl"><em class="hyperlink">OReilly Media</em></a>] has provided technology and business training, knowledge, and insight to help companies succeed.
5 years ago
====
3 years ago
Our unique network of experts and innovators share their knowledge and expertise through books, articles, and our online learning platform. OReillys online learning platform gives you on-demand access to live training courses, in-depth learning paths, interactive coding environments, and a vast collection of text and video from O'Reilly and 200+ other publishers. For more information, visit pass:[<a href="http://oreilly.com" class="orm:hideurl"><em>http://oreilly.com</em></a>].
5 years ago
[[how_to_contact_us_sec]]
=== How to Contact Us
Information about _Mastering the Lightning Network_ as well as the Open Edition and translations are available at link:$$https://lnbook.info$$[].
5 years ago
Please address comments and questions concerning this book to the publisher:
5 years ago
++++
<ul class="simplelist">
<li>OReilly Media, Inc.</li>
5 years ago
<li>1005 Gravenstein Highway North</li>
<li>Sebastopol, CA 95472</li>
<li>800-998-9938 (in the United States or Canada)</li>
<li>707-829-0515 (international or local)</li>
<li>707-829-0104 (fax)</li>
</ul>
++++
3 years ago
Email pass:[<a class="email" href="mailto:bookquestions@oreilly.com"><em>bookquestions@oreilly.com</em></a>] to comment or ask technical questions about this book.
5 years ago
3 years ago
For news and information about our books and courses, visit link:$$http://oreilly.com$$[].
5 years ago
3 years ago
Find us on Facebook: link:$$http://facebook.com/oreilly$$[]
5 years ago
3 years ago
Follow us on Twitter: link:$$http://twitter.com/oreillymedia$$[]
5 years ago
3 years ago
Watch us on YouTube: link:$$http://www.youtube.com/oreillymedia$$[]
5 years ago
==== Contacting Andreas
You can contact Andreas M. Antonopoulos on his personal site:
link:$$https://aantonop.com$$[]
5 years ago
Subscribe to Andreas's channel on YouTube:
link:$$https://www.youtube.com/aantonop$$[]
Like Andreas's page on Facebook:
link:$$https://www.facebook.com/AndreasMAntonopoulos$$[]
Follow Andreas on Twitter:
link:$$https://twitter.com/aantonop$$[]
Connect with Andreas on LinkedIn:
link:$$https://linkedin.com/company/aantonop$$[]
Andreas would also like to thank the patrons who support his work through monthly donations. You can support Andreas on Patreon at link:$$https://patreon.com/aantonop$$[].
5 years ago
==== Contacting René
You can contact René Pickhardt on his personal site:
link:$$https://ln.rene-pickhardt.de$$[]
Subscribe to René's channel on YouTube:
link:$$https://www.youtube.com/user/RenePickhardt$$[]
Follow René on Twitter:
link:$$https://twitter.com/renepickhardt$$[]
Connect with René on LinkedIn:
link:$$https://www.linkedin.com/in/rene-pickhardt-80313744$$[]
René would also like to thank all of the patrons who support his work through monthly donations. You can support René on Patreon at link:$$https://patreon.com/renepickhardt$$[].
Or you can support his work directly with Bitcoin (also via the Lightning Network) at link:$$https://donate.ln.rene-pickhardt.de$$[] for which René is equally thankful as for his patreons.
==== Contacting Olaoluwa Osuntokun
You can contact Olaoluwa Osuntokun at his professional email address:
__laolu@lightning.engineering__
Follow Olaoluwa on Twitter:
link:$$https://twitter.com/roasbeef$$[]
5 years ago
[[acknowledgments_sec]]
=== Acknowledgments by Andreas
5 years ago
I owe my love of words and books to my mother, Theresa, who raised me in a house with books lining every wall. My mother also bought me my first computer in 1982, despite being a self-described technophobe. My father, Menelaos, a civil engineer who published his first book at 80 years old, was the one who taught me logical and analytical thinking and a love of science and engineering.
Thank you all for supporting me throughout this journey.
=== Acknowledgments by René
I want to thank the German education system through which I acquired the knowledge upon which my work builds. It is one of the greatest gifts I was given.
Similarly I want to thank the German public healthcare system and every person devoting their time into working within that industry. Your effort and endurance make you my personal heroes and I will never forget the help, patience, and support I received when I was in need.
Thanks goes to all the students I was allowed to teach and who engaged in interesting discussions and questions. From you I learned the most.
I am also grateful to the Bitcoin and Lightning Network community that warmly welcomed me and to the enthusiasts and private persons who financially supported and continue to support my work.
In particular I am grateful to all the open source developers (not only Bitcoin and Lightning Network) and to the people who fund them to make that technology possible.
A special thanks goes to my coauthors for riding with me through the storm.
Last but not least, I am thankful to my loved ones.
=== Acknowledgments by Olaoluwa Osuntokun
I'd like to thank the amazing team at Lightning Labs, as without you all, there
would be no LND. I'd also like to thank the original set of authors of the BOLT
specification: Rusty Russell, Fabrice Drouin, Conner Fromnkchet, Pierre-Marie
Padiou, Lisa Neigut, and Christian Decker. Last but not least, I'd like to
thank Joseph Poon and Tadge Dryja, the authors of the original Lightning
Network paper, as without them, there would be no Lightning Network to write a
book about.
5 years ago
[[github_contrib]]
=== Contributions
Many contributors offered comments, corrections, and additions to the book as it was collaboratively written on GitHub.
Following is an alphabetically sorted list of all the GitHub contributors, including their GitHub IDs in parentheses:
include::github_contributors.asciidoc[]
5 years ago
Without the help offered by everyone listed here, this book would not have been possible. Your contributions demonstrate the power of open source and open culture, and we are eternally grateful for your help.
5 years ago
Thank you.
=== Sources
Some of the material in this book has been sourced from a variety of public domain sources, open license sources, or with permission. See <<sources_licenses>> for source, license, and attribution details.