Pocketnet is a decentralized social network based on the blockchain. There is no central authority or corporation. Platform is run by equal nodes on a blockchain with no centralized server. All revenue is split between node operators and content creators. Node operators stake Pocketcoin in order to mint blocks with rewards and transactions fees. Half of rewards in each block go to content creators based on ratings their content gathers from users. Read more in the article.
This software allows you to participate in the work of the blockchain network - https://pocketnet.app/help
.
To start a node independently, you need basic skills of working with the operating system, understanding the principle of the blockchain network. A deeper level of personal computer proficiency is welcome.
PocketnetCore is distributed in two ways: binary installer and build from source code.
Minimum system requirements:
- 2 core x86-64 CPU
- 4GB RAM
- 150 GB harddrive
- 10 Mbps internet connection
Recommended System Requirements
- 4 core x86-64 CPU
- 16 GB RAM
- 500 GB SSD Harddrive
- 100 Mbps internet connection
- Publicly accessible IP address and ports
Install package with root privilegies. To do this, open the terminal in the directory where you downloaded the installer and execute commands:
$ sudo dpkg -i pocketnetcore_*_linux_x64_setup.deb
Run the pocketnetcore_*_win_x64_setup.exe
and follow the instructions of the installer.
When you first start, the pocketnetcore desktop utility will ask for the location of the blockchain data directory. Default for Windows %APPDATA%/Pocketcoin
, for linux ~/.pocketcoin
.
Make sure that enough resources are allocated in your docker settings for the node to work from the section https://github.com/pocketnetteam/pocketnet.core#usage
You can start your node with a single command from Docker.
$ docker run -d \
--name=pocketnet.main \
-p 37070:37070 \
-p 38081:38081 \
-p 38881:38881 \
-p 8087:8087 \
-p 8887:8887 \
-v /var/pocketnet/.data:/home/pocketcoin/.pocketcoin \
pocketnetteam/pocketnet.core:latest
Sample docker-compose.yml
:
version: "3"
services:
pocketnet.core:
container_name: pocketnet.core
image: pocketnetteam/pocketnet.core:latest
restart: on-failure
stop_grace_period: 10m
# Increasing the number of available file descriptors
ulimits:
nofile:
soft: 65536
hard: 65536
# Create a Volume for the Blockchain database directory
volumes:
- ~/.pocketcoin:/home/pocketcore/.pocketcoin
ports:
# To accept connections from other network nodes
- 37070:37070
# Manage node. Be careful - port 37071 opens access to your node and wallet
- 37071:37071
# To accept HTTP POST requests along the path 127.0.0.1:38081/public/
- 38081:38081
# TLS version of HTTP POST
- 38881:38881
# For the ability to establish a WebSocket connection to a node to support notifications
- 8087:8087
# TLS version of WebSocket (WSS)
- 8887:8887
logging:
driver: "local"
options:
max-size: "10m"
max-file: "3"
Run via docker-compose:
$ docker-compose up -d
$ docker ps --format '{{.ID}}\t{{.Names}}\t{{.Image}}'
ea7759a47250 pocketnet.main pocketnetteam/pocketnet.core:latest
$
$ docker exec -it pocketnet.main /bin/sh
$
$ pocketcoin-cli --help
$ pocketcoin-tx --help
More information : https://hub.docker.com/r/pocketnetteam/pocketnet.core
To quickly synchronize and minimize traffic costs, you can run an empty node with additional parameters:
-listen=0
- disable the visibility of your node so that other novice nodes can't connect to you to download the blockchain.-blocksonly=1
- specifies the mode of operation without transaction relay. In this way, the node will load the blocks as a whole, ignoring individual transactions on the network.-disablewallet=1
- disables wallet mechanisms to speed up the synchronization process
After full synchronization, it is strongly recommended to disable these settings for the full operation of the node.
You can get the full list of parameters:
$ pocketcoind --help
- Stop the node.
- Download database archive:
# List all snapshots available at https://snapshot.pocketnet.app # Latest snapshot archive https://snapshot.pocketnet.app/latest.tgz
- There must be archive tgz with 3 directories:
blocks\ - ... indexes\ - ... pocketdb\ - main.sqlite3 - web.sqlite3
VERY IMPORTANT: save the wallet.dat file or wallets/ files before cleaning the directory. It is recommended to even save these files somewhere for backup.
- Clean out everything except wallet.dat file, wallets/ directory and pocketcoin.conf config file in the blockchain working directory and unpack the archive:
# for unix $ cd ~/.pocketcoin/ # or for windows $ cd %APPDATA%\Pocketcoin\ # or for macos $ cd ~/Library/Application\ Support/Pocketcoin/ # delete exists DB $ rm -r ./blocks $ rm -r ./chainstate $ rm -r ./indexes $ rm -r ./pocketdb # unpack new checkpoint DB # for tar.gz archive $ tar -xzf latest.tgz -C ./
- Make sure the folders and files inside are not set to "read only" (grant permissions to all files for current user via
chmod -R <username> ~/.pocketcoin/
unix command) - Start the node.
# get address for PKOIN receiving
$ pocketcoin-cli getnewaddress "node"
<received_adress>
$
# get private key info for private safe storage
$ pocketcoin-cli dumpprivkey "<received_address>"
See doc/build-*.md
files for build instructions.
You can get help and useful information from different sources:
- https://bastyon.com/help
- https://github.com/pocketnetteam/pocketnet.core/blob/master/doc/public_access.md
- https://github.com/pocketnetteam/pocketnet.core/tree/master/doc/help
- https://github.com/pocketnetteam/pocketnet.core/blob/master/share/examples/pocketcoin.conf
- Contact section below
Pocketnet Core is released under the terms of the Apache 2.0 license. See LICENSE for more information or see https://opensource.org/licenses/Apache-2.0.
[email protected] - general questions
[email protected] - blockchain nodes