最大的比特币支付提供商之一BitPay已经遭遇Bitcoiners的折磨很长一段时间。该社区呼吁进行抵制,开发商Nicolas Dorier巧妙地利用了这一抵制事件。php
Nicolas建立了一个名为BTCPayServer的开源和自托管BitPay兼容支付网关,受到了社区的好评。虽然有许多关于如何使用Docker和其余方法进行设置的指南,但我喜欢控制我在服务器上安装的内容,同时还要了解它的工做原理。html
若是你出于某种缘由更喜欢手动安装BTCPayServer,我会写一篇关于如何作到这一点的分步指南。前端
本教程是为Ubuntu 18.04编写的,但也适用于旧版本和其余基于Debian的发行版。在开始以前,请确保运行比特币核心和闪电网络节点。java
要运行BTCPayServer,你须要安装.NET Core SDK
,NBXplorer
和PostgreSQL
。node
转到下载文件夹或用于存储临时文件的任何其余文件夹:python
cd ~/Downloads
并下载.NET Core SDK
所需的Microsoft软件包:linux
wget -qO- https://packages.microsoft.com/keys/microsoft.asc | gpg --dearmor > microsoft.asc.gpg sudo mv microsoft.asc.gpg /etc/apt/trusted.gpg.d/ wget -q https://packages.microsoft.com/config/ubuntu/$(lsb_release -sr)/prod.list sudo mv prod.list /etc/apt/sources.list.d/microsoft-prod.list
更新包缓存并安装.NET Core:android
sudo apt-get install apt-transport-https sudo apt-get update sudo apt-get install dotnet-sdk-2.1
咱们须要安装NBXplorer才能跟踪传入的链上交易。git
若是你尚未建立源文件夹并打开它:程序员
mkdir ~/source cd ~/source
克隆存储库并构建代码:
git clone https://github.com/dgarage/NBXplorer cd NBXplorer ./build.sh
建立数据文件夹:
mkdir -p ~/.nbxplorer/Main cd ~/.nbxplorer/Main
新的配置文件:
touch settings.config
使用你选择的编辑器打开文件并添加如下行:
btc.rpc.auth=<bitcoind rpc user>:<bitcoind rpc password> port=24445 mainnet=1
确保使用你的bitcoind的rpc登陆凭据。你可使用如下命令找到它们:
cat ~/.bitcoin/bitcoin.conf | grep rpc
测试是否全部设置都正确:
/usr/bin/dotnet ~/source/NBXplorer/NBXplorer/bin/Release/netcoreapp2.1/NBXplorer.dll -c ~/.nbxplorer/Main/settings.config
若是是这样,输入ctrl + c
终止进程并下载Systemd服务:
cd /usr/lib/systemd/system sudo wget https://gist.githubusercontent.com/mariodian/de873b969e70eca4d0a7673efd697d0a/raw/acfc70c5694cd53d8a3df7ff54a35ff2caba7532/nbxplorer.service
根据你的环境编辑文件。
启用服务,启动它并检查状态:
sudo systemctl enable nbxplorer.service sudo service nbxplorer start sudo service nbxplorer status
若是你没有看到错误,请转到下一步。
我没法使用MySQL/MariaDB设置BTCPayServer,因此我被迫使用PostgreSQL
。
首先安装它并以新建立的系统用户身份打开shell提示符:
sudo apt install postgresql postgresql-contrib sudo -i -u postgres
建立一个新的数据库用户:
createuser --pwprompt --interactive
输入如下内容(你能够将satoshi更改成你喜欢的任何用户名):
建立一个新数据库:
createdb -O satoshi btcpayserver
若是你看到没有错误退出shell:
exit
克隆存储库并构建代码:
cd ~/source git clone https://github.com/btcpayserver/btcpayserver.git cd btcpayserver ./build.sh
建立一个数据文件夹:
mkdir -p ~/.btcpayserver/Main cd ~/.btcpayserver/Main
一个新的配置文件:
touch settings.config
获取LND的证书指纹并将其粘贴到下面的配置文件中。
openssl x509 -noout -fingerprint -sha256 -inform pem -in ~/.lnd/tls.cert
打开settings.config
并添加如下行:
network=mainnet port=23001 bind=0.0.0.0 chains=btc BTC.explorer.url=http://127.0.0.1:24445 BTC.lightning=type=lnd-rest;server=https://127.0.0.1:8080/;macaroonfilepath=~/.lnd/data/chain/bitcoin/mainnet/admin.macaroon;certthumbprint=<finger print> postgres=User ID=<your db user>;Password=<your db password>;Host=localhost;Port=5432;Database=btcpayserver;
根据你的设置更改突出显示的变量variables
。
检查一切是否正常。
/usr/bin/dotnet run -p ~i/source/btcpayserver/BTCPayServer/BTCPayServer.csproj -c ~/.btcpayserver/Main/settings.config --network=mainnet
若是是这样,输入ctrl + c
终止进程并下载Systemd服务:
cd /usr/lib/systemd/system sudo wget https://gist.githubusercontent.com/mariodian/07bb13da314e2a321784b380f543651a/raw/6cef554d9e8311e683a017d5e63a07822dee7642/btcpayserver.service
根据你的环境编辑文件。
启用该服务,启动它并检查它是否正常运行:
sudo systemctl enable btcpayserver.service sudo service btcpayserver start sudo service btcpayserver status
恭喜,你刚刚度过了最难的部分!
若是要远程运行服务器,则必须打开端口23001
。
首先,转到路由器设置并找到虚拟服务器Virtual Server
或端口转发Port Forwarding
的部分,并在上述端口上设置端口转发。
而后回到你的linux机器并用iptables打开端口:
sudo iptables -A INPUT -p tcp --dport 23001 -j ACCEPT
若是你使用iptables-save也运行如下命令:
sudo iptables-save > /etc/iptables/rules.v4
你如今应该能够从另外一台计算机链接到你的服务器。
转到你的BTCPayServer管理,注册一个新的管理员账户并登陆。
如今,转到Stores
并单击Create a new store
。完成后,转到商店设置并向下滚动到Derivation Scheme
。
在BTC
下单击修改Edit
,而后在计算机或手机上打开支持BIP32的钱包。
出于本教程的目的,我将使用Electrum。
建议你建立一个新的钱包,而不是使用旧钱包,这样你就没必要费心地从新扫描地址上的余额了。
完成后,单击Wallet -> Information
,复制主公钥,将其粘贴回BTCPayServer管理,选中已启用,而后保存。
接下来,向下滚动到Lightning nodes (Experimental)
,而后单击修改modify
。
应该设置你的链接字符串,但若是没有,请粘贴如下内容:
type=lnd-rest;server=https://127.0.0.1:8080/;macaroonfilepath=/home/satoshi/.lnd/data/chain/bitcoin/mainnet/admin.macaroon;certthumbprint=<your cert fingerprint>
请记住添加你以前得到的LND证书指纹,并将主目录更改成你本身的目录。
单击测试链接Test connection
,若是一切正常,请选中已启用Enable
并单击提交submit
。
在这种状况下,服务器在你要经过域名访问的单独计算机上运行,转到Server Settings -> Maintenance
,并在Change domain name
添加你的名称(固然,你必须购买它)。
你还必须根据你的设置向你的域名提供商添加CNAME或A DNS记录。对不起,我没法帮助你,提供者太多了。
如今,你应该可使用新域名访问BTCPayServer管理,以下所示:http://domain.ltd:23001
。
要建立POS终端,请转到Apps -> Create a new app
并填写简短表单。而后,你将进入应用程序设置,你能够经过模板更改项目列表。
你还能够在网站中添加一个简单的付款按钮,你能够在Stores -> Settings -> Pay Button
中配置,也能够在Stores -> Invoices -> Create a new invoice
中手动建立发票。而后,你能够发送给客户。
固然,支付网关的前端设计是彻底可定制的,所以你能够设置本身的徽标和颜色。
首先让咱们安装将用做反向代理的Apache 2。
sudo apt-get install apache2
启用所需模块:
sudo a2enmod rewrite sudo a2enmod proxy sudo a2enmod proxy_http sudo a2enmod proxy_ajp sudo a2enmod deflate sudo a2enmod headers sudo a2enmod proxy_balancer sudo a2enmod proxy_connect sudo a2enmod proxy_html
重启服务器:
sudo systemctl restart apache2
为你的域名安装Let's加密证书。但你可使用任何其余证书颁发机构。
用如下内容替换/etc/apache2/sites-enabled/000-default.conf
的内容:
<VirtualHost *:80> ServerAdmin webmaster@localhost ServerName btcpay.freedomnode.com RewriteEngine on RewriteCond %{SERVER_NAME} =btcpay.freedomnode.com RewriteRule ^ https://%{SERVER_NAME}%{REQUEST_URI} [END,NE,R=permanent] ErrorLog ${APACHE_LOG_DIR}/error.log CustomLog ${APACHE_LOG_DIR}/access.log combined </VirtualHost>
根据你的须要更改ServerName
。
而后,使用如下内容替换/etc/apache2/sites-enabled/000-default-le-ssl.conf
的内容:
<IfModule mod_ssl.c> <VirtualHost *:443> ServerAdmin webmaster@localhost ServerName btcpay.freedomnode.com ErrorLog ${APACHE_LOG_DIR}/error.log CustomLog ${APACHE_LOG_DIR}/access.log combined ProxyPass "/" "http://127.0.0.1:23001/" ProxyPassReverse / "http://127.0.0.1:23001/" ProxyPreserveHost On SSLCertificateFile /etc/letsencrypt/live/btcpay.freedomnode.com/fullchain.pem SSLCertificateKeyFile /etc/letsencrypt/live/btcpay.freedomnode.com/privkey.pem Include /etc/letsencrypt/options-ssl-apache.conf </VirtualHost> </IfModule>
再次,编辑ServerName
并确保SSLCertificateFile
和SSLCertificateKeyFile
指向正确的文件。
从新加载服务器:
sudo systemctl reload apache2
如今回到~/.btcpayserver/Main/settings.config
并添加:
externalurl=HTTPS://btcpay.freedomnode.com
再次将服务器名称更改成你本身的名称。
你还能够从配置中删除bind=0.0.0.0
,由于远程链接将从如今开始经过Apache进行代理。
重启BTCPayServer:
sudo service btcpayserver restart
打开浏览器并检查新安装的SSL证书是否正常工做。
======================================================================
分享一些比特币、以太坊、EOS、Fabric等区块链相关的交互式在线编程实战教程:
- java比特币开发教程,本课程面向初学者,内容即涵盖比特币的核心概念,例如区块链存储、去中心化共识机制、密钥与脚本、交易与UTXO等,同时也详细讲解如何在Java代码中集成比特币支持功能,例如建立地址、管理钱包、构造裸交易等,是Java工程师不可多得的比特币开发学习课程。
- php比特币开发教程,本课程面向初学者,内容即涵盖比特币的核心概念,例如区块链存储、去中心化共识机制、密钥与脚本、交易与UTXO等,同时也详细讲解如何在Php代码中集成比特币支持功能,例如建立地址、管理钱包、构造裸交易等,是Php工程师不可多得的比特币开发学习课程。
- c#比特币开发教程,本课程面向初学者,内容即涵盖比特币的核心概念,例如区块链存储、去中心化共识机制、密钥与脚本、交易与UTXO等,同时也详细讲解如何在C#代码中集成比特币支持功能,例如建立地址、管理钱包、构造裸交易等,是C#工程师不可多得的比特币开发学习课程。
- java以太坊开发教程,主要是针对java和android程序员进行区块链以太坊开发的web3j详解。
- python以太坊,主要是针对python工程师使用web3.py进行区块链以太坊开发的详解。
- php以太坊,主要是介绍使用php进行智能合约开发交互,进行帐号建立、交易、转帐、代币开发以及过滤器和交易等内容。
- 以太坊入门教程,主要介绍智能合约与dapp应用开发,适合入门。
- 以太坊开发进阶教程,主要是介绍使用node.js、mongodb、区块链、ipfs实现去中心化电商DApp实战,适合进阶。
- ERC721以太坊通证明战,课程以一个数字艺术品创做与分享DApp的实战开发为主线,深刻讲解以太坊非同质化通证的概念、标准与开发方案。内容包含ERC-721标准的自主实现,讲解OpenZeppelin合约代码库二次开发,实战项目采用Truffle,IPFS,实现了通证以及去中心化的通证交易所。
- C#以太坊,主要讲解如何使用C#开发基于.Net的以太坊应用,包括帐户管理、状态与交易、智能合约开发与交互、过滤器和交易等。
- EOS入门教程,本课程帮助你快速入门EOS区块链去中心化应用的开发,内容涵盖EOS工具链、帐户与钱包、发行代币、智能合约开发与部署、使用代码与智能合约交互等核心知识点,最后综合运用各知识点完成一个便签DApp的开发。
- 深刻浅出玩转EOS钱包开发,本课程以手机EOS钱包的完整开发过程为主线,深刻学习EOS区块链应用开发,课程内容即涵盖帐户、计算资源、智能合约、动做与交易等EOS区块链的核心概念,同时也讲解如何使用eosjs和eosjs-ecc开发包访问EOS区块链,以及如何在React前端应用中集成对EOS区块链的支持。课程内容深刻浅出,很是适合前端工程师深刻学习EOS区块链应用开发。
- Hyperledger Fabric 区块链开发详解,本课程面向初学者,内容即包含Hyperledger Fabric的身份证书与MSP服务、权限策略、通道配置与启动、链码通讯接口等核心概念,也包含Fabric网络设计、nodejs链码与应用开发的操做实践,是Nodejs工程师学习Fabric区块链开发的最佳选择。
- Hyperledger Fabric java 区块链开发详解,课程面向初学者,内容即包含Hyperledger Fabric的身份证书与MSP服务、权限策略、通道配置与启动、链码通讯接口等核心概念,也包含Fabric网络设计、java链码与应用开发的操做实践,是java工程师学习Fabric区块链开发的最佳选择。
- tendermint区块链开发详解,本课程适合但愿使用tendermint进行区块链开发的工程师,课程内容即包括tendermint应用开发模型中的核心概念,例如ABCI接口、默克尔树、多版本状态库等,也包括代币发行等丰富的实操代码,是go语言工程师快速入门区块链开发的最佳选择。
汇智网原创翻译,转载请标明出处。这里是如何在Linux上手动安装BTCPayServer并设置比特币BTC和Lightning支付网关