{"content":{"title":"🐧Electrumx安装心得全纪录（Part 2）","body":"# 🎉如何在Mac里面安装Docker并安装Electrumx\r\n\r\n如果在Docker里安装，就不用关注Part1里说的那些Python依赖库的安装，但要对Docker本身的运行原理和命令行比较熟悉才能行。\r\n\r\n### 😄首先说下原理\r\n\r\n你可以理解为网友帮你制作的Electrumx Docker Image（镜像），就是把python以及其依赖包都打包好了，你直接安装就可以了。在下图里，Bins\\Libs就是这些Python环境和库；App就是Electrumx索引器程序\r\n\r\n![img](https://img.learnblockchain.cn/attachments/migrate/1719483303354)\r\n\r\nDokcer原理\r\n\r\n如果已经安装好Docker并运行，大概的样子会是这样的：\r\n\r\n![img](https://img.learnblockchain.cn/attachments/migrate/1719483303357)\r\n\r\ncontainer(容器)，里面有正在跑的Electrumx程序\r\n\r\n![img](https://img.learnblockchain.cn/attachments/migrate/1719483303366)\r\n\r\n运行的日志示意\r\n\r\n![img](https://img.learnblockchain.cn/attachments/migrate/1719483303370)\r\n\r\nImage镜像，你看我安装了了多少版本，真爱啊\r\n\r\n![img](https://img.learnblockchain.cn/attachments/migrate/1719483303374)\r\n\r\nVolume卷\r\n\r\n我们大致了解一下这几个核心概念（From Chatgpt）：\r\n\r\n1.  **Volumes（卷）**：\r\n\r\n   -    Volumes是Docker用来**持久化数据**的一种机制。它们允许容器和宿主机之间共享和存储数据，以便在容器删除或重新创建时数据不会丢失。Volumes可以用来存储数据库文件、日志文件、配置文件等任何需要持久保存的数据。\r\n\r\n2. **Images（镜像）**：\r\n\r\n-  **镜像是Docker容器**的基础，可以将其视为包含应用程序运行所需的所有文件和依赖项的模板。镜像包含了文件系统的完整副本，其中包括操作系统、应用程序代码、运行时环境等。\r\n\r\n3. **Containers（容器）**：\r\n\r\n -  容器是Docker**中运行的实例**。它们是基于镜像创建的运行时环境，其中包含了应用程序代码、运行时环境和依赖项。容器可以被启动、停止、删除，并且可以与其他容器或主机进行通信。\r\n\r\n所以，Images（镜像）是容器的模板，你可以理解为用光盘安装程序时代的光盘镜像，可以挂载到计算机的；Containers（容器）则是基于镜像运行的实例，你可以理解为通过光盘具体的安装程序；Volumes（卷）用于持久化数据，什么是持久化自己扩展学习。\r\n\r\n在这里，我们用的是Nextdao制作的Docker的教程，我加上备注说一下安装过程：\r\n\r\n\r\n\r\n### 😄开始安装\r\n\r\n首先打开官网github地址https://github.com/Next-DAO/atomicals-electrumx-docker ，我们按照方法逐行做：\r\n\r\n**解读Requirements，首先把Bitcoincore服务器端设置好**\r\n\r\n> 1.   `server=1`：\r\n>\r\n>    -   这个选项告诉 Bitcoin Core 启用服务器模式，允许其他 Bitcoin 客户端连接到这个节点。\r\n>\r\n> 2.   `txindex=1`：\r\n>\r\n>    -  这个选项告诉 Bitcoin Core 启用交易索引，使得节点能够查询和索引所有交易，而不仅仅是已确认的交易。\r\n>\r\n> 3. \r\n>\r\n>    `rpcauth=nextdao:cca838b4b19bdc6093f4e0312550361c$213834a29e8488804946c196781059a7ee0ac2b48dbf896b4c6852060d9d83dd`：\r\n>\r\n>    - \r\n>\r\n>      这个选项设置 RPC 认证凭据，用于远程过程调用（RPC）访问 Bitcoin Core 的 API。这里的字符串是通过 rpcauth.py 脚本生成的，包含了用户名和哈希密码。本质是用户名和密码都是nextdao。\r\n>\r\n> 4. \r\n>\r\n>    `rpcallowip=127.0.0.1`：\r\n>\r\n>    - \r\n>\r\n>      这个选项指定允许连接到 RPC 服务的 IP 地址。这里只允许本地主机（127.0.0.1）连接。\r\n>\r\n> 5. \r\n>\r\n>    `rpcallowip=172.0.0.0/8` 和 `rpcallowip=192.168.0.0/16`：\r\n>\r\n>    - \r\n>\r\n>      这两个选项指定了允许连接到 RPC 服务的 IP 地址范围。172.0.0.0/8 是一个保留的私有地址段，192.168.0.0/16 是另一个私有地址段，用于允许在局域网内的设备连接到 RPC 服务。\r\n>\r\n> 6. \r\n>\r\n>    `rpcbind=0.0.0.0`：\r\n>\r\n>    - \r\n>\r\n>      这个选项指定了 RPC 服务绑定的 IP 地址。0.0.0.0 表示绑定到所有可用的网络接口，允许来自本地主机和局域网内设备的连接\r\n\r\n在本地电脑（需要100G以上，实测到2024年2月份大概95G）设置一个全新的文件夹，比如我的叫electrumx-docker\r\n\r\n![img](https://img.learnblockchain.cn/attachments/migrate/1719483303378)\r\n\r\n新建的文件夹\r\n\r\n#### 解读Usage：1. Download [docker-compose.yml](https://github.com/Next-DAO/atomicals-electrumx-docker/raw/main/docker-compose.yml) to a folder.\r\n\r\n修改docker-compose.yml,默认是这样的：\r\n\r\n\r\n\r\n```\r\nversion: '3'\r\nservices:\r\n  electrumx:\r\n    image: lucky2077/atomicals-electrumx:v1.3.9.0\r\n    restart: always\r\n    ports:\r\n      - 50001:50001\r\n      - 50002:50002\r\n      - 8000:8000\r\n      - 8080:8080\r\n    healthcheck:\r\n      test: \"nc -z localhost 50001\"\r\n      interval: 30s\r\n      timeout: 10s\r\n      retries: 3\r\n      start_period: 30s\r\n    volumes:\r\n      - ./electrumx-data:/data\r\n    environment:\r\n      - DAEMON_URL=nextdao:nextdao@127.0.0.1:8332\r\n      - COIN=BitCoin\r\n```\r\n\r\n官方的备注是\r\n\r\n\r\n\r\n```\r\nChange 127.0.0.1 to lan ip of the bitcoin core host, eg: 192.168.50.2.\r\n```\r\n\r\n注意！这里信息量很大。我的经验是无论就是127.0.0.1，还是改为localhost还是公网的IP，比如我的是121.xx.xx.xx，也都连不上比特币节点。这是为何？\r\n\r\n这是因为Docker内部虚拟出来了网络结构，127.0.0.1和locahhost已经不再是电脑的内部回环地址了！我们应该改为host.docker.internal\r\n\r\n\r\n```\r\nenvironment:\r\n      - DAEMON_URL=nextdao:nextdao@host.docker.internal:8332\r\n```\r\n\r\n我们来问问chatgpt这是干什么的:\r\n\r\n> `host.docker.internal` 是 Docker Desktop for Mac 或 Docker Desktop for Windows 中的一个特殊的 DNS 名称。它用于在容器内访问宿主机的服务。\r\n>\r\n> **在 Docker 中，通常容器是在自己的网络命名空间中运行的，它们默认无法直接访问宿主机上的服务**。但是，为了方便开发和调试，Docker 在 Docker Desktop for Mac 和 Docker Desktop for Windows 中引入了 `host.docker.internal` 这个特殊的 DNS 名称。**当你在容器内使用这个域名时，它会被解析为宿主机的 IP 地址**。\r\n>\r\n> 这使得容器内的应用程序能够轻松地与宿主机上的服务进行通信，无需知道宿主机的实际 IP 地址。这对于需要与本地开发环境中的服务进行交互的应用程序来说非常有用，因为它们可以像访问远程服务一样访问宿主机上的服务，而无需进行额外的配置。\r\n\r\n你如果再好奇，用这个命令看看主机到底分配了一个什么IP地址给Docker\r\n\r\n\r\n\r\n```\r\ndocker run --rm alpine nslookup host.docker.internal\r\n```\r\n\r\n我的结果显示是,可见其实是192.168.65.7分配给Docker了\r\n\r\n![img](https://img.learnblockchain.cn/attachments/migrate/1719483305149)\r\n\r\n**这一点很重要，不然你的Docker启动后会遇到这样的报错**：\r\n\r\n![img](https://img.learnblockchain.cn/attachments/migrate/1719483305524)\r\n\r\n### 解读2. Run the RPC server:\r\n\r\n接着做，\r\n\r\n\r\n\r\n```\r\ndocker-compose pull && docker-compose up -d\r\n```\r\n\r\n`docker-compose pull` 命令用于从远程镜像仓库拉取 Docker 镜像。这时你的docker 程序里 Image就多了一个镜像。\r\n\r\n`docker-compose up -d` 命令用于启动 Docker Compose 配置文件中定义的服务，并且在后台运行，选项 `-d` 表示以守护进程模式（后台模式）运行服务。\r\n\r\n这时候你会默认多一个Electrumx的目录结构是这样的，新建了一个叫electrumx-data的文件夹\r\n\r\n![img](https://img.learnblockchain.cn/attachments/migrate/1719483305546)\r\n\r\n打开文件夹的目录结构是这样的\r\n\r\n![img](https://img.learnblockchain.cn/attachments/migrate/1719483305749)\r\n\r\n如果你看到跟我一样的目录结构，就对了，恭喜你。看看官方在这一步都是怎么说的:\r\n\r\n- \r\n\r\n  the electrumx indexes stored in `./electrumx-data` directory.\r\n\r\n*备注*：在同一个目录下新建electrumx-data文件夹。这是因为我们在.env配置文件docker-compose.yml有如下这一行，这本质是挂载的数据目录，你可以在Containers-bind mounts里面找到同样的信息：\r\n\r\n\r\n\r\n```\r\nvolumes:\r\n      - ./electrumx-data:/data\r\n```\r\n\r\n- \r\n\r\n  use `docker-compose logs -f` to check the logs.\r\n\r\n*备注：其实在图形界面Container-log里面看得更完整一些*\r\n\r\n- \r\n\r\n  use `docker-compose down` to stop the server.\r\n\r\n别担心，这个命令这只会停止和删除Container，你的数据还在。\r\n\r\n如果要复用别人同步好的数据，怎么办？我们要修改数据挂载的地方，比如我的数据其实是在移动硬盘目录    /Volumes/Element/atomical-legacy下的，所以修改的方式是\r\n\r\n\r\n\r\n```\r\nvolumes:\r\n      - /Volumes/Element/atomical-legacy:/data\r\n```\r\n\r\n我为何这么啰嗦地写？很多新手肯定会像我一样，都不敢动手去改呢！\r\n\r\n\r\n\r\n如果你的Docker里的Electrumx运行成功了，你可以看到log里面各种同步信息，更进一步地，你可以试试这个命令\r\n\r\n\r\n\r\n```\r\ndocker-compose ps\r\n```\r\n\r\n看到类似的样子，这说明我们的electrumx服务在tcp的8080端口，tcp里的50001-50002都在监听\r\n\r\n![img](https://img.learnblockchain.cn/attachments/migrate/1719483305914)\r\n\r\n在mint quark那段时间，electrumx服务器还不支持http协议，所以那个时候我们还要再装一个proxy，但从无线挖矿开启后，官方升级到v1.3.9以后，已经支持http了，所以我们只需要安装一个程序。\r\n\r\nOK，再检查一遍你是否装好了，跟着我在浏览器输入\r\n\r\n\r\n\r\n```\r\nlocalhost:8080/proxy\r\n```\r\n\r\n结果如下\r\n\r\n![img](https://img.learnblockchain.cn/attachments/migrate/1719483306165)\r\n\r\n\r\n\r\n```\r\nlocalhost:8080/proxy/health\r\n```\r\n\r\n![img](https://img.learnblockchain.cn/attachments/migrate/1719483306229)\r\n\r\n注意，一般数据同步完了才会都显示true.\r\n\r\n先写到这里。大致的安装思路和背后的原理就是这样，大家如果有不同环境遇到的问题可以留言，或者自行请教chatgpt。\r\n\r\n------\r\n\r\n*欢迎关注作者并提出宝贵修改意见：https://twitter.com/zzmjxy*\r\n\r\n## 扩展\r\n[**🦜跟着Casey Rodarmor一起安装比特币全节点和Ord索引器(Part 1)**](https://learnblockchain.cn/article/8513)\r\n[**🐧Electrumx安装心得全纪录(Part 1)**](https://learnblockchain.cn/article/8515)\r\n[**🐧Electrumx安装心得全纪录（Part 2）**](https://learnblockchain.cn/article/8516)"},"author":{"user":"https://learnblockchain.cn/people/21122","address":null},"history":"bafkreih3kedjdg7azxqdkfdwlck4tkwbetbtbl4qxn7l3ppsafzyk7vlfu","timestamp":1719483571,"version":1}